mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Revert r142618, r142622, and r142624, which were based on an incorrect reading of the ARMv7 docs.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142626 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fe0748d696
commit
cd20c58e98
@ -4562,13 +4562,8 @@ def MRSsys : ABI<0b0001, (outs GPR:$Rd), (ins), NoItinerary,
|
|||||||
// same and the assembly parser has no way to distinguish between them. The mask
|
// same and the assembly parser has no way to distinguish between them. The mask
|
||||||
// operand contains the special register (R Bit) in bit 4 and bits 3-0 contains
|
// operand contains the special register (R Bit) in bit 4 and bits 3-0 contains
|
||||||
// the mask with the fields to be accessed in the special register.
|
// the mask with the fields to be accessed in the special register.
|
||||||
//
|
def MSR : ABI<0b0001, (outs), (ins msr_mask:$mask, GPR:$Rn), NoItinerary,
|
||||||
// NOTE: There are separate versions of these instructions for M-class versus
|
"msr", "\t$mask, $Rn", []> {
|
||||||
// AR-class processors. M-class processors can accept a wider range of
|
|
||||||
// mask values than AR-class processors can.
|
|
||||||
def MSRm : ABI<0b0001, (outs), (ins msr_mask:$mask, GPR:$Rn), NoItinerary,
|
|
||||||
"msr", "\t$mask, $Rn", []>,
|
|
||||||
Requires<[IsMClass]> {
|
|
||||||
bits<5> mask;
|
bits<5> mask;
|
||||||
bits<4> Rn;
|
bits<4> Rn;
|
||||||
|
|
||||||
@ -4581,9 +4576,8 @@ def MSRm : ABI<0b0001, (outs), (ins msr_mask:$mask, GPR:$Rn), NoItinerary,
|
|||||||
let Inst{3-0} = Rn;
|
let Inst{3-0} = Rn;
|
||||||
}
|
}
|
||||||
|
|
||||||
def MSRmi : ABI<0b0011, (outs), (ins msr_mask:$mask, so_imm:$a), NoItinerary,
|
def MSRi : ABI<0b0011, (outs), (ins msr_mask:$mask, so_imm:$a), NoItinerary,
|
||||||
"msr", "\t$mask, $a", []>,
|
"msr", "\t$mask, $a", []> {
|
||||||
Requires<[IsMClass]> {
|
|
||||||
bits<5> mask;
|
bits<5> mask;
|
||||||
bits<12> a;
|
bits<12> a;
|
||||||
|
|
||||||
@ -4595,38 +4589,6 @@ def MSRmi : ABI<0b0011, (outs), (ins msr_mask:$mask, so_imm:$a), NoItinerary,
|
|||||||
let Inst{11-0} = a;
|
let Inst{11-0} = a;
|
||||||
}
|
}
|
||||||
|
|
||||||
def MSRar : ABI<0b0001, (outs), (ins msr_mask:$mask, GPR:$Rn), NoItinerary,
|
|
||||||
"msr", "\t$mask, $Rn", []>,
|
|
||||||
Requires<[IsARClass]> {
|
|
||||||
bits<5> mask;
|
|
||||||
bits<4> Rn;
|
|
||||||
|
|
||||||
let Inst{23} = 0;
|
|
||||||
let Inst{22} = 0;
|
|
||||||
let Inst{21-20} = 0b10;
|
|
||||||
let Inst{19-18} = mask{3-2};
|
|
||||||
let Inst{17-16} = 0b00;
|
|
||||||
let Inst{15-12} = 0b1111;
|
|
||||||
let Inst{11-4} = 0b00000000;
|
|
||||||
let Inst{3-0} = Rn;
|
|
||||||
}
|
|
||||||
|
|
||||||
def MSRari : ABI<0b0011, (outs), (ins msr_mask:$mask, so_imm:$a), NoItinerary,
|
|
||||||
"msr", "\t$mask, $a", []>,
|
|
||||||
Requires<[IsARClass]> {
|
|
||||||
bits<5> mask;
|
|
||||||
bits<12> a;
|
|
||||||
|
|
||||||
let Inst{23} = 0;
|
|
||||||
let Inst{22} = 0;
|
|
||||||
let Inst{21-20} = 0b10;
|
|
||||||
let Inst{19-18} = mask{3-2};
|
|
||||||
let Inst{17-16} = 0b00;
|
|
||||||
let Inst{15-12} = 0b1111;
|
|
||||||
let Inst{11-0} = a;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// TLS Instructions
|
// TLS Instructions
|
||||||
//
|
//
|
||||||
|
@ -928,15 +928,15 @@ Lforward:
|
|||||||
@ CHECK: msr APSR_nzcvq, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
@ CHECK: msr APSR_nzcvq, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
||||||
@ CHECK: msr APSR_nzcvq, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
@ CHECK: msr APSR_nzcvq, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
||||||
@ CHECK: msr APSR_nzcvqg, #5 @ encoding: [0x05,0xf0,0x2c,0xe3]
|
@ CHECK: msr APSR_nzcvqg, #5 @ encoding: [0x05,0xf0,0x2c,0xe3]
|
||||||
@ CHECK: msr CPSR_fc, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
@ CHECK: msr CPSR_fc, #5 @ encoding: [0x05,0xf0,0x29,0xe3]
|
||||||
@ CHECK: msr CPSR_c, #5 @ encoding: [0x05,0xf0,0x20,0xe3]
|
@ CHECK: msr CPSR_c, #5 @ encoding: [0x05,0xf0,0x21,0xe3]
|
||||||
@ CHECK: msr CPSR_x, #5 @ encoding: [0x05,0xf0,0x20,0xe3]
|
@ CHECK: msr CPSR_x, #5 @ encoding: [0x05,0xf0,0x22,0xe3]
|
||||||
@ CHECK: msr CPSR_fc, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
@ CHECK: msr CPSR_fc, #5 @ encoding: [0x05,0xf0,0x29,0xe3]
|
||||||
@ CHECK: msr CPSR_fc, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
@ CHECK: msr CPSR_fc, #5 @ encoding: [0x05,0xf0,0x29,0xe3]
|
||||||
@ CHECK: msr CPSR_fsx, #5 @ encoding: [0x05,0xf0,0x2c,0xe3]
|
@ CHECK: msr CPSR_fsx, #5 @ encoding: [0x05,0xf0,0x2e,0xe3]
|
||||||
@ CHECK: msr SPSR_fc, #5 @ encoding: [0x05,0xf0,0x28,0xe3]
|
@ CHECK: msr SPSR_fc, #5 @ encoding: [0x05,0xf0,0x69,0xe3]
|
||||||
@ CHECK: msr SPSR_fsxc, #5 @ encoding: [0x05,0xf0,0x2c,0xe3]
|
@ CHECK: msr SPSR_fsxc, #5 @ encoding: [0x05,0xf0,0x6f,0xe3]
|
||||||
@ CHECK: msr CPSR_fsxc, #5 @ encoding: [0x05,0xf0,0x2c,0xe3]
|
@ CHECK: msr CPSR_fsxc, #5 @ encoding: [0x05,0xf0,0x2f,0xe3]
|
||||||
|
|
||||||
msr apsr, r0
|
msr apsr, r0
|
||||||
msr apsr_g, r0
|
msr apsr_g, r0
|
||||||
@ -958,15 +958,15 @@ Lforward:
|
|||||||
@ CHECK: msr APSR_nzcvq, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
@ CHECK: msr APSR_nzcvq, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
||||||
@ CHECK: msr APSR_nzcvq, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
@ CHECK: msr APSR_nzcvq, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
||||||
@ CHECK: msr APSR_nzcvqg, r0 @ encoding: [0x00,0xf0,0x2c,0xe1]
|
@ CHECK: msr APSR_nzcvqg, r0 @ encoding: [0x00,0xf0,0x2c,0xe1]
|
||||||
@ CHECK: msr CPSR_fc, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
@ CHECK: msr CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
|
||||||
@ CHECK: msr CPSR_c, r0 @ encoding: [0x00,0xf0,0x20,0xe1]
|
@ CHECK: msr CPSR_c, r0 @ encoding: [0x00,0xf0,0x21,0xe1]
|
||||||
@ CHECK: msr CPSR_x, r0 @ encoding: [0x00,0xf0,0x20,0xe1]
|
@ CHECK: msr CPSR_x, r0 @ encoding: [0x00,0xf0,0x22,0xe1]
|
||||||
@ CHECK: msr CPSR_fc, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
@ CHECK: msr CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
|
||||||
@ CHECK: msr CPSR_fc, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
@ CHECK: msr CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
|
||||||
@ CHECK: msr CPSR_fsx, r0 @ encoding: [0x00,0xf0,0x2c,0xe1]
|
@ CHECK: msr CPSR_fsx, r0 @ encoding: [0x00,0xf0,0x2e,0xe1]
|
||||||
@ CHECK: msr SPSR_fc, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
|
@ CHECK: msr SPSR_fc, r0 @ encoding: [0x00,0xf0,0x69,0xe1]
|
||||||
@ CHECK: msr SPSR_fsxc, r0 @ encoding: [0x00,0xf0,0x2c,0xe1]
|
@ CHECK: msr SPSR_fsxc, r0 @ encoding: [0x00,0xf0,0x6f,0xe1]
|
||||||
@ CHECK: msr CPSR_fsxc, r0 @ encoding: [0x00,0xf0,0x2c,0xe1]
|
@ CHECK: msr CPSR_fsxc, r0 @ encoding: [0x00,0xf0,0x2f,0xe1]
|
||||||
|
|
||||||
@------------------------------------------------------------------------------
|
@------------------------------------------------------------------------------
|
||||||
@ MUL
|
@ MUL
|
||||||
|
@ -161,6 +161,12 @@
|
|||||||
# CHECK: cpsie if, #10
|
# CHECK: cpsie if, #10
|
||||||
0xca 0x00 0x0a 0xf1
|
0xca 0x00 0x0a 0xf1
|
||||||
|
|
||||||
|
# CHECK: msr CPSR_fc, r0
|
||||||
|
0x00 0xf0 0x29 0xe1
|
||||||
|
|
||||||
|
# CHECK: msrmi CPSR_c, #4043309056
|
||||||
|
0xf1 0xf4 0x21 0x43
|
||||||
|
|
||||||
# CHECK: rsbs r6, r7, r8
|
# CHECK: rsbs r6, r7, r8
|
||||||
0x08 0x60 0x77 0xe0
|
0x08 0x60 0x77 0xe0
|
||||||
|
|
||||||
|
@ -744,21 +744,65 @@
|
|||||||
# MSR
|
# MSR
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# CHECK: msr CPSR_fc, #5
|
||||||
|
# CHECK: msr APSR_g, #5
|
||||||
|
# CHECK: msr APSR_nzcvq, #5
|
||||||
|
# CHECK: msr APSR_nzcvq, #5
|
||||||
|
# CHECK: msr APSR_nzcvqg, #5
|
||||||
|
# CHECK: msr CPSR_fc, #5
|
||||||
# CHECK: msr CPSR_c, #5
|
# CHECK: msr CPSR_c, #5
|
||||||
# CHECK: msr CPSR_x, #5
|
# CHECK: msr CPSR_x, #5
|
||||||
# CHECK: msr CPSR_xc, #5
|
# CHECK: msr CPSR_fc, #5
|
||||||
|
# CHECK: msr CPSR_fc, #5
|
||||||
|
# CHECK: msr CPSR_fsx, #5
|
||||||
|
# CHECK: msr SPSR_fc, #5
|
||||||
|
# CHECK: msr SPSR_fsxc, #5
|
||||||
|
# CHECK: msr CPSR_fsxc, #5
|
||||||
|
|
||||||
|
0x05 0xf0 0x29 0xe3
|
||||||
0x05 0xf0 0x24 0xe3
|
0x05 0xf0 0x24 0xe3
|
||||||
0x05 0xf0 0x28 0xe3
|
0x05 0xf0 0x28 0xe3
|
||||||
|
0x05 0xf0 0x28 0xe3
|
||||||
0x05 0xf0 0x2c 0xe3
|
0x05 0xf0 0x2c 0xe3
|
||||||
|
0x05 0xf0 0x29 0xe3
|
||||||
|
0x05 0xf0 0x21 0xe3
|
||||||
|
0x05 0xf0 0x22 0xe3
|
||||||
|
0x05 0xf0 0x29 0xe3
|
||||||
|
0x05 0xf0 0x29 0xe3
|
||||||
|
0x05 0xf0 0x2e 0xe3
|
||||||
|
0x05 0xf0 0x69 0xe3
|
||||||
|
0x05 0xf0 0x6f 0xe3
|
||||||
|
0x05 0xf0 0x2f 0xe3
|
||||||
|
|
||||||
|
# CHECK: msr CPSR_fc, r0
|
||||||
|
# CHECK: msr APSR_g, r0
|
||||||
|
# CHECK: msr APSR_nzcvq, r0
|
||||||
|
# CHECK: msr APSR_nzcvq, r0
|
||||||
|
# CHECK: msr APSR_nzcvqg, r0
|
||||||
|
# CHECK: msr CPSR_fc, r0
|
||||||
# CHECK: msr CPSR_c, r0
|
# CHECK: msr CPSR_c, r0
|
||||||
# CHECK: msr CPSR_x, r0
|
# CHECK: msr CPSR_x, r0
|
||||||
# CHECK: msr CPSR_xc, r0
|
# CHECK: msr CPSR_fc, r0
|
||||||
|
# CHECK: msr CPSR_fc, r0
|
||||||
|
# CHECK: msr CPSR_fsx, r0
|
||||||
|
# CHECK: msr SPSR_fc, r0
|
||||||
|
# CHECK: msr SPSR_fsxc, r0
|
||||||
|
# CHECK: msr CPSR_fsxc, r0
|
||||||
|
|
||||||
|
0x00 0xf0 0x29 0xe1
|
||||||
0x00 0xf0 0x24 0xe1
|
0x00 0xf0 0x24 0xe1
|
||||||
0x00 0xf0 0x28 0xe1
|
0x00 0xf0 0x28 0xe1
|
||||||
|
0x00 0xf0 0x28 0xe1
|
||||||
0x00 0xf0 0x2c 0xe1
|
0x00 0xf0 0x2c 0xe1
|
||||||
|
0x00 0xf0 0x29 0xe1
|
||||||
|
0x00 0xf0 0x21 0xe1
|
||||||
|
0x00 0xf0 0x22 0xe1
|
||||||
|
0x00 0xf0 0x29 0xe1
|
||||||
|
0x00 0xf0 0x29 0xe1
|
||||||
|
0x00 0xf0 0x2e 0xe1
|
||||||
|
0x00 0xf0 0x69 0xe1
|
||||||
|
0x00 0xf0 0x6f 0xe1
|
||||||
|
0x00 0xf0 0x2f 0xe1
|
||||||
|
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
# MUL
|
# MUL
|
||||||
|
Loading…
x
Reference in New Issue
Block a user