1# RUN: llvm-mc -triple thumbv7 -mattr=virtualization -show-encoding %s | FileCheck %s --check-prefix=CHECK-THUMB
2
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]
11
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]
20
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]
51
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.
57
58    subs pc, lr, #0
59# CHECK-THUMB: [0xde,0xf3,0x00,0x8f]
60