|  | Date: Wed, 20 Jun 2001 12:32:22 -0500 | 
|  | From: Vikram Adve <vadve@cs.uiuc.edu> | 
|  | To: Chris Lattner <lattner@cs.uiuc.edu> | 
|  | Subject: .NET vs. our VM | 
|  |  | 
|  | One significant difference between .NET CLR and our VM is that the CLR | 
|  | includes full information about classes and inheritance.  In fact, I just | 
|  | sat through the paper on adding templates to .NET CLR, and the speaker | 
|  | indicated that the goal seems to be to do simple static compilation (very | 
|  | little lowering or optimization).  Also, the templates implementation in CLR | 
|  | "relies on dynamic class loading and JIT compilation". | 
|  |  | 
|  | This is an important difference because I think there are some significant | 
|  | advantages to have a much lower level VM layer, and do significant static | 
|  | analysis and optimization. | 
|  |  | 
|  | I also talked to the lead guy for KAI's C++ compiler (Arch Robison) and he | 
|  | said that SGI and other commercial compilers have included options to export | 
|  | their *IR* next to the object code (i.e., .il files) and use them for | 
|  | link-time code generation.  In fact, he said that the .o file was nearly | 
|  | empty and was entirely generated from the .il at link-time.  But he agreed | 
|  | that this limited the link-time interprocedural optimization to modules | 
|  | compiled by the same compiler, whereas our approach allows us to link and | 
|  | optimize modules from multiple different compilers.  (Also, of course, they | 
|  | don't do anything for runtime optimization). | 
|  |  | 
|  | All issues to bring up in Related Work. | 
|  |  | 
|  | --Vikram | 
|  |  |