I don’t actually plan on doing this, just curious and trying to learn how various intermediate representation languages work. Similar to how the JVM and .NET compile higher level languages to an assembly-like intermediate language, which is then executed on a JIT compiler, could we do that with LLVM IR to make any LLVM-based language like Rust, Objective C or Swift “interpreted” on a level similar to the JVM? Maybe even interop them since now they’re running on the same interpreter like how Java, Kotlin and Scala can all work together; or C#, F# and Visual Basic. And since LLVM IR is cross platform, I can imagine this can be an easy way to have platform agnostic executables for languages where you’d normally have to compile separate binaries, and since LLVM doesn’t have a garbage collector, of you use a parent language that also doesn’t have a garbage collector, you could probably get more reliable latency than JVM or .NET, right?
Does such a runtime already exist? And does LLVM IR have a pure binary version that would actually make it similar to the bytecodes of other languages?
This exists as part of the LLVM project. LLVM was originally a virtual machine, the title used to stand for Low-Level Virtual Machine. It was only later that it gained the focus on ahead-of-time compiling.
LLVM IR has a binary format, it is semantically equivalent to the text format.
I’m not aware of any general purpose “execute this IR file” programs, but I am not aware of any reason you couldn’t do it. I suspect that the IR format isn’t optimal for this use case but it is probably decent enough.