mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-29 14:40:25 +00:00
Treat VEX.vvvv as a 3-bit field outside of 64-bit mode. Prevents access to registers xmm8-xmm15 outside 64-bit mode.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@140997 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
04b0b34b3a
commit
04c5be9f12
@ -1491,6 +1491,9 @@ static int readVVVV(struct InternalInstruction* insn) {
|
||||
else
|
||||
return -1;
|
||||
|
||||
if (insn->mode != MODE_64BIT)
|
||||
insn->vvvv &= 0x7;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -365,3 +365,6 @@
|
||||
|
||||
# CHECK: testq $0, %rax
|
||||
0x48 0xa9 0x00 0x00 0x00 0x00
|
||||
|
||||
# CHECK: vaddps %xmm3, %xmm15, %xmm0
|
||||
0xc4 0xe1 0x00 0x58 0xc3
|
||||
|
@ -384,3 +384,6 @@
|
||||
|
||||
# CHECK: movl %eax, 0
|
||||
0xa3 0x00 0x00 0x00 0x00
|
||||
|
||||
# CHECK: vaddps %xmm3, %xmm7, %xmm0
|
||||
0xc4 0xe1 0x00 0x58 0xc3
|
||||
|
Loading…
Reference in New Issue
Block a user