[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / MC / ARM / thumb2-mclass.s
blob331ecc147629691b2e147fa7467212c8f2a48652
1 @ RUN: llvm-mc -triple=thumbv6m -show-encoding < %s | FileCheck --check-prefix=CHECK --check-prefix=CHECK-V6M %s
2 @ RUN: llvm-mc -triple=thumbv7m -show-encoding < %s | FileCheck --check-prefix=CHECK --check-prefix=CHECK-V7M %s
4 .syntax unified
6 @ Check that the assembler can handle the documented syntax from the ARM ARM.
7 @ These tests test instruction encodings specific to v6m & v7m (FeatureMClass).
9 @------------------------------------------------------------------------------
10 @ MRS
11 @------------------------------------------------------------------------------
13 mrs r0, apsr
14 mrs r0, iapsr
15 mrs r0, eapsr
16 mrs r0, xpsr
17 mrs r0, ipsr
18 mrs r0, epsr
19 mrs r0, iepsr
20 mrs r0, msp
21 mrs r0, psp
22 mrs r0, primask
23 mrs r0, control
25 @ CHECK: mrs r0, apsr @ encoding: [0xef,0xf3,0x00,0x80]
26 @ CHECK: mrs r0, iapsr @ encoding: [0xef,0xf3,0x01,0x80]
27 @ CHECK: mrs r0, eapsr @ encoding: [0xef,0xf3,0x02,0x80]
28 @ CHECK: mrs r0, xpsr @ encoding: [0xef,0xf3,0x03,0x80]
29 @ CHECK: mrs r0, ipsr @ encoding: [0xef,0xf3,0x05,0x80]
30 @ CHECK: mrs r0, epsr @ encoding: [0xef,0xf3,0x06,0x80]
31 @ CHECK: mrs r0, iepsr @ encoding: [0xef,0xf3,0x07,0x80]
32 @ CHECK: mrs r0, msp @ encoding: [0xef,0xf3,0x08,0x80]
33 @ CHECK: mrs r0, psp @ encoding: [0xef,0xf3,0x09,0x80]
34 @ CHECK: mrs r0, primask @ encoding: [0xef,0xf3,0x10,0x80]
35 @ CHECK: mrs r0, control @ encoding: [0xef,0xf3,0x14,0x80]
37 @------------------------------------------------------------------------------
38 @ MSR
39 @------------------------------------------------------------------------------
41 msr apsr, r0
42 msr apsr_nzcvq, r0
43 msr iapsr, r0
44 msr iapsr_nzcvq, r0
45 msr eapsr, r0
46 msr eapsr_nzcvq, r0
47 msr xpsr, r0
48 msr xpsr_nzcvq, r0
49 msr ipsr, r0
50 msr epsr, r0
51 msr iepsr, r0
52 msr msp, r0
53 msr psp, r0
54 msr primask, r0
55 msr control, r0
57 @ CHECK-V6M: msr apsr, r0 @ encoding: [0x80,0xf3,0x00,0x88]
58 @ CHECK-V6M: msr apsr, r0 @ encoding: [0x80,0xf3,0x00,0x88]
59 @ CHECK-V6M: msr iapsr, r0 @ encoding: [0x80,0xf3,0x01,0x88]
60 @ CHECK-V6M: msr iapsr, r0 @ encoding: [0x80,0xf3,0x01,0x88]
61 @ CHECK-V6M: msr eapsr, r0 @ encoding: [0x80,0xf3,0x02,0x88]
62 @ CHECK-V6M: msr eapsr, r0 @ encoding: [0x80,0xf3,0x02,0x88]
63 @ CHECK-V6M: msr xpsr, r0 @ encoding: [0x80,0xf3,0x03,0x88]
64 @ CHECK-V6M: msr xpsr, r0 @ encoding: [0x80,0xf3,0x03,0x88]
65 @ CHECK-V7M: msr apsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x00,0x88]
66 @ CHECK-V7M: msr apsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x00,0x88]
67 @ CHECK-V7M: msr iapsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x01,0x88]
68 @ CHECK-V7M: msr iapsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x01,0x88]
69 @ CHECK-V7M: msr eapsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x02,0x88]
70 @ CHECK-V7M: msr eapsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x02,0x88]
71 @ CHECK-V7M: msr xpsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x03,0x88]
72 @ CHECK-V7M: msr xpsr_nzcvq, r0 @ encoding: [0x80,0xf3,0x03,0x88]
73 @ CHECK: msr ipsr, r0 @ encoding: [0x80,0xf3,0x05,0x88]
74 @ CHECK: msr epsr, r0 @ encoding: [0x80,0xf3,0x06,0x88]
75 @ CHECK: msr iepsr, r0 @ encoding: [0x80,0xf3,0x07,0x88]
76 @ CHECK: msr msp, r0 @ encoding: [0x80,0xf3,0x08,0x88]
77 @ CHECK: msr psp, r0 @ encoding: [0x80,0xf3,0x09,0x88]
78 @ CHECK: msr primask, r0 @ encoding: [0x80,0xf3,0x10,0x88]
79 @ CHECK: msr control, r0 @ encoding: [0x80,0xf3,0x14,0x88]