Assembler for an abstract machine

Programming, for all ages and all languages.
User avatar
Thomas
Member
Member
Posts: 284
Joined: Thu Jun 04, 2009 11:12 pm

Re: Assembler for an abstract machine

Post by Thomas »

Hobbes wrote:Gravaera, Solar,
I don't know much about code optimization, but isn't this true for every Intermediate Language? It doesn't need to have an assembly-like syntax, or am I missing something?
Yes you are right Hobbes.That's the case with most of the popular commercial implementations.MSIL supports constructs like allocating memory,declaring a class etc which is not that low level ,I am in the middle of reading a book on the internals of Java VM,I shall post more about that after sometime :). However both of them are stack based :) .They are close to some extent but not as close as you would expect :)
--Thomas
User avatar
Owen
Member
Member
Posts: 1700
Joined: Fri Jun 13, 2008 3:21 pm
Location: Cambridge, United Kingdom
Contact:

Re: Assembler for an abstract machine

Post by Owen »

Solar wrote:gravaera more or less named it.

The compiler already did the bulk work of parsing the high-level language (using one of multiple frontends), as well as the brunt of the optimizing work. Unreachable code has been eliminated, return value optimizations have been done, all the stuff that takes up clock cycles.

The loader / translater only has to map the virtual registers to physical / memory, and translate the virtual opcodes to native ones - simple lookup work, which can be done with reasonable efficiency even on low-on-horsepower embedded systems.
Most LLVM compilers don't have optimizers. They leave it all up to LLVM: After all, bticode makes both a good cross platform "assembly" language and an excellent intermediate language for optimization, and LLVM has very effective optimizers (For example: Clang regularly trades places with GCC performance wise, and uses LLVM's optimizers for all optimizations).

But bitcode is as close to a cross platform assembly as you get
User avatar
Solar
Member
Member
Posts: 7615
Joined: Thu Nov 16, 2006 12:01 pm
Location: Germany
Contact:

Re: Assembler for an abstract machine

Post by Solar »

What I said about Tao's VP technology (most of the optimization done AOT) was straight from what I remembered from the presentations they gave and the AmigaDE SDK documentation.

I can't judge on the validity of their claims, or the concept as a whole, and I won't.
Every good solution is obvious once you've found it.
User avatar
qw
Member
Member
Posts: 792
Joined: Mon Jan 26, 2009 2:48 am

Re: Assembler for an abstract machine

Post by qw »

All right, what I make of all of this is that LLVM is a way to produce code that is optimized before it is translated to a certain platform. That makes sense, though I am curious how it performs in practice.
User avatar
Owen
Member
Member
Posts: 1700
Joined: Fri Jun 13, 2008 3:21 pm
Location: Cambridge, United Kingdom
Contact:

Re: Assembler for an abstract machine

Post by Owen »

Hobbes wrote:All right, what I make of all of this is that LLVM is a way to produce code that is optimized before it is translated to a certain platform. That makes sense, though I am curious how it performs in practice.
Very well. And note that the target specific optimizations are implemented - in the target backend ;)

Also, most compilers do their optimizations on a nonspecific IR. For example, GCC does it on GIMPLE
Post Reply