target-i386: Add Core Duo Definition
This patch adds a CPU definition for the Core Duo CPU. I tried to resemble the original as closely as possible and document what features are missing still. This patch enables the use of a recent CPU definition on 32 bit platforms. It also fixes two issues that went along the line: - invalid xlevel in core2duo spec While looking though the CPUIDs again, I found that xlevel is actually 8. - non-PSE36 support The CoreDuo CPUID does not expose the PSE36 capability, but CPUID 0x80000008 is tied to 36 bits. This broke Windows XP installation for me, so I just set it to 32 bits width when PSE36 is not available. The original CPU also exposes 32 bit width in CPUID 0x80000008. Signed-off-by: Alexander Graf <agraf@suse.de> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5488 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
		
							parent
							
								
									7ab064d2b5
								
							
						
					
					
						commit
						45fd08effd
					
				| @ -183,7 +183,7 @@ static x86_def_t x86_defs[] = { | |||||||
|         .ext_features = CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3, |         .ext_features = CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3, | ||||||
|         .ext2_features = CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX, |         .ext2_features = CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX, | ||||||
|         /* Missing: .ext3_features = CPUID_EXT3_LAHF_LM */ |         /* Missing: .ext3_features = CPUID_EXT3_LAHF_LM */ | ||||||
|         .xlevel = 0x8000000A, |         .xlevel = 0x80000008, | ||||||
|         .model_id = "Intel(R) Core(TM)2 Duo CPU     T7700  @ 2.40GHz", |         .model_id = "Intel(R) Core(TM)2 Duo CPU     T7700  @ 2.40GHz", | ||||||
|     }, |     }, | ||||||
| #endif | #endif | ||||||
| @ -198,6 +198,25 @@ static x86_def_t x86_defs[] = { | |||||||
|         .xlevel = 0, |         .xlevel = 0, | ||||||
|         .model_id = "QEMU Virtual CPU version " QEMU_VERSION, |         .model_id = "QEMU Virtual CPU version " QEMU_VERSION, | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |         .name = "coreduo", | ||||||
|  |         .level = 10, | ||||||
|  |         .family = 6, | ||||||
|  |         .model = 14, | ||||||
|  |         .stepping = 8, | ||||||
|  |         /* The original CPU also implements these features:
 | ||||||
|  |                CPUID_DTS, CPUID_ACPI, CPUID_SS, CPUID_HT, | ||||||
|  |                CPUID_TM, CPUID_PBE */ | ||||||
|  |         .features = PPRO_FEATURES | CPUID_VME | | ||||||
|  |             CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA, | ||||||
|  |         /* The original CPU also implements these ext features:
 | ||||||
|  |                CPUID_EXT_VMX, CPUID_EXT_EST, CPUID_EXT_TM2, CPUID_EXT_XTPR, | ||||||
|  |                CPUID_EXT_PDCM */ | ||||||
|  |         .ext_features = CPUID_EXT_SSE3 | CPUID_EXT_MONITOR, | ||||||
|  |         .ext2_features = CPUID_EXT2_NX, | ||||||
|  |         .xlevel = 0x80000008, | ||||||
|  |         .model_id = "Genuine Intel(R) CPU           T2600  @ 2.16GHz", | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         .name = "486", |         .name = "486", | ||||||
|         .level = 0, |         .level = 0, | ||||||
|  | |||||||
| @ -2026,7 +2026,10 @@ void helper_cpuid(void) | |||||||
| #if defined(USE_KQEMU) | #if defined(USE_KQEMU) | ||||||
|             EAX = 0x00000020;	/* 32 bits physical */ |             EAX = 0x00000020;	/* 32 bits physical */ | ||||||
| #else | #else | ||||||
|  |             if (env->cpuid_features & CPUID_PSE36) | ||||||
|                 EAX = 0x00000024; /* 36 bits physical */ |                 EAX = 0x00000024; /* 36 bits physical */ | ||||||
|  |             else | ||||||
|  |                 EAX = 0x00000020; /* 32 bits physical */ | ||||||
| #endif | #endif | ||||||
|         } |         } | ||||||
|         EBX = 0; |         EBX = 0; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 aurel32
						aurel32