mirror of
				https://gitlab.com/freepascal.org/fpc/source.git
				synced 2025-10-26 21:51:59 +01:00 
			
		
		
		
	 4d86d25c6c
			
		
	
	
		4d86d25c6c
		
	
	
	
	
		
			
			like field reordering (possible problems cracker classes) or using ebp as normal register (broken
      stack traces from dump_stack)
    + niln is also valid in a cse domain
    * parameters passed by reference shall have a complexity >1
    * load nodes from outer scopes shall have a complexity >1
    * better cse debugging
    + more node types added to cse
    * consider parameters passed by reference in cse
    * take care of cse in parameters in simple cases
git-svn-id: trunk@22050 -
		
	
			
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			ObjectPascal
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			ObjectPascal
		
	
	
	
	
	
| {
 | |
|     Copyright (c) 2010 by the Free Pascal development team
 | |
| 
 | |
|     Basic Processor information for the Java VM
 | |
| 
 | |
|     See the file COPYING.FPC, included in this distribution,
 | |
|     for details about the copyright.
 | |
| 
 | |
|     This program is distributed in the hope that it will be useful,
 | |
|     but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 | |
| 
 | |
|  **********************************************************************}
 | |
| 
 | |
| Unit cpuinfo;
 | |
| 
 | |
| Interface
 | |
| 
 | |
|   uses
 | |
|     globtype;
 | |
| 
 | |
| Type
 | |
|    bestreal = double;
 | |
|    ts32real = single;
 | |
|    ts64real = double;
 | |
|    ts80real = extended;
 | |
|    ts128real = extended;
 | |
|    ts64comp = comp;
 | |
| 
 | |
|    pbestreal=^bestreal;
 | |
| 
 | |
|    { possible supported processors for this target }
 | |
|    tcputype =
 | |
|       (cpu_none,
 | |
|        { jvm, same as cpu_none }
 | |
|        cpu_jvm,
 | |
|        { jvm byte code to be translated into Dalvik bytecode: more type-
 | |
|          sensitive }
 | |
|        cpu_dalvik
 | |
|       );
 | |
| 
 | |
|    tfputype =
 | |
|      (fpu_none,
 | |
|       fpu_standard
 | |
|      );
 | |
| 
 | |
| 
 | |
| Const
 | |
|    { calling conventions supported by the code generator }
 | |
|    supported_calling_conventions : tproccalloptions = [
 | |
|      pocall_internproc
 | |
|    ];
 | |
| 
 | |
|    cputypestr : array[tcputype] of string[9] = ('',
 | |
|      'JVM',
 | |
|      'JVMDALVIK'
 | |
|    );
 | |
| 
 | |
|    fputypestr : array[tfputype] of string[8] = (
 | |
|      'NONE',
 | |
|      'STANDARD'
 | |
|    );
 | |
| 
 | |
|    { Supported optimizations, only used for information }
 | |
|    supported_optimizerswitches = genericlevel1optimizerswitches+
 | |
|                                  genericlevel2optimizerswitches+
 | |
|                                  genericlevel3optimizerswitches-
 | |
|                                  { no need to write info about those }
 | |
|                                  [cs_opt_level1,cs_opt_level2,cs_opt_level3]+
 | |
|                                  [cs_opt_loopunroll,cs_opt_nodecse];
 | |
| 
 | |
|    level1optimizerswitches = genericlevel1optimizerswitches;
 | |
|    level2optimizerswitches = genericlevel2optimizerswitches + level1optimizerswitches + [cs_opt_nodecse];
 | |
|    level3optimizerswitches = genericlevel3optimizerswitches + level2optimizerswitches + [{,cs_opt_loopunroll}];
 | |
|    level4optimizerswitches = genericlevel4optimizerswitches + level3optimizerswitches + [];
 | |
| 
 | |
| Implementation
 | |
| 
 | |
| end.
 |