[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / MC / ARM / virtexts-thumb.s
blob0ea0bafe5a865a90df87eaaeccd4c959592e1ee2
1 # RUN: llvm-mc -triple thumbv7 -mattr=virtualization -show-encoding %s | FileCheck %s --check-prefix=CHECK-THUMB
3 hvc #1
4 hvc #7
5 hvc #257
6 hvc #65535
7 # CHECK-THUMB: [0xe0,0xf7,0x01,0x80]
8 # CHECK-THUMB: [0xe0,0xf7,0x07,0x80]
9 # CHECK-THUMB: [0xe0,0xf7,0x01,0x81]
10 # CHECK-THUMB: [0xef,0xf7,0xff,0x8f]
12 hvc.w #1
13 hvc.w #7
14 hvc.w #257
15 hvc.w #65535
16 # CHECK-THUMB: [0xe0,0xf7,0x01,0x80]
17 # CHECK-THUMB: [0xe0,0xf7,0x07,0x80]
18 # CHECK-THUMB: [0xe0,0xf7,0x01,0x81]
19 # CHECK-THUMB: [0xef,0xf7,0xff,0x8f]
21 eret
22 it eq; ereteq
23 it ne; eretne
24 it hs; ereths
25 it lo; eretlo
26 it mi; eretmi
27 it pl; eretpl
28 it vs; eretvs
29 it vc; eretvc
30 it hi; erethi
31 it ls; eretls
32 it ge; eretge
33 it lt; eretlt
34 it gt; eretgt
35 it le; eretle
36 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
37 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
38 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
39 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
40 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
41 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
42 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
43 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
44 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
45 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
46 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
47 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
48 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
49 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
50 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
52 # SUBS PC, LR, #0 should have the same encoding as ERET.
53 # The conditional forms can't be tested because the ARM assembler parser doesn't
54 # accept SUBS<cond> PC, LR, #<imm>, only the unconditonal form is allowed. This
55 # is due to the way that the custom parser handles optional operands; see the
56 # FIXME in ARM/AsmParser/ARMAsmParser.cpp.
58 subs pc, lr, #0
59 # CHECK-THUMB: [0xde,0xf3,0x00,0x8f]