mirror of
				https://gitlab.com/freepascal.org/fpc/source.git
				synced 2025-10-31 16:31:36 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			106 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			ObjectPascal
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			3.0 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;
 | |
| {$if FPC_FULLVERSION>20700}
 | |
|    bestrealrec = TDoubleRec;
 | |
| {$endif FPC_FULLVERSION>20700}
 | |
|    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
 | |
|      );
 | |
| 
 | |
|    tcontrollertype =
 | |
|      (ct_none
 | |
|      );
 | |
| 
 | |
|    tcontrollerdatatype = record
 | |
|       controllertypestr, controllerunitstr: string[20];
 | |
|       cputype: tcputype; fputype: tfputype;
 | |
|       flashbase, flashsize, srambase, sramsize, eeprombase, eepromsize, bootbase, bootsize: dword;
 | |
|    end;
 | |
| 
 | |
| 
 | |
| Const
 | |
|    { Is there support for dealing with multiple microcontrollers available }
 | |
|    { for this platform? }
 | |
|    ControllerSupport = false;
 | |
| 
 | |
|    { We know that there are fields after sramsize
 | |
|      but we don't care about this warning }
 | |
|    {$PUSH}
 | |
|     {$WARN 3177 OFF}
 | |
|    embedded_controllers : array [tcontrollertype] of tcontrollerdatatype =
 | |
|    (
 | |
|       (controllertypestr:''; controllerunitstr:''; cputype:cpu_none; fputype:fpu_none; flashbase:0; flashsize:0; srambase:0; sramsize:0));
 | |
|    {$POP}
 | |
| 
 | |
|    { 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.
 | 
