1 // RUN
: llvm-mc
-arch
=amdgcn
-show-encoding
%s | FileCheck
-check-prefix
=SI
%s
2 // RUN
: llvm-mc
-arch
=amdgcn
-mcpu
=tonga
-show-encoding
%s | FileCheck
-check-prefix
=VI
%s
4 exp mrt0 off
, off
, off
, off
5 // SI
: exp mrt0 off
, off
, off
, off ; encoding
: [0x00,0x00,0x00,0xf8,0x00,0x00,0x00,0x00]
6 // VI
: exp mrt0 off
, off
, off
, off ; encoding
: [0x00,0x00,0x00,0xc4,0x00,0x00,0x00,0x00]
8 exp mrt0 off
, off
, off
, off done
9 // SI
: exp mrt0 off
, off
, off
, off done ; encoding
: [0x00,0x08,0x00,0xf8,0x00,0x00,0x00,0x00]
10 // VI
: exp mrt0 off
, off
, off
, off done ; encoding
: [0x00,0x08,0x00,0xc4,0x00,0x00,0x00,0x00]
12 exp mrt0 v4
, off
, off
, off done
13 // SI
: exp mrt0 v4
, off
, off
, off done ; encoding
: [0x01,0x08,0x00,0xf8,0x04,0x00,0x00,0x00]
14 // VI
: exp mrt0 v4
, off
, off
, off done ; encoding
: [0x01,0x08,0x00,0xc4,0x04,0x00,0x00,0x00]
16 exp mrt0 off
, v3
, off
, off done
17 // SI
: exp mrt0 off
, v3
, off
, off done ; encoding
: [0x02,0x08,0x00,0xf8,0x00,0x03,0x00,0x00]
18 // VI
: exp mrt0 off
, v3
, off
, off done ; encoding
: [0x02,0x08,0x00,0xc4,0x00,0x03,0x00,0x00]
20 exp mrt0 off
, off
, v2
, off done
21 // SI
: exp mrt0 off
, off
, v2
, off done ; encoding
: [0x04,0x08,0x00,0xf8,0x00,0x00,0x02,0x00]
22 // VI
: exp mrt0 off
, off
, v2
, off done ; encoding
: [0x04,0x08,0x00,0xc4,0x00,0x00,0x02,0x00]
24 exp mrt0 off
, off
, off
, v1 done
25 // SI
: exp mrt0 off
, off
, off
, v1 done ; encoding
: [0x08,0x08,0x00,0xf8,0x00,0x00,0x00,0x01]
26 // VI
: exp mrt0 off
, off
, off
, v1 done ; encoding
: [0x08,0x08,0x00,0xc4,0x00,0x00,0x00,0x01]
28 exp mrt0 v4
, v3
, off
, off done
29 // SI
: exp mrt0 v4
, v3
, off
, off done ; encoding
: [0x03,0x08,0x00,0xf8,0x04,0x03,0x00,0x00]
30 // VI
: exp mrt0 v4
, v3
, off
, off done ; encoding
: [0x03,0x08,0x00,0xc4,0x04,0x03,0x00,0x00]
32 exp mrt0 v4
, off
, v2
, off done
33 // SI
: exp mrt0 v4
, off
, v2
, off done ; encoding
: [0x05,0x08,0x00,0xf8,0x04,0x00,0x02,0x00]
34 // VI
: exp mrt0 v4
, off
, v2
, off done ; encoding
: [0x05,0x08,0x00,0xc4,0x04,0x00,0x02,0x00]
36 exp mrt0 v4
, off
, off
, v1
37 // SI
: exp mrt0 v4
, off
, off
, v1 ; encoding
: [0x09,0x00,0x00,0xf8,0x04,0x00,0x00,0x01]
38 // VI
: exp mrt0 v4
, off
, off
, v1 ; encoding
: [0x09,0x00,0x00,0xc4,0x04,0x00,0x00,0x01]
40 exp mrt0 v4
, off
, off
, v1 done
41 // SI
: exp mrt0 v4
, off
, off
, v1 done ; encoding
: [0x09,0x08,0x00,0xf8,0x04,0x00,0x00,0x01]
42 // VI
: exp mrt0 v4
, off
, off
, v1 done ; encoding
: [0x09,0x08,0x00,0xc4,0x04,0x00,0x00,0x01]
44 exp mrt0 v4
, v3
, v2
, v1
45 // SI
: exp mrt0 v4
, v3
, v2
, v1 ; encoding
: [0x0f,0x00,0x00,0xf8,0x04,0x03,0x02,0x01]
46 // VI
: exp mrt0 v4
, v3
, v2
, v1 ; encoding
: [0x0f,0x00,0x00,0xc4,0x04,0x03,0x02,0x01]
48 exp mrt0 v4
, v3
, v2
, v1 done
49 // SI
: exp mrt0 v4
, v3
, v2
, v1 done ; encoding
: [0x0f,0x08,0x00,0xf8,0x04,0x03,0x02,0x01]
50 // VI
: exp mrt0 v4
, v3
, v2
, v1 done ; encoding
: [0x0f,0x08,0x00,0xc4,0x04,0x03,0x02,0x01]
52 exp mrt7 v1
, v1
, v1
, v1
53 // SI
: exp mrt7 v1
, v1
, v1
, v1 ; encoding
: [0x7f,0x00,0x00,0xf8,0x01,0x01,0x01,0x01]
54 // VI
: exp mrt7 v1
, v1
, v1
, v1 ; encoding
: [0x7f,0x00,0x00,0xc4,0x01,0x01,0x01,0x01]
56 exp mrt7 v1
, v1
, v1
, v1 done
57 // SI
: exp mrt7 v1
, v1
, v1
, v1 done ; encoding
: [0x7f,0x08,0x00,0xf8,0x01,0x01,0x01,0x01]
58 // VI
: exp mrt7 v1
, v1
, v1
, v1 done ; encoding
: [0x7f,0x08,0x00,0xc4,0x01,0x01,0x01,0x01]
60 exp mrtz v4
, v3
, v2
, v1
61 // SI
: exp mrtz v4
, v3
, v2
, v1 ; encoding
: [0x8f,0x00,0x00,0xf8,0x04,0x03,0x02,0x01]
62 // VI
: exp mrtz v4
, v3
, v2
, v1 ; encoding
: [0x8f,0x00,0x00,0xc4,0x04,0x03,0x02,0x01]
64 exp mrtz v4
, v3
, v2
, v1 done
65 // SI
: exp mrtz v4
, v3
, v2
, v1 done ; encoding
: [0x8f,0x08,0x00,0xf8,0x04,0x03,0x02,0x01]
66 // VI
: exp mrtz v4
, v3
, v2
, v1 done ; encoding
: [0x8f,0x08,0x00,0xc4,0x04,0x03,0x02,0x01]
68 exp null v4
, v3
, v2
, v1
69 // SI
: exp null v4
, v3
, v2
, v1 ; encoding
: [0x9f,0x00,0x00,0xf8,0x04,0x03,0x02,0x01]
70 // VI
: exp null v4
, v3
, v2
, v1 ; encoding
: [0x9f,0x00,0x00,0xc4,0x04,0x03,0x02,0x01]
72 exp null v4
, v3
, v2
, v1 done
73 // SI
: exp null v4
, v3
, v2
, v1 done ; encoding
: [0x9f,0x08,0x00,0xf8,0x04,0x03,0x02,0x01]
74 // VI
: exp null v4
, v3
, v2
, v1 done ; encoding
: [0x9f,0x08,0x00,0xc4,0x04,0x03,0x02,0x01]
76 exp pos0 v4
, v3
, v2
, v1
77 // SI
: exp pos0 v4
, v3
, v2
, v1 ; encoding
: [0xcf,0x00,0x00,0xf8,0x04,0x03,0x02,0x01]
78 // VI
: exp pos0 v4
, v3
, v2
, v1 ; encoding
: [0xcf,0x00,0x00,0xc4,0x04,0x03,0x02,0x01]
80 exp pos0 v4
, v3
, v2
, v1 done
81 // SI
: exp pos0 v4
, v3
, v2
, v1 done ; encoding
: [0xcf,0x08,0x00,0xf8,0x04,0x03,0x02,0x01]
82 // VI
: exp pos0 v4
, v3
, v2
, v1 done ; encoding
: [0xcf,0x08,0x00,0xc4,0x04,0x03,0x02,0x01]
84 exp pos3 v4
, v3
, v2
, v1
85 // SI
: exp pos3 v4
, v3
, v2
, v1 ; encoding
: [0xff,0x00,0x00,0xf8,0x04,0x03,0x02,0x01]
86 // VI
: exp pos3 v4
, v3
, v2
, v1 ; encoding
: [0xff,0x00,0x00,0xc4,0x04,0x03,0x02,0x01]
88 exp pos3 v4
, v3
, v2
, v1 done
89 // SI
: exp pos3 v4
, v3
, v2
, v1 done ; encoding
: [0xff,0x08,0x00,0xf8,0x04,0x03,0x02,0x01]
90 // VI
: exp pos3 v4
, v3
, v2
, v1 done ; encoding
: [0xff,0x08,0x00,0xc4,0x04,0x03,0x02,0x01]
92 exp param0 v4
, v3
, v2
, v1
93 // SI
: exp param0 v4
, v3
, v2
, v1 ; encoding
: [0x0f,0x02,0x00,0xf8,0x04,0x03,0x02,0x01]
94 // VI
: exp param0 v4
, v3
, v2
, v1 ; encoding
: [0x0f,0x02,0x00,0xc4,0x04,0x03,0x02,0x01]
96 exp param0 v4
, v3
, v2
, v1 done
97 // SI
: exp param0 v4
, v3
, v2
, v1 done ; encoding
: [0x0f,0x0a,0x00,0xf8,0x04,0x03,0x02,0x01]
98 // VI
: exp param0 v4
, v3
, v2
, v1 done ; encoding
: [0x0f,0x0a,0x00,0xc4,0x04,0x03,0x02,0x01]
100 exp param31 v4
, v3
, v2
, v1
101 // SI
: exp param31 v4
, v3
, v2
, v1 ; encoding
: [0xff,0x03,0x00,0xf8,0x04,0x03,0x02,0x01]
102 // VI
: exp param31 v4
, v3
, v2
, v1 ; encoding
: [0xff,0x03,0x00,0xc4,0x04,0x03,0x02,0x01]
104 exp param31 v4
, v3
, v2
, v1 done
105 // SI
: exp param31 v4
, v3
, v2
, v1 done ; encoding
: [0xff,0x0b,0x00,0xf8,0x04,0x03,0x02,0x01]
106 // VI
: exp param31 v4
, v3
, v2
, v1 done ; encoding
: [0xff,0x0b,0x00,0xc4,0x04,0x03,0x02,0x01]
108 exp mrt0 v4
, v3
, v2
, v1 vm
109 // SI
: exp mrt0 v4
, v3
, v2
, v1 vm ; encoding
: [0x0f,0x10,0x00,0xf8,0x04,0x03,0x02,0x01]
110 // VI
: exp mrt0 v4
, v3
, v2
, v1 vm ; encoding
: [0x0f,0x10,0x00,0xc4,0x04,0x03,0x02,0x01]
112 exp mrt0 v4
, v3
, v2
, v1 done vm
113 // SI
: exp mrt0 v4
, v3
, v2
, v1 done vm ; encoding
: [0x0f,0x18,0x00,0xf8,0x04,0x03,0x02,0x01]
114 // VI
: exp mrt0 v4
, v3
, v2
, v1 done vm ; encoding
: [0x0f,0x18,0x00,0xc4,0x04,0x03,0x02,0x01]
116 exp mrtz
, v3
, v3
, v7
, v7 compr
117 // SI
: exp mrtz v3
, v3
, v7
, v7 compr ; encoding
: [0x8f,0x04,0x00,0xf8,0x03,0x07,0x00,0x00]
118 // VI
: exp mrtz v3
, v3
, v7
, v7 compr ; encoding
: [0x8f,0x04,0x00,0xc4,0x03,0x07,0x00,0x00]
120 exp mrtz
, off
, off
, v7
, v7 compr
121 // SI
: exp mrtz off
, off
, v7
, v7 compr ; encoding
: [0x8c,0x04,0x00,0xf8,0x00,0x07,0x00,0x00]
122 // VI
: exp mrtz off
, off
, v7
, v7 compr ; encoding
: [0x8c,0x04,0x00,0xc4,0x00,0x07,0x00,0x00]
124 exp mrtz
, v3
, v3
, off
, off compr
125 // SI
: exp mrtz v3
, v3
, off
, off compr ; encoding
: [0x83,0x04,0x00,0xf8,0x03,0x00,0x00,0x00]
126 // VI
: exp mrtz v3
, v3
, off
, off compr ; encoding
: [0x83,0x04,0x00,0xc4,0x03,0x00,0x00,0x00]