mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-26 01:58:22 +00:00 
			
		
		
		
	target-i386: Make x86 mfence and lfence illegal without SSE2
While trying to use qemu -cpu pentium3 to test for incorrect uses of certain SSE2 instructions, I found that QEMU allowed the mfence and lfence instructions to be executed even though Pentium 3 doesn't support them. According to the processor specs (and experience on a real Pentium 3), these instructions are only available with SSE2, but QEMU is checking for SSE. The check for the related sfence instruction is correct (it works with SSE). This trival patch fixes the test. Signed-off-by: Martin Simmons <martin@lispworks.com> Signed-off-by: Stefan Hajnoczi <stefanha@linux.vnet.ibm.com>
This commit is contained in:
		
							parent
							
								
									351326a618
								
							
						
					
					
						commit
						8001c294f8
					
				| @ -7538,7 +7538,7 @@ static target_ulong disas_insn(DisasContext *s, target_ulong pc_start) | ||||
|             break; | ||||
|         case 5: /* lfence */ | ||||
|         case 6: /* mfence */ | ||||
|             if ((modrm & 0xc7) != 0xc0 || !(s->cpuid_features & CPUID_SSE)) | ||||
|             if ((modrm & 0xc7) != 0xc0 || !(s->cpuid_features & CPUID_SSE2)) | ||||
|                 goto illegal_op; | ||||
|             break; | ||||
|         case 7: /* sfence / clflush */ | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Martin Simmons
						Martin Simmons