[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / test / CodeGen / X86 / evex-to-vex-compress.mir
blob583ff9d4bb1972994c471c434f4b29e5ac4ed879
1 # RUN: llc -mtriple=x86_64-- -run-pass x86-evex-to-vex-compress -verify-machineinstrs -mcpu=skx -o - %s | FileCheck %s
2 # This test verifies VEX encoding for AVX-512 instructions that use registers of low indexes and
3 # do not use zmm or mask registers and have a corresponding AVX/AVX2 opcode
5 --- |
6    define void @evex_z256_to_vex_test() { ret void }
7    define void @evex_z128_to_vex_test() { ret void }   
8    define void @evex_scalar_to_vex_test() { ret void }   
9    define void @evex_z256_to_evex_test() { ret void }
10    define void @evex_z128_to_evex_test() { ret void }
11    define void @evex_scalar_to_evex_test() { ret void }
12 ...
13 ---
14   # CHECK-LABEL: name: evex_z256_to_vex_test
15   # CHECK: bb.0:
17 name: evex_z256_to_vex_test                    
18 body: |                                        
19   bb.0:                                        
20   ; CHECK: VMOVAPDYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
21   VMOVAPDZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm0                        
22   ; CHECK: $ymm0 = VMOVAPDYrm                  $rip, 1, $rax, 0, $noreg
23   $ymm0 = VMOVAPDZ256rm                        $rip, 1, $rax, 0, $noreg                            
24   ; CHECK: $ymm0 = VMOVAPDYrr                  $ymm0
25   $ymm0 = VMOVAPDZ256rr                        $ymm0                                          
26   ; CHECK: $ymm0 = VMOVAPDYrr_REV              $ymm0
27   $ymm0 = VMOVAPDZ256rr_REV                    $ymm0                                          
28   ; CHECK: VMOVAPSYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
29   VMOVAPSZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm0                        
30   ; CHECK: $ymm0 = VMOVAPSYrm                  $rip, 1, $rax, 0, $noreg
31   $ymm0 = VMOVAPSZ256rm                        $rip, 1, $rax, 0, $noreg
32   ; CHECK: $ymm0 = VMOVAPSYrr                  $ymm0
33   $ymm0 = VMOVAPSZ256rr                        $ymm0                                          
34   ; CHECK: $ymm0 = VMOVAPSYrr_REV              $ymm0
35   $ymm0 = VMOVAPSZ256rr_REV                    $ymm0                                          
36   ; CHECK: $ymm0 = VMOVDDUPYrm                 $rip, 1, $rax, 0, $noreg
37   $ymm0 = VMOVDDUPZ256rm                       $rip, 1, $rax, 0, $noreg
38   ; CHECK: $ymm0 = VMOVDDUPYrr                 $ymm0
39   $ymm0 = VMOVDDUPZ256rr                       $ymm0                                          
40   ; CHECK: VMOVDQAYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
41   VMOVDQA32Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm0                        
42   ; CHECK: $ymm0 = VMOVDQAYrm                  $rip, 1, $rax, 0, $noreg
43   $ymm0 = VMOVDQA32Z256rm                      $rip, 1, $rax, 0, $noreg
44   ; CHECK: $ymm0 = VMOVDQAYrr                  $ymm0
45   $ymm0 = VMOVDQA32Z256rr                      $ymm0                                          
46   ; CHECK: $ymm0 = VMOVDQAYrr_REV              $ymm0
47   $ymm0 = VMOVDQA32Z256rr_REV                  $ymm0                                          
48   ; CHECK: VMOVDQAYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
49   VMOVDQA64Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm0                        
50   ; CHECK: $ymm0 = VMOVDQAYrm                  $rip, 1, $rax, 0, $noreg
51   $ymm0 = VMOVDQA64Z256rm                      $rip, 1, $rax, 0, $noreg
52   ; CHECK: $ymm0 = VMOVDQAYrr                  $ymm0
53   $ymm0 = VMOVDQA64Z256rr                      $ymm0                                          
54   ; CHECK: $ymm0 = VMOVDQAYrr_REV              $ymm0
55   $ymm0 = VMOVDQA64Z256rr_REV                  $ymm0                                          
56   ; CHECK: VMOVDQUYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
57   VMOVDQU16Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm0                        
58   ; CHECK: $ymm0 = VMOVDQUYrm                  $rip, 1, $rax, 0, $noreg
59   $ymm0 = VMOVDQU16Z256rm                      $rip, 1, $rax, 0, $noreg
60   ; CHECK: $ymm0 = VMOVDQUYrr                  $ymm0
61   $ymm0 = VMOVDQU16Z256rr                      $ymm0                                          
62   ; CHECK: $ymm0 = VMOVDQUYrr_REV              $ymm0
63   $ymm0 = VMOVDQU16Z256rr_REV                  $ymm0                                          
64   ; CHECK: VMOVDQUYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
65   VMOVDQU32Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm0                        
66   ; CHECK: $ymm0 = VMOVDQUYrm                  $rip, 1, $rax, 0, $noreg
67   $ymm0 = VMOVDQU32Z256rm                      $rip, 1, $rax, 0, $noreg
68   ; CHECK: $ymm0 = VMOVDQUYrr                  $ymm0
69   $ymm0 = VMOVDQU32Z256rr                      $ymm0                                          
70   ; CHECK: $ymm0 = VMOVDQUYrr_REV              $ymm0
71   $ymm0 = VMOVDQU32Z256rr_REV                  $ymm0                                          
72   ; CHECK: VMOVDQUYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
73   VMOVDQU64Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm0                        
74   ; CHECK: $ymm0 = VMOVDQUYrm                  $rip, 1, $rax, 0, $noreg
75   $ymm0 = VMOVDQU64Z256rm                      $rip, 1, $rax, 0, $noreg                            
76   ; CHECK: $ymm0 = VMOVDQUYrr                  $ymm0
77   $ymm0 = VMOVDQU64Z256rr                      $ymm0                                          
78   ; CHECK: $ymm0 = VMOVDQUYrr_REV              $ymm0
79   $ymm0 = VMOVDQU64Z256rr_REV                  $ymm0                                          
80   ; CHECK: VMOVDQUYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
81   VMOVDQU8Z256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm0                        
82   ; CHECK: $ymm0 = VMOVDQUYrm                  $rip, 1, $rax, 0, $noreg
83   $ymm0 = VMOVDQU8Z256rm                       $rip, 1, $rax, 0, $noreg                            
84   ; CHECK: $ymm0 = VMOVDQUYrr                  $ymm0
85   $ymm0 = VMOVDQU8Z256rr                       $ymm0                                          
86   ; CHECK: $ymm0 = VMOVDQUYrr_REV              $ymm0
87   $ymm0 = VMOVDQU8Z256rr_REV                   $ymm0                                          
88   ; CHECK: $ymm0 = VMOVNTDQAYrm                $rip, 1, $rax, 0, $noreg
89   $ymm0 = VMOVNTDQAZ256rm                      $rip, 1, $rax, 0, $noreg
90   ; CHECK: VMOVNTDQYmr                         $rdi, 1, $noreg, 0, $noreg, $ymm0
91   VMOVNTDQZ256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm0                        
92   ; CHECK: VMOVNTPDYmr                         $rdi, 1, $noreg, 0, $noreg, $ymm0
93   VMOVNTPDZ256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm0                        
94   ; CHECK: VMOVNTPSYmr                         $rdi, 1, $noreg, 0, $noreg, $ymm0
95   VMOVNTPSZ256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm0                        
96   ; CHECK: $ymm0 = VMOVSHDUPYrm                $rip, 1, $rax, 0, $noreg
97   $ymm0 = VMOVSHDUPZ256rm                      $rip, 1, $rax, 0, $noreg
98   ; CHECK: $ymm0 = VMOVSHDUPYrr                $ymm0
99   $ymm0 = VMOVSHDUPZ256rr                      $ymm0                                          
100   ; CHECK: $ymm0 = VMOVSLDUPYrm                $rip, 1, $rax, 0, $noreg
101   $ymm0 = VMOVSLDUPZ256rm                      $rip, 1, $rax, 0, $noreg
102   ; CHECK: $ymm0 = VMOVSLDUPYrr                $ymm0
103   $ymm0 = VMOVSLDUPZ256rr                      $ymm0                                          
104   ; CHECK: VMOVUPDYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
105   VMOVUPDZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm0                        
106   ; CHECK: $ymm0 = VMOVUPDYrm                  $rip, 1, $rax, 0, $noreg
107   $ymm0 = VMOVUPDZ256rm                        $rip, 1, $rax, 0, $noreg
108   ; CHECK: $ymm0 = VMOVUPDYrr                  $ymm0
109   $ymm0 = VMOVUPDZ256rr                        $ymm0                                          
110   ; CHECK: $ymm0 = VMOVUPDYrr_REV              $ymm0
111   $ymm0 = VMOVUPDZ256rr_REV                    $ymm0                                          
112   ; CHECK: VMOVUPSYmr                          $rdi, 1, $noreg, 0, $noreg, $ymm0
113   VMOVUPSZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm0                                              
114   ; CHECK: $ymm0 = VPANDYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
115   $ymm0 = VPANDDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
116   ; CHECK: $ymm0 = VPANDYrr                    $ymm0, $ymm1  
117   $ymm0 = VPANDDZ256rr                         $ymm0, $ymm1                                   
118   ; CHECK: $ymm0 = VPANDYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
119   $ymm0 = VPANDQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
120   ; CHECK: $ymm0 = VPANDYrr                    $ymm0, $ymm1
121   $ymm0 = VPANDQZ256rr                         $ymm0, $ymm1                                   
122   ; CHECK: $ymm0 = VPANDNYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
123   $ymm0 = VPANDNDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
124   ; CHECK: $ymm0 = VPANDNYrr                    $ymm0, $ymm1  
125   $ymm0 = VPANDNDZ256rr                         $ymm0, $ymm1                                   
126   ; CHECK: $ymm0 = VPANDNYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
127   $ymm0 = VPANDNQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
128   ; CHECK: $ymm0 = VPANDNYrr                    $ymm0, $ymm1
129   $ymm0 = VPANDNQZ256rr                         $ymm0, $ymm1                                   
130   ; CHECK: $ymm0 = VPAVGBYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
131   $ymm0 = VPAVGBZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
132   ; CHECK: $ymm0 = VPAVGBYrr                   $ymm0, $ymm1
133   $ymm0 = VPAVGBZ256rr                         $ymm0, $ymm1                                   
134   ; CHECK: $ymm0 = VPAVGWYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
135   $ymm0 = VPAVGWZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
136   ; CHECK: $ymm0 = VPAVGWYrr                   $ymm0, $ymm1
137   $ymm0 = VPAVGWZ256rr                         $ymm0, $ymm1                                   
138   ; CHECK: $ymm0 = VPADDBYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
139   $ymm0 = VPADDBZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
140   ; CHECK: $ymm0 = VPADDBYrr                   $ymm0, $ymm1  
141   $ymm0 = VPADDBZ256rr                         $ymm0, $ymm1                                   
142   ; CHECK: $ymm0 = VPADDDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
143   $ymm0 = VPADDDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
144   ; CHECK: $ymm0 = VPADDDYrr                   $ymm0, $ymm1
145   $ymm0 = VPADDDZ256rr                         $ymm0, $ymm1                                   
146   ; CHECK: $ymm0 = VPADDQYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
147   $ymm0 = VPADDQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
148   ; CHECK: $ymm0 = VPADDQYrr                   $ymm0, $ymm1
149   $ymm0 = VPADDQZ256rr                         $ymm0, $ymm1                                   
150   ; CHECK: $ymm0 = VPADDSBYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
151   $ymm0 = VPADDSBZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
152   ; CHECK: $ymm0 = VPADDSBYrr                  $ymm0, $ymm1
153   $ymm0 = VPADDSBZ256rr                        $ymm0, $ymm1                                   
154   ; CHECK: $ymm0 = VPADDSWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
155   $ymm0 = VPADDSWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
156   ; CHECK: $ymm0 = VPADDSWYrr                  $ymm0, $ymm1
157   $ymm0 = VPADDSWZ256rr                        $ymm0, $ymm1                                   
158   ; CHECK: $ymm0 = VPADDUSBYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
159   $ymm0 = VPADDUSBZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
160   ; CHECK: $ymm0 = VPADDUSBYrr                 $ymm0, $ymm1
161   $ymm0 = VPADDUSBZ256rr                       $ymm0, $ymm1                                   
162   ; CHECK: $ymm0 = VPADDUSWYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
163   $ymm0 = VPADDUSWZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
164   ; CHECK: $ymm0 = VPADDUSWYrr                 $ymm0, $ymm1
165   $ymm0 = VPADDUSWZ256rr                       $ymm0, $ymm1                                   
166   ; CHECK: $ymm0 = VPADDWYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
167   $ymm0 = VPADDWZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
168   ; CHECK: $ymm0 = VPADDWYrr                   $ymm0, $ymm1
169   $ymm0 = VPADDWZ256rr                         $ymm0, $ymm1                                   
170   ; CHECK: $ymm0 = VMULPDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
171   $ymm0 = VMULPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
172   ; CHECK: $ymm0 = VMULPDYrr                   $ymm0, $ymm1
173   $ymm0 = VMULPDZ256rr                         $ymm0, $ymm1                                   
174   ; CHECK: $ymm0 = VMULPSYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
175   $ymm0 = VMULPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
176   ; CHECK: $ymm0 = VMULPSYrr                   $ymm0, $ymm1
177   $ymm0 = VMULPSZ256rr                         $ymm0, $ymm1                                   
178   ; CHECK: $ymm0 = VORPDYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
179   $ymm0 = VORPDZ256rm                          $ymm0, $rip, 1, $rax, 0, $noreg
180   ; CHECK: $ymm0 = VORPDYrr                    $ymm0, $ymm1
181   $ymm0 = VORPDZ256rr                          $ymm0, $ymm1                                   
182   ; CHECK: $ymm0 = VORPSYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
183   $ymm0 = VORPSZ256rm                          $ymm0, $rip, 1, $rax, 0, $noreg
184   ; CHECK: $ymm0 = VORPSYrr                    $ymm0, $ymm1
185   $ymm0 = VORPSZ256rr                          $ymm0, $ymm1                                   
186   ; CHECK: $ymm0 = VPMADDUBSWYrm               $ymm0, $rip, 1, $rax, 0, $noreg
187   $ymm0 = VPMADDUBSWZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
188   ; CHECK: $ymm0 = VPMADDUBSWYrr               $ymm0, $ymm1
189   $ymm0 = VPMADDUBSWZ256rr                     $ymm0, $ymm1                                   
190   ; CHECK: $ymm0 = VPMADDWDYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
191   $ymm0 = VPMADDWDZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
192   ; CHECK: $ymm0 = VPMADDWDYrr                 $ymm0, $ymm1
193   $ymm0 = VPMADDWDZ256rr                       $ymm0, $ymm1                                   
194   ; CHECK: $ymm0 = VPMAXSBYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
195   $ymm0 = VPMAXSBZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
196   ; CHECK: $ymm0 = VPMAXSBYrr                  $ymm0, $ymm1
197   $ymm0 = VPMAXSBZ256rr                        $ymm0, $ymm1                                   
198   ; CHECK: $ymm0 = VPMAXSDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
199   $ymm0 = VPMAXSDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
200   ; CHECK: $ymm0 = VPMAXSDYrr                  $ymm0, $ymm1
201   $ymm0 = VPMAXSDZ256rr                        $ymm0, $ymm1                                   
202   ; CHECK: $ymm0 = VPMAXSWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
203   $ymm0 = VPMAXSWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
204   ; CHECK: $ymm0 = VPMAXSWYrr                  $ymm0, $ymm1
205   $ymm0 = VPMAXSWZ256rr                        $ymm0, $ymm1                                   
206   ; CHECK: $ymm0 = VPMAXUBYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
207   $ymm0 = VPMAXUBZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
208   ; CHECK: $ymm0 = VPMAXUBYrr                  $ymm0, $ymm1
209   $ymm0 = VPMAXUBZ256rr                        $ymm0, $ymm1                                   
210   ; CHECK: $ymm0 = VPMAXUDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
211   $ymm0 = VPMAXUDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
212   ; CHECK: $ymm0 = VPMAXUDYrr                  $ymm0, $ymm1
213   $ymm0 = VPMAXUDZ256rr                        $ymm0, $ymm1                                   
214   ; CHECK: $ymm0 = VPMAXUWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
215   $ymm0 = VPMAXUWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
216   ; CHECK: $ymm0 = VPMAXUWYrr                  $ymm0, $ymm1
217   $ymm0 = VPMAXUWZ256rr                        $ymm0, $ymm1                                   
218   ; CHECK: $ymm0 = VPMINSBYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
219   $ymm0 = VPMINSBZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
220   ; CHECK: $ymm0 = VPMINSBYrr                  $ymm0, $ymm1
221   $ymm0 = VPMINSBZ256rr                        $ymm0, $ymm1                                   
222   ; CHECK: $ymm0 = VPMINSDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
223   $ymm0 = VPMINSDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
224   ; CHECK: $ymm0 = VPMINSDYrr                  $ymm0, $ymm1
225   $ymm0 = VPMINSDZ256rr                        $ymm0, $ymm1                                   
226   ; CHECK: $ymm0 = VPMINSWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
227   $ymm0 = VPMINSWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
228   ; CHECK: $ymm0 = VPMINSWYrr                  $ymm0, $ymm1
229   $ymm0 = VPMINSWZ256rr                        $ymm0, $ymm1                                   
230   ; CHECK: $ymm0 = VPMINUBYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
231   $ymm0 = VPMINUBZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
232   ; CHECK: $ymm0 = VPMINUBYrr                  $ymm0, $ymm1
233   $ymm0 = VPMINUBZ256rr                        $ymm0, $ymm1                                   
234   ; CHECK: $ymm0 = VPMINUDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
235   $ymm0 = VPMINUDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
236   ; CHECK: $ymm0 = VPMINUDYrr                  $ymm0, $ymm1
237   $ymm0 = VPMINUDZ256rr                        $ymm0, $ymm1                                   
238   ; CHECK: $ymm0 = VPMINUWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
239   $ymm0 = VPMINUWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
240   ; CHECK: $ymm0 = VPMINUWYrr                  $ymm0, $ymm1
241   $ymm0 = VPMINUWZ256rr                        $ymm0, $ymm1                                   
242   ; CHECK: $ymm0 = VPMULDQYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
243   $ymm0 = VPMULDQZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
244   ; CHECK: $ymm0 = VPMULDQYrr                  $ymm0, $ymm1  
245   $ymm0 = VPMULDQZ256rr                        $ymm0, $ymm1                                   
246   ; CHECK: $ymm0 = VPMULHRSWYrm                $ymm0, $rip, 1, $rax, 0, $noreg
247   $ymm0 = VPMULHRSWZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
248   ; CHECK: $ymm0 = VPMULHRSWYrr                $ymm0, $ymm1
249   $ymm0 = VPMULHRSWZ256rr                      $ymm0, $ymm1                                   
250   ; CHECK: $ymm0 = VPMULHUWYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
251   $ymm0 = VPMULHUWZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
252   ; CHECK: $ymm0 = VPMULHUWYrr                 $ymm0, $ymm1
253   $ymm0 = VPMULHUWZ256rr                       $ymm0, $ymm1                                   
254   ; CHECK: $ymm0 = VPMULHWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
255   $ymm0 = VPMULHWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
256   ; CHECK: $ymm0 = VPMULHWYrr                  $ymm0, $ymm1
257   $ymm0 = VPMULHWZ256rr                        $ymm0, $ymm1                                   
258   ; CHECK: $ymm0 = VPMULLDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
259   $ymm0 = VPMULLDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
260   ; CHECK: $ymm0 = VPMULLDYrr                  $ymm0, $ymm1
261   $ymm0 = VPMULLDZ256rr                        $ymm0, $ymm1                                   
262   ; CHECK: $ymm0 = VPMULLWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
263   $ymm0 = VPMULLWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
264   ; CHECK: $ymm0 = VPMULLWYrr                  $ymm0, $ymm1  
265   $ymm0 = VPMULLWZ256rr                        $ymm0, $ymm1                                   
266   ; CHECK: $ymm0 = VPMULUDQYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
267   $ymm0 = VPMULUDQZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
268   ; CHECK: $ymm0 = VPMULUDQYrr                 $ymm0, $ymm1
269   $ymm0 = VPMULUDQZ256rr                       $ymm0, $ymm1                                   
270   ; CHECK: $ymm0 = VPORYrm                     $ymm0, $rip, 1, $rax, 0, $noreg
271   $ymm0 = VPORDZ256rm                          $ymm0, $rip, 1, $rax, 0, $noreg
272   ; CHECK: $ymm0 = VPORYrr                     $ymm0, $ymm1
273   $ymm0 = VPORDZ256rr                          $ymm0, $ymm1                                   
274   ; CHECK: $ymm0 = VPORYrm                     $ymm0, $rip, 1, $rax, 0, $noreg
275   $ymm0 = VPORQZ256rm                          $ymm0, $rip, 1, $rax, 0, $noreg
276   ; CHECK: $ymm0 = VPORYrr                     $ymm0, $ymm1
277   $ymm0 = VPORQZ256rr                          $ymm0, $ymm1                                   
278   ; CHECK: $ymm0 = VPSUBBYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
279   $ymm0 = VPSUBBZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
280   ; CHECK: $ymm0 = VPSUBBYrr                   $ymm0, $ymm1
281   $ymm0 = VPSUBBZ256rr                         $ymm0, $ymm1                                   
282   ; CHECK: $ymm0 = VPSUBDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
283   $ymm0 = VPSUBDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
284   ; CHECK: $ymm0 = VPSUBDYrr                   $ymm0, $ymm1
285   $ymm0 = VPSUBDZ256rr                         $ymm0, $ymm1                                   
286   ; CHECK: $ymm0 = VPSUBQYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
287   $ymm0 = VPSUBQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
288   ; CHECK: $ymm0 = VPSUBQYrr                   $ymm0, $ymm1
289   $ymm0 = VPSUBQZ256rr                         $ymm0, $ymm1                                   
290   ; CHECK: $ymm0 = VPSUBSBYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
291   $ymm0 = VPSUBSBZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
292   ; CHECK: $ymm0 = VPSUBSBYrr                  $ymm0, $ymm1
293   $ymm0 = VPSUBSBZ256rr                        $ymm0, $ymm1                                   
294   ; CHECK: $ymm0 = VPSUBSWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
295   $ymm0 = VPSUBSWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
296   ; CHECK: $ymm0 = VPSUBSWYrr                  $ymm0, $ymm1
297   $ymm0 = VPSUBSWZ256rr                        $ymm0, $ymm1                                   
298   ; CHECK: $ymm0 = VPSUBUSBYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
299   $ymm0 = VPSUBUSBZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
300   ; CHECK: $ymm0 = VPSUBUSBYrr                 $ymm0, $ymm1
301   $ymm0 = VPSUBUSBZ256rr                       $ymm0, $ymm1                                   
302   ; CHECK: $ymm0 = VPSUBUSWYrm                 $ymm0, $rip, 1, $rax, 0, $noreg
303   $ymm0 = VPSUBUSWZ256rm                       $ymm0, $rip, 1, $rax, 0, $noreg
304   ; CHECK: $ymm0 = VPSUBUSWYrr                 $ymm0, $ymm1
305   $ymm0 = VPSUBUSWZ256rr                       $ymm0, $ymm1                                   
306   ; CHECK: $ymm0 = VPSUBWYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
307   $ymm0 = VPSUBWZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
308   ; CHECK: $ymm0 = VPSUBWYrr                   $ymm0, $ymm1
309   $ymm0 = VPSUBWZ256rr                         $ymm0, $ymm1                                   
310   ; CHECK: $ymm0 = VPXORYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
311   $ymm0 = VPXORDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
312   ; CHECK: $ymm0 = VPXORYrr                    $ymm0, $ymm1
313   $ymm0 = VPXORDZ256rr                         $ymm0, $ymm1                                   
314   ; CHECK: $ymm0 = VPXORYrm                    $ymm0, $rip, 1, $rax, 0, $noreg
315   $ymm0 = VPXORQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
316   ; CHECK: $ymm0 = VPXORYrr                    $ymm0, $ymm1  
317   $ymm0 = VPXORQZ256rr                         $ymm0, $ymm1                                   
318   ; CHECK: $ymm0 = VADDPDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
319   $ymm0 = VADDPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
320   ; CHECK: $ymm0 = VADDPDYrr                   $ymm0, $ymm1
321   $ymm0 = VADDPDZ256rr                         $ymm0, $ymm1                                   
322   ; CHECK: $ymm0 = VADDPSYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
323   $ymm0 = VADDPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
324   ; CHECK: $ymm0 = VADDPSYrr                   $ymm0, $ymm1
325   $ymm0 = VADDPSZ256rr                         $ymm0, $ymm1                                   
326   ; CHECK: $ymm0 = VANDNPDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
327   $ymm0 = VANDNPDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
328   ; CHECK: $ymm0 = VANDNPDYrr                  $ymm0, $ymm1
329   $ymm0 = VANDNPDZ256rr                        $ymm0, $ymm1                                   
330   ; CHECK: $ymm0 = VANDNPSYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
331   $ymm0 = VANDNPSZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
332   ; CHECK: $ymm0 = VANDNPSYrr                  $ymm0, $ymm1
333   $ymm0 = VANDNPSZ256rr                        $ymm0, $ymm1                                   
334   ; CHECK: $ymm0 = VANDPDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
335   $ymm0 = VANDPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
336   ; CHECK: $ymm0 = VANDPDYrr                   $ymm0, $ymm1
337   $ymm0 = VANDPDZ256rr                         $ymm0, $ymm1                                   
338   ; CHECK: $ymm0 = VANDPSYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
339   $ymm0 = VANDPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
340   ; CHECK: $ymm0 = VANDPSYrr                   $ymm0, $ymm1
341   $ymm0 = VANDPSZ256rr                         $ymm0, $ymm1                                   
342   ; CHECK: $ymm0 = VDIVPDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
343   $ymm0 = VDIVPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
344   ; CHECK: $ymm0 = VDIVPDYrr                   $ymm0, $ymm1  
345   $ymm0 = VDIVPDZ256rr                         $ymm0, $ymm1                                   
346   ; CHECK: $ymm0 = VDIVPSYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
347   $ymm0 = VDIVPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
348   ; CHECK: $ymm0 = VDIVPSYrr                   $ymm0, $ymm1
349   $ymm0 = VDIVPSZ256rr                         $ymm0, $ymm1                                   
350   ; CHECK: $ymm0 = VMAXCPDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
351   $ymm0 = VMAXCPDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
352   ; CHECK: $ymm0 = VMAXCPDYrr                  $ymm0, $ymm1
353   $ymm0 = VMAXCPDZ256rr                        $ymm0, $ymm1                                   
354   ; CHECK: $ymm0 = VMAXCPSYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
355   $ymm0 = VMAXCPSZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
356   ; CHECK: $ymm0 = VMAXCPSYrr                  $ymm0, $ymm1
357   $ymm0 = VMAXCPSZ256rr                        $ymm0, $ymm1                                   
358   ; CHECK: $ymm0 = VMAXCPDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
359   $ymm0 = VMAXPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
360   ; CHECK: $ymm0 = VMAXCPDYrr                  $ymm0, $ymm1
361   $ymm0 = VMAXPDZ256rr                         $ymm0, $ymm1                                   
362   ; CHECK: $ymm0 = VMAXCPSYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
363   $ymm0 = VMAXPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
364   ; CHECK: $ymm0 = VMAXCPSYrr                  $ymm0, $ymm1
365   $ymm0 = VMAXPSZ256rr                         $ymm0, $ymm1                                   
366   ; CHECK: $ymm0 = VMINCPDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
367   $ymm0 = VMINCPDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
368   ; CHECK: $ymm0 = VMINCPDYrr                  $ymm0, $ymm1
369   $ymm0 = VMINCPDZ256rr                        $ymm0, $ymm1                                   
370   ; CHECK: $ymm0 = VMINCPSYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
371   $ymm0 = VMINCPSZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
372   ; CHECK: $ymm0 = VMINCPSYrr                  $ymm0, $ymm1
373   $ymm0 = VMINCPSZ256rr                        $ymm0, $ymm1                                   
374   ; CHECK: $ymm0 = VMINCPDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
375   $ymm0 = VMINPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
376   ; CHECK: $ymm0 = VMINCPDYrr                  $ymm0, $ymm1
377   $ymm0 = VMINPDZ256rr                         $ymm0, $ymm1                                   
378   ; CHECK: $ymm0 = VMINCPSYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
379   $ymm0 = VMINPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
380   ; CHECK: $ymm0 = VMINCPSYrr                  $ymm0, $ymm1
381   $ymm0 = VMINPSZ256rr                         $ymm0, $ymm1                                   
382   ; CHECK: $ymm0 = VXORPDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
383   $ymm0 = VXORPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
384   ; CHECK: $ymm0 = VXORPDYrr                   $ymm0, $ymm1
385   $ymm0 = VXORPDZ256rr                         $ymm0, $ymm1                                   
386   ; CHECK: $ymm0 = VXORPSYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
387   $ymm0 = VXORPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
388   ; CHECK: $ymm0 = VXORPSYrr                   $ymm0, $ymm1
389   $ymm0 = VXORPSZ256rr                         $ymm0, $ymm1                                   
390   ; CHECK: $ymm0 = VPACKSSDWYrm                $ymm0, $rip, 1, $rax, 0, $noreg
391   $ymm0 = VPACKSSDWZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
392   ; CHECK: $ymm0 = VPACKSSDWYrr                $ymm0, $ymm1
393   $ymm0 = VPACKSSDWZ256rr                      $ymm0, $ymm1                                   
394   ; CHECK: $ymm0 = VPACKSSWBYrm                $ymm0, $rip, 1, $rax, 0, $noreg
395   $ymm0 = VPACKSSWBZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
396   ; CHECK: $ymm0 = VPACKSSWBYrr                $ymm0, $ymm1
397   $ymm0 = VPACKSSWBZ256rr                      $ymm0, $ymm1                                   
398   ; CHECK: $ymm0 = VPACKUSDWYrm                $ymm0, $rip, 1, $rax, 0, $noreg
399   $ymm0 = VPACKUSDWZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
400   ; CHECK: $ymm0 = VPACKUSDWYrr                $ymm0, $ymm1
401   $ymm0 = VPACKUSDWZ256rr                      $ymm0, $ymm1                                   
402   ; CHECK: $ymm0 = VPACKUSWBYrm                $ymm0, $rip, 1, $rax, 0, $noreg
403   $ymm0 = VPACKUSWBZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
404   ; CHECK: $ymm0 = VPACKUSWBYrr                $ymm0, $ymm1
405   $ymm0 = VPACKUSWBZ256rr                      $ymm0, $ymm1                                   
406   ; CHECK: $ymm0 = VUNPCKHPDYrm                $ymm0, $rip, 1, $rax, 0, $noreg
407   $ymm0 = VUNPCKHPDZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
408   ; CHECK: $ymm0 = VUNPCKHPDYrr                $ymm0, $ymm1
409   $ymm0 = VUNPCKHPDZ256rr                      $ymm0, $ymm1                                   
410   ; CHECK: $ymm0 = VUNPCKHPSYrm                $ymm0, $rip, 1, $rax, 0, $noreg
411   $ymm0 = VUNPCKHPSZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
412   ; CHECK: $ymm0 = VUNPCKHPSYrr                $ymm0, $ymm1
413   $ymm0 = VUNPCKHPSZ256rr                      $ymm0, $ymm1                                   
414   ; CHECK: $ymm0 = VUNPCKLPDYrm                $ymm0, $rip, 1, $rax, 0, $noreg
415   $ymm0 = VUNPCKLPDZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
416   ; CHECK: $ymm0 = VUNPCKLPDYrr                $ymm0, $ymm1
417   $ymm0 = VUNPCKLPDZ256rr                      $ymm0, $ymm1                                   
418   ; CHECK: $ymm0 = VUNPCKLPSYrm                $ymm0, $rip, 1, $rax, 0, $noreg
419   $ymm0 = VUNPCKLPSZ256rm                      $ymm0, $rip, 1, $rax, 0, $noreg
420   ; CHECK: $ymm0 = VUNPCKLPSYrr                $ymm0, $ymm1
421   $ymm0 = VUNPCKLPSZ256rr                      $ymm0, $ymm1                                   
422   ; CHECK: $ymm0 = VSUBPDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
423   $ymm0 = VSUBPDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
424   ; CHECK: $ymm0 = VSUBPDYrr                   $ymm0, $ymm1 
425   $ymm0 = VSUBPDZ256rr                         $ymm0, $ymm1                                   
426   ; CHECK: $ymm0 = VSUBPSYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
427   $ymm0 = VSUBPSZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
428   ; CHECK: $ymm0 = VSUBPSYrr                   $ymm0, $ymm1                               
429   $ymm0 = VSUBPSZ256rr                         $ymm0, $ymm1                                   
430   ; CHECK: $ymm0 = VPUNPCKHBWYrm               $ymm0, $rip, 1, $rax, 0, $noreg
431   $ymm0 = VPUNPCKHBWZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
432   ; CHECK: $ymm0 = VPUNPCKHBWYrr               $ymm0, $ymm1
433   $ymm0 = VPUNPCKHBWZ256rr                     $ymm0, $ymm1                                   
434   ; CHECK: $ymm0 = VPUNPCKHDQYrm               $ymm0, $rip, 1, $rax, 0, $noreg
435   $ymm0 = VPUNPCKHDQZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
436   ; CHECK: $ymm0 = VPUNPCKHDQYrr               $ymm0, $ymm1
437   $ymm0 = VPUNPCKHDQZ256rr                     $ymm0, $ymm1                                   
438   ; CHECK: $ymm0 = VPUNPCKHQDQYrm              $ymm0, $rip, 1, $rax, 0, $noreg
439   $ymm0 = VPUNPCKHQDQZ256rm                    $ymm0, $rip, 1, $rax, 0, $noreg
440   ; CHECK: $ymm0 = VPUNPCKHQDQYrr              $ymm0, $ymm1
441   $ymm0 = VPUNPCKHQDQZ256rr                    $ymm0, $ymm1                                   
442   ; CHECK: $ymm0 = VPUNPCKHWDYrm               $ymm0, $rip, 1, $rax, 0, $noreg
443   $ymm0 = VPUNPCKHWDZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
444   ; CHECK: $ymm0 = VPUNPCKHWDYrr               $ymm0, $ymm1
445   $ymm0 = VPUNPCKHWDZ256rr                     $ymm0, $ymm1                                   
446   ; CHECK: $ymm0 = VPUNPCKLBWYrm               $ymm0, $rip, 1, $rax, 0, $noreg
447   $ymm0 = VPUNPCKLBWZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
448   ; CHECK: $ymm0 = VPUNPCKLBWYrr               $ymm0, $ymm1
449   $ymm0 = VPUNPCKLBWZ256rr                     $ymm0, $ymm1                                   
450   ; CHECK: $ymm0 = VPUNPCKLDQYrm               $ymm0, $rip, 1, $rax, 0, $noreg
451   $ymm0 = VPUNPCKLDQZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
452   ; CHECK: $ymm0 = VPUNPCKLDQYrr               $ymm0, $ymm1 
453   $ymm0 = VPUNPCKLDQZ256rr                     $ymm0, $ymm1                                   
454   ; CHECK: $ymm0 = VPUNPCKLQDQYrm              $ymm0, $rip, 1, $rax, 0, $noreg
455   $ymm0 = VPUNPCKLQDQZ256rm                    $ymm0, $rip, 1, $rax, 0, $noreg
456   ; CHECK: $ymm0 = VPUNPCKLQDQYrr              $ymm0, $ymm1 
457   $ymm0 = VPUNPCKLQDQZ256rr                    $ymm0, $ymm1                                   
458   ; CHECK: $ymm0 = VPUNPCKLWDYrm               $ymm0, $rip, 1, $rax, 0, $noreg
459   $ymm0 = VPUNPCKLWDZ256rm                     $ymm0, $rip, 1, $rax, 0, $noreg
460   ; CHECK: $ymm0 = VPUNPCKLWDYrr               $ymm0, $ymm1                               
461   $ymm0 = VPUNPCKLWDZ256rr                     $ymm0, $ymm1                                                
462   ; CHECK: $ymm0 = VFMADD132PDYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
463   $ymm0 = VFMADD132PDZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
464   ; CHECK: $ymm0 = VFMADD132PDYr               $ymm0, $ymm1, $ymm2
465   $ymm0 = VFMADD132PDZ256r                     $ymm0, $ymm1, $ymm2                            
466   ; CHECK: $ymm0 = VFMADD132PSYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
467   $ymm0 = VFMADD132PSZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
468   ; CHECK: $ymm0 = VFMADD132PSYr               $ymm0, $ymm1, $ymm2
469   $ymm0 = VFMADD132PSZ256r                     $ymm0, $ymm1, $ymm2                            
470   ; CHECK: $ymm0 = VFMADD213PDYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
471   $ymm0 = VFMADD213PDZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
472   ; CHECK: $ymm0 = VFMADD213PDYr               $ymm0, $ymm1, $ymm2
473   $ymm0 = VFMADD213PDZ256r                     $ymm0, $ymm1, $ymm2                            
474   ; CHECK: $ymm0 = VFMADD213PSYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
475   $ymm0 = VFMADD213PSZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
476   ; CHECK: $ymm0 = VFMADD213PSYr               $ymm0, $ymm1, $ymm2
477   $ymm0 = VFMADD213PSZ256r                     $ymm0, $ymm1, $ymm2                            
478   ; CHECK: $ymm0 = VFMADD231PDYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
479   $ymm0 = VFMADD231PDZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
480   ; CHECK: $ymm0 = VFMADD231PDYr               $ymm0, $ymm1, $ymm2
481   $ymm0 = VFMADD231PDZ256r                     $ymm0, $ymm1, $ymm2                            
482   ; CHECK: $ymm0 = VFMADD231PSYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
483   $ymm0 = VFMADD231PSZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
484   ; CHECK: $ymm0 = VFMADD231PSYr               $ymm0, $ymm1, $ymm2
485   $ymm0 = VFMADD231PSZ256r                     $ymm0, $ymm1, $ymm2                            
486   ; CHECK: $ymm0 = VFMADDSUB132PDYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
487   $ymm0 = VFMADDSUB132PDZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
488   ; CHECK: $ymm0 = VFMADDSUB132PDYr            $ymm0, $ymm1, $ymm2
489   $ymm0 = VFMADDSUB132PDZ256r                  $ymm0, $ymm1, $ymm2                            
490   ; CHECK: $ymm0 = VFMADDSUB132PSYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
491   $ymm0 = VFMADDSUB132PSZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
492   ; CHECK: $ymm0 = VFMADDSUB132PSYr            $ymm0, $ymm1, $ymm2
493   $ymm0 = VFMADDSUB132PSZ256r                  $ymm0, $ymm1, $ymm2                            
494   ; CHECK: $ymm0 = VFMADDSUB213PDYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
495   $ymm0 = VFMADDSUB213PDZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
496   ; CHECK: $ymm0 = VFMADDSUB213PDYr            $ymm0, $ymm1, $ymm2
497   $ymm0 = VFMADDSUB213PDZ256r                  $ymm0, $ymm1, $ymm2                            
498   ; CHECK: $ymm0 = VFMADDSUB213PSYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
499   $ymm0 = VFMADDSUB213PSZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
500   ; CHECK: $ymm0 = VFMADDSUB213PSYr            $ymm0, $ymm1, $ymm2
501   $ymm0 = VFMADDSUB213PSZ256r                  $ymm0, $ymm1, $ymm2                            
502   ; CHECK: $ymm0 = VFMADDSUB231PDYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
503   $ymm0 = VFMADDSUB231PDZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
504   ; CHECK: $ymm0 = VFMADDSUB231PDYr            $ymm0, $ymm1, $ymm2
505   $ymm0 = VFMADDSUB231PDZ256r                  $ymm0, $ymm1, $ymm2                            
506   ; CHECK: $ymm0 = VFMADDSUB231PSYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
507   $ymm0 = VFMADDSUB231PSZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
508   ; CHECK: $ymm0 = VFMADDSUB231PSYr            $ymm0, $ymm1, $ymm2
509   $ymm0 = VFMADDSUB231PSZ256r                  $ymm0, $ymm1, $ymm2                            
510   ; CHECK: $ymm0 = VFMSUB132PDYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
511   $ymm0 = VFMSUB132PDZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
512   ; CHECK: $ymm0 = VFMSUB132PDYr               $ymm0, $ymm1, $ymm2
513   $ymm0 = VFMSUB132PDZ256r                     $ymm0, $ymm1, $ymm2                            
514   ; CHECK: $ymm0 = VFMSUB132PSYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
515   $ymm0 = VFMSUB132PSZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
516   ; CHECK: $ymm0 = VFMSUB132PSYr               $ymm0, $ymm1, $ymm2
517   $ymm0 = VFMSUB132PSZ256r                     $ymm0, $ymm1, $ymm2                            
518   ; CHECK: $ymm0 = VFMSUB213PDYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
519   $ymm0 = VFMSUB213PDZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
520   ; CHECK: $ymm0 = VFMSUB213PDYr               $ymm0, $ymm1, $ymm2
521   $ymm0 = VFMSUB213PDZ256r                     $ymm0, $ymm1, $ymm2                            
522   ; CHECK: $ymm0 = VFMSUB213PSYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
523   $ymm0 = VFMSUB213PSZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
524   ; CHECK: $ymm0 = VFMSUB213PSYr               $ymm0, $ymm1, $ymm2
525   $ymm0 = VFMSUB213PSZ256r                     $ymm0, $ymm1, $ymm2                            
526   ; CHECK: $ymm0 = VFMSUB231PDYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
527   $ymm0 = VFMSUB231PDZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
528   ; CHECK: $ymm0 = VFMSUB231PDYr               $ymm0, $ymm1, $ymm2
529   $ymm0 = VFMSUB231PDZ256r                     $ymm0, $ymm1, $ymm2                            
530   ; CHECK: $ymm0 = VFMSUB231PSYm               $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
531   $ymm0 = VFMSUB231PSZ256m                     $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
532   ; CHECK: $ymm0 = VFMSUB231PSYr               $ymm0, $ymm1, $ymm2
533   $ymm0 = VFMSUB231PSZ256r                     $ymm0, $ymm1, $ymm2                            
534   ; CHECK: $ymm0 = VFMSUBADD132PDYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
535   $ymm0 = VFMSUBADD132PDZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
536   ; CHECK: $ymm0 = VFMSUBADD132PDYr            $ymm0, $ymm1, $ymm2
537   $ymm0 = VFMSUBADD132PDZ256r                  $ymm0, $ymm1, $ymm2                            
538   ; CHECK: $ymm0 = VFMSUBADD132PSYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
539   $ymm0 = VFMSUBADD132PSZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
540   ; CHECK: $ymm0 = VFMSUBADD132PSYr            $ymm0, $ymm1, $ymm2
541   $ymm0 = VFMSUBADD132PSZ256r                  $ymm0, $ymm1, $ymm2                            
542   ; CHECK: $ymm0 = VFMSUBADD213PDYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
543   $ymm0 = VFMSUBADD213PDZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
544   ; CHECK: $ymm0 = VFMSUBADD213PDYr            $ymm0, $ymm1, $ymm2
545   $ymm0 = VFMSUBADD213PDZ256r                  $ymm0, $ymm1, $ymm2                            
546   ; CHECK: $ymm0 = VFMSUBADD213PSYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
547   $ymm0 = VFMSUBADD213PSZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
548   ; CHECK: $ymm0 = VFMSUBADD213PSYr            $ymm0, $ymm1, $ymm2
549   $ymm0 = VFMSUBADD213PSZ256r                  $ymm0, $ymm1, $ymm2                            
550   ; CHECK: $ymm0 = VFMSUBADD231PDYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
551   $ymm0 = VFMSUBADD231PDZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
552   ; CHECK: $ymm0 = VFMSUBADD231PDYr            $ymm0, $ymm1, $ymm2
553   $ymm0 = VFMSUBADD231PDZ256r                  $ymm0, $ymm1, $ymm2                            
554   ; CHECK: $ymm0 = VFMSUBADD231PSYm            $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
555   $ymm0 = VFMSUBADD231PSZ256m                  $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
556   ; CHECK: $ymm0 = VFMSUBADD231PSYr            $ymm0, $ymm1, $ymm2
557   $ymm0 = VFMSUBADD231PSZ256r                  $ymm0, $ymm1, $ymm2                            
558   ; CHECK: $ymm0 = VFNMADD132PDYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
559   $ymm0 = VFNMADD132PDZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
560   ; CHECK: $ymm0 = VFNMADD132PDYr              $ymm0, $ymm1, $ymm2
561   $ymm0 = VFNMADD132PDZ256r                    $ymm0, $ymm1, $ymm2                            
562   ; CHECK: $ymm0 = VFNMADD132PSYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
563   $ymm0 = VFNMADD132PSZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
564   ; CHECK: $ymm0 = VFNMADD132PSYr              $ymm0, $ymm1, $ymm2
565   $ymm0 = VFNMADD132PSZ256r                    $ymm0, $ymm1, $ymm2                            
566   ; CHECK: $ymm0 = VFNMADD213PDYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
567   $ymm0 = VFNMADD213PDZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
568   ; CHECK: $ymm0 = VFNMADD213PDYr              $ymm0, $ymm1, $ymm2
569   $ymm0 = VFNMADD213PDZ256r                    $ymm0, $ymm1, $ymm2                            
570   ; CHECK: $ymm0 = VFNMADD213PSYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
571   $ymm0 = VFNMADD213PSZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
572   ; CHECK: $ymm0 = VFNMADD213PSYr              $ymm0, $ymm1, $ymm2
573   $ymm0 = VFNMADD213PSZ256r                    $ymm0, $ymm1, $ymm2                            
574   ; CHECK: $ymm0 = VFNMADD231PDYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
575   $ymm0 = VFNMADD231PDZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
576   ; CHECK: $ymm0 = VFNMADD231PDYr              $ymm0, $ymm1, $ymm2
577   $ymm0 = VFNMADD231PDZ256r                    $ymm0, $ymm1, $ymm2                            
578   ; CHECK: $ymm0 = VFNMADD231PSYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
579   $ymm0 = VFNMADD231PSZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
580   ; CHECK: $ymm0 = VFNMADD231PSYr              $ymm0, $ymm1, $ymm2
581   $ymm0 = VFNMADD231PSZ256r                    $ymm0, $ymm1, $ymm2                            
582   ; CHECK: $ymm0 = VFNMSUB132PDYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
583   $ymm0 = VFNMSUB132PDZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
584   ; CHECK: $ymm0 = VFNMSUB132PDYr              $ymm0, $ymm1, $ymm2
585   $ymm0 = VFNMSUB132PDZ256r                    $ymm0, $ymm1, $ymm2                            
586   ; CHECK: $ymm0 = VFNMSUB132PSYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
587   $ymm0 = VFNMSUB132PSZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
588   ; CHECK: $ymm0 = VFNMSUB132PSYr              $ymm0, $ymm1, $ymm2
589   $ymm0 = VFNMSUB132PSZ256r                    $ymm0, $ymm1, $ymm2                            
590   ; CHECK: $ymm0 = VFNMSUB213PDYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
591   $ymm0 = VFNMSUB213PDZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
592   ; CHECK: $ymm0 = VFNMSUB213PDYr              $ymm0, $ymm1, $ymm2
593   $ymm0 = VFNMSUB213PDZ256r                    $ymm0, $ymm1, $ymm2                            
594   ; CHECK: $ymm0 = VFNMSUB213PSYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
595   $ymm0 = VFNMSUB213PSZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
596   ; CHECK: $ymm0 = VFNMSUB213PSYr              $ymm0, $ymm1, $ymm2
597   $ymm0 = VFNMSUB213PSZ256r                    $ymm0, $ymm1, $ymm2                            
598   ; CHECK: $ymm0 = VFNMSUB231PDYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
599   $ymm0 = VFNMSUB231PDZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
600   ; CHECK: $ymm0 = VFNMSUB231PDYr              $ymm0, $ymm1, $ymm2
601   $ymm0 = VFNMSUB231PDZ256r                    $ymm0, $ymm1, $ymm2                            
602   ; CHECK: $ymm0 = VFNMSUB231PSYm              $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg
603   $ymm0 = VFNMSUB231PSZ256m                    $ymm0, $ymm0, $rsi, 1, $noreg, 0, $noreg                 
604   ; CHECK: $ymm0 = VFNMSUB231PSYr              $ymm0, $ymm1, $ymm2                        
605   $ymm0 = VFNMSUB231PSZ256r                    $ymm0, $ymm1, $ymm2                                               
606   ; CHECK: $ymm0 = VPSRADYri                   $ymm0, 7
607   $ymm0 = VPSRADZ256ri                         $ymm0, 7                                       
608   ; CHECK: $ymm0 = VPSRADYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
609   $ymm0 = VPSRADZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
610   ; CHECK: $ymm0 = VPSRADYrr                   $ymm0, $xmm1
611   $ymm0 = VPSRADZ256rr                         $ymm0, $xmm1                                   
612   ; CHECK: $ymm0 = VPSRAVDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
613   $ymm0 = VPSRAVDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
614   ; CHECK: $ymm0 = VPSRAVDYrr                  $ymm0, $ymm1
615   $ymm0 = VPSRAVDZ256rr                        $ymm0, $ymm1                                   
616   ; CHECK: $ymm0 = VPSRAWYri                   $ymm0, 7
617   $ymm0 = VPSRAWZ256ri                         $ymm0, 7                                       
618   ; CHECK: $ymm0 = VPSRAWYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
619   $ymm0 = VPSRAWZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
620   ; CHECK: $ymm0 = VPSRAWYrr                   $ymm0, $xmm1
621   $ymm0 = VPSRAWZ256rr                         $ymm0, $xmm1                                   
622   ; CHECK: $ymm0 = VPSRLDQYri                  $ymm0, 7
623   $ymm0 = VPSRLDQZ256rr                        $ymm0, 7
624   ; CHECK: $ymm0 = VPSRLDYri                   $ymm0, 7
625   $ymm0 = VPSRLDZ256ri                         $ymm0, 7                                       
626   ; CHECK: $ymm0 = VPSRLDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
627   $ymm0 = VPSRLDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
628   ; CHECK: $ymm0 = VPSRLDYrr                   $ymm0, $xmm1
629   $ymm0 = VPSRLDZ256rr                         $ymm0, $xmm1                                   
630   ; CHECK: $ymm0 = VPSRLQYri                   $ymm0, 7
631   $ymm0 = VPSRLQZ256ri                         $ymm0, 7                                       
632   ; CHECK: $ymm0 = VPSRLQYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
633   $ymm0 = VPSRLQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
634   ; CHECK: $ymm0 = VPSRLQYrr                   $ymm0, $xmm1
635   $ymm0 = VPSRLQZ256rr                         $ymm0, $xmm1                                   
636   ; CHECK: $ymm0 = VPSRLVDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
637   $ymm0 = VPSRLVDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
638   ; CHECK: $ymm0 = VPSRLVDYrr                  $ymm0, $ymm1
639   $ymm0 = VPSRLVDZ256rr                        $ymm0, $ymm1                                   
640   ; CHECK: $ymm0 = VPSRLVQYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
641   $ymm0 = VPSRLVQZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
642   ; CHECK: $ymm0 = VPSRLVQYrr                  $ymm0, $ymm1
643   $ymm0 = VPSRLVQZ256rr                        $ymm0, $ymm1                                   
644   ; CHECK: $ymm0 = VPSRLWYri                   $ymm0, 7
645   $ymm0 = VPSRLWZ256ri                         $ymm0, 7                                       
646   ; CHECK: $ymm0 = VPSRLWYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
647   $ymm0 = VPSRLWZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
648   ; CHECK: $ymm0 = VPSRLWYrr                   $ymm0, $xmm1                               
649   $ymm0 = VPSRLWZ256rr                         $ymm0, $xmm1                                               
650   ; CHECK: $ymm0 = VPMOVSXBDYrm                $rip, 1, $rax, 0, $noreg
651   $ymm0 = VPMOVSXBDZ256rm                      $rip, 1, $rax, 0, $noreg
652   ; CHECK: $ymm0 = VPMOVSXBDYrr                $xmm0
653   $ymm0 = VPMOVSXBDZ256rr                      $xmm0                                          
654   ; CHECK: $ymm0 = VPMOVSXBQYrm                $rip, 1, $rax, 0, $noreg
655   $ymm0 = VPMOVSXBQZ256rm                      $rip, 1, $rax, 0, $noreg
656   ; CHECK: $ymm0 = VPMOVSXBQYrr                $xmm0
657   $ymm0 = VPMOVSXBQZ256rr                      $xmm0                                          
658   ; CHECK: $ymm0 = VPMOVSXBWYrm                $rip, 1, $rax, 0, $noreg
659   $ymm0 = VPMOVSXBWZ256rm                      $rip, 1, $rax, 0, $noreg
660   ; CHECK: $ymm0 = VPMOVSXBWYrr                $xmm0
661   $ymm0 = VPMOVSXBWZ256rr                      $xmm0                                          
662   ; CHECK: $ymm0 = VPMOVSXDQYrm                $rip, 1, $rax, 0, $noreg
663   $ymm0 = VPMOVSXDQZ256rm                      $rip, 1, $rax, 0, $noreg
664   ; CHECK: $ymm0 = VPMOVSXDQYrr                $xmm0
665   $ymm0 = VPMOVSXDQZ256rr                      $xmm0                                          
666   ; CHECK: $ymm0 = VPMOVSXWDYrm                $rip, 1, $rax, 0, $noreg
667   $ymm0 = VPMOVSXWDZ256rm                      $rip, 1, $rax, 0, $noreg
668   ; CHECK: $ymm0 = VPMOVSXWDYrr                $xmm0
669   $ymm0 = VPMOVSXWDZ256rr                      $xmm0                                          
670   ; CHECK: $ymm0 = VPMOVSXWQYrm                $rip, 1, $rax, 0, $noreg
671   $ymm0 = VPMOVSXWQZ256rm                      $rip, 1, $rax, 0, $noreg
672   ; CHECK: $ymm0 = VPMOVSXWQYrr                $xmm0
673   $ymm0 = VPMOVSXWQZ256rr                      $xmm0                                          
674   ; CHECK: $ymm0 = VPMOVZXBDYrm                $rip, 1, $rax, 0, $noreg
675   $ymm0 = VPMOVZXBDZ256rm                      $rip, 1, $rax, 0, $noreg
676   ; CHECK: $ymm0 = VPMOVZXBDYrr                $xmm0
677   $ymm0 = VPMOVZXBDZ256rr                      $xmm0                                          
678   ; CHECK: $ymm0 = VPMOVZXBQYrm                $rip, 1, $rax, 0, $noreg
679   $ymm0 = VPMOVZXBQZ256rm                      $rip, 1, $rax, 0, $noreg
680   ; CHECK: $ymm0 = VPMOVZXBQYrr                $xmm0
681   $ymm0 = VPMOVZXBQZ256rr                      $xmm0                                          
682   ; CHECK: $ymm0 = VPMOVZXBWYrm                $rip, 1, $rax, 0, $noreg
683   $ymm0 = VPMOVZXBWZ256rm                      $rip, 1, $rax, 0, $noreg
684   ; CHECK: $ymm0 = VPMOVZXBWYrr                $xmm0
685   $ymm0 = VPMOVZXBWZ256rr                      $xmm0                                          
686   ; CHECK: $ymm0 = VPMOVZXDQYrm                $rip, 1, $rax, 0, $noreg
687   $ymm0 = VPMOVZXDQZ256rm                      $rip, 1, $rax, 0, $noreg
688   ; CHECK: $ymm0 = VPMOVZXDQYrr                $xmm0
689   $ymm0 = VPMOVZXDQZ256rr                      $xmm0                                          
690   ; CHECK: $ymm0 = VPMOVZXWDYrm                $rip, 1, $rax, 0, $noreg
691   $ymm0 = VPMOVZXWDZ256rm                      $rip, 1, $rax, 0, $noreg
692   ; CHECK: $ymm0 = VPMOVZXWDYrr                $xmm0
693   $ymm0 = VPMOVZXWDZ256rr                      $xmm0                                          
694   ; CHECK: $ymm0 = VPMOVZXWQYrm                $rip, 1, $rax, 0, $noreg
695   $ymm0 = VPMOVZXWQZ256rm                      $rip, 1, $rax, 0, $noreg
696   ; CHECK: $ymm0 = VPMOVZXWQYrr                $xmm0                                      
697   $ymm0 = VPMOVZXWQZ256rr                      $xmm0                                                 
698   ; CHECK: $ymm0 = VBROADCASTF128              $rip, 1, $rax, 0, $noreg
699   $ymm0 = VBROADCASTF32X4Z256rm                $rip, 1, $rax, 0, $noreg
700   ; CHECK: $ymm0 = VBROADCASTSDYrm             $rip, 1, $rax, 0, $noreg
701   $ymm0 = VBROADCASTF32X2Z256m                 $rip, 1, $rax, 0, $noreg
702   ; CHECK: $ymm0 = VBROADCASTSDYrr             $xmm0
703   $ymm0 = VBROADCASTF32X2Z256r                 $xmm0
704   ; CHECK: $ymm0 = VBROADCASTSDYrm             $rip, 1, $rax, 0, $noreg
705   $ymm0 = VBROADCASTSDZ256m                    $rip, 1, $rax, 0, $noreg
706   ; CHECK: $ymm0 = VBROADCASTSDYrr             $xmm0
707   $ymm0 = VBROADCASTSDZ256r                    $xmm0                                          
708   ; CHECK: $ymm0 = VBROADCASTSSYrm             $rip, 1, $rax, 0, $noreg
709   $ymm0 = VBROADCASTSSZ256m                    $rip, 1, $rax, 0, $noreg
710   ; CHECK: $ymm0 = VBROADCASTSSYrr             $xmm0
711   $ymm0 = VBROADCASTSSZ256r                    $xmm0                                          
712   ; CHECK: $ymm0 = VPBROADCASTBYrm             $rip, 1, $rax, 0, $noreg
713   $ymm0 = VPBROADCASTBZ256m                    $rip, 1, $rax, 0, $noreg
714   ; CHECK: $ymm0 = VPBROADCASTBYrr             $xmm0
715   $ymm0 = VPBROADCASTBZ256r                    $xmm0                                          
716   ; CHECK: $ymm0 = VPBROADCASTDYrm             $rip, 1, $rax, 0, $noreg
717   $ymm0 = VPBROADCASTDZ256m                    $rip, 1, $rax, 0, $noreg
718   ; CHECK: $ymm0 = VPBROADCASTDYrr             $xmm0
719   $ymm0 = VPBROADCASTDZ256r                    $xmm0                                          
720   ; CHECK: $ymm0 = VPBROADCASTWYrm             $rip, 1, $rax, 0, $noreg
721   $ymm0 = VPBROADCASTWZ256m                    $rip, 1, $rax, 0, $noreg
722   ; CHECK: $ymm0 = VPBROADCASTWYrr             $xmm0
723   $ymm0 = VPBROADCASTWZ256r                    $xmm0                                          
724   ; CHECK: $ymm0 = VBROADCASTI128              $rip, 1, $rax, 0, $noreg
725   $ymm0 = VBROADCASTI32X4Z256rm                $rip, 1, $rax, 0, $noreg
726   ; CHECK: $ymm0 = VPBROADCASTQYrm             $rip, 1, $rax, 0, $noreg
727   $ymm0 = VBROADCASTI32X2Z256m                 $rip, 1, $rax, 0, $noreg
728   ; CHECK: $ymm0 = VPBROADCASTQYrr             $xmm0
729   $ymm0 = VBROADCASTI32X2Z256r                 $xmm0
730   ; CHECK: $ymm0 = VPBROADCASTQYrm             $rip, 1, $rax, 0, $noreg
731   $ymm0 = VPBROADCASTQZ256m                    $rip, 1, $rax, 0, $noreg
732   ; CHECK: $ymm0 = VPBROADCASTQYrr             $xmm0                                      
733   $ymm0 = VPBROADCASTQZ256r                    $xmm0                                               
734   ; CHECK: $ymm0 = VPABSBYrm                   $rip, 1, $rax, 0, $noreg
735   $ymm0 = VPABSBZ256rm                         $rip, 1, $rax, 0, $noreg
736   ; CHECK: $ymm0 = VPABSBYrr                   $ymm0
737   $ymm0 = VPABSBZ256rr                         $ymm0                                          
738   ; CHECK: $ymm0 = VPABSDYrm                   $rip, 1, $rax, 0, $noreg
739   $ymm0 = VPABSDZ256rm                         $rip, 1, $rax, 0, $noreg
740   ; CHECK: $ymm0 = VPABSDYrr                   $ymm0
741   $ymm0 = VPABSDZ256rr                         $ymm0                                          
742   ; CHECK: $ymm0 = VPABSWYrm                   $rip, 1, $rax, 0, $noreg
743   $ymm0 = VPABSWZ256rm                         $rip, 1, $rax, 0, $noreg
744   ; CHECK: $ymm0 = VPABSWYrr                   $ymm0                                      
745   $ymm0 = VPABSWZ256rr                         $ymm0                                               
746   ; CHECK: $ymm0 = VPSADBWYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
747   $ymm0 = VPSADBWZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
748   ; CHECK: $ymm0 = VPSADBWYrr                  $ymm0, $ymm1                               
749   $ymm0 = VPSADBWZ256rr                        $ymm0, $ymm1                                               
750   ; CHECK: $ymm0 = VPERMDYrm                   $ymm0, $rdi, 1, $noreg, 0, $noreg
751   $ymm0 = VPERMDZ256rm                         $ymm0, $rdi, 1, $noreg, 0, $noreg                        
752   ; CHECK: $ymm0 = VPERMDYrr                   $ymm1, $ymm0
753   $ymm0 = VPERMDZ256rr                         $ymm1, $ymm0                                   
754   ; CHECK: $ymm0 = VPERMILPDYmi                $rdi, 1, $noreg, 0, $noreg, 7
755   $ymm0 = VPERMILPDZ256mi                      $rdi, 1, $noreg, 0, $noreg, 7
756   ; CHECK: $ymm0 = VPERMILPDYri                $ymm0, 7
757   $ymm0 = VPERMILPDZ256ri                      $ymm0, 7                                       
758   ; CHECK: $ymm0 = VPERMILPDYrm                $ymm0, $rdi, 1, $noreg, 0, $noreg
759   $ymm0 = VPERMILPDZ256rm                      $ymm0, $rdi, 1, $noreg, 0, $noreg                        
760   ; CHECK: $ymm0 = VPERMILPDYrr                $ymm1, $ymm0
761   $ymm0 = VPERMILPDZ256rr                      $ymm1, $ymm0                                   
762   ; CHECK: $ymm0 = VPERMILPSYmi                $rdi, 1, $noreg, 0, $noreg, 7
763   $ymm0 = VPERMILPSZ256mi                      $rdi, 1, $noreg, 0, $noreg, 7
764   ; CHECK: $ymm0 = VPERMILPSYri                $ymm0, 7
765   $ymm0 = VPERMILPSZ256ri                      $ymm0, 7                                       
766   ; CHECK: $ymm0 = VPERMILPSYrm                $ymm0, $rdi, 1, $noreg, 0, $noreg
767   $ymm0 = VPERMILPSZ256rm                      $ymm0, $rdi, 1, $noreg, 0, $noreg                        
768   ; CHECK: $ymm0 = VPERMILPSYrr                $ymm1, $ymm0
769   $ymm0 = VPERMILPSZ256rr                      $ymm1, $ymm0                                   
770   ; CHECK: $ymm0 = VPERMPDYmi                  $rdi, 1, $noreg, 0, $noreg, 7
771   $ymm0 = VPERMPDZ256mi                        $rdi, 1, $noreg, 0, $noreg, 7
772   ; CHECK: $ymm0 = VPERMPDYri                  $ymm0, 7
773   $ymm0 = VPERMPDZ256ri                        $ymm0, 7                                       
774   ; CHECK: $ymm0 = VPERMPSYrm                  $ymm0, $rdi, 1, $noreg, 0, $noreg
775   $ymm0 = VPERMPSZ256rm                        $ymm0, $rdi, 1, $noreg, 0, $noreg                        
776   ; CHECK: $ymm0 = VPERMPSYrr                  $ymm1, $ymm0
777   $ymm0 = VPERMPSZ256rr                        $ymm1, $ymm0                                   
778   ; CHECK: $ymm0 = VPERMQYmi                   $rdi, 1, $noreg, 0, $noreg, 7
779   $ymm0 = VPERMQZ256mi                         $rdi, 1, $noreg, 0, $noreg, 7
780   ; CHECK: $ymm0 = VPERMQYri                   $ymm0, 7                                   
781   $ymm0 = VPERMQZ256ri                         $ymm0, 7                                               
782   ; CHECK: $ymm0 = VPSLLDQYri                  $ymm0, 14
783   $ymm0 = VPSLLDQZ256rr                        $ymm0, 14                                      
784   ; CHECK: $ymm0 = VPSLLDYri                   $ymm0, 7
785   $ymm0 = VPSLLDZ256ri                         $ymm0, 7                                       
786   ; CHECK: $ymm0 = VPSLLDYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
787   $ymm0 = VPSLLDZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
788   ; CHECK: $ymm0 = VPSLLDYrr                   $ymm0, $xmm0
789   $ymm0 = VPSLLDZ256rr                         $ymm0, $xmm0
790   ; CHECK: $ymm0 = VPSLLQYri                   $ymm0, 7
791   $ymm0 = VPSLLQZ256ri                         $ymm0, 7                                       
792   ; CHECK: $ymm0 = VPSLLQYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
793   $ymm0 = VPSLLQZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
794   ; CHECK: $ymm0 = VPSLLQYrr                   $ymm0, $xmm0
795   $ymm0 = VPSLLQZ256rr                         $ymm0, $xmm0
796   ; CHECK: $ymm0 = VPSLLVDYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
797   $ymm0 = VPSLLVDZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
798   ; CHECK: $ymm0 = VPSLLVDYrr                  $ymm0, $ymm0
799   $ymm0 = VPSLLVDZ256rr                        $ymm0, $ymm0
800   ; CHECK: $ymm0 = VPSLLVQYrm                  $ymm0, $rip, 1, $rax, 0, $noreg
801   $ymm0 = VPSLLVQZ256rm                        $ymm0, $rip, 1, $rax, 0, $noreg
802   ; CHECK: $ymm0 = VPSLLVQYrr                  $ymm0, $ymm0
803   $ymm0 = VPSLLVQZ256rr                        $ymm0, $ymm0
804   ; CHECK: $ymm0 = VPSLLWYri                   $ymm0, 7
805   $ymm0 = VPSLLWZ256ri                         $ymm0, 7                                       
806   ; CHECK: $ymm0 = VPSLLWYrm                   $ymm0, $rip, 1, $rax, 0, $noreg
807   $ymm0 = VPSLLWZ256rm                         $ymm0, $rip, 1, $rax, 0, $noreg
808   ; CHECK: $ymm0 = VPSLLWYrr                   $ymm0, $xmm0
809   $ymm0 = VPSLLWZ256rr                         $ymm0, $xmm0
810   ; CHECK: $ymm0 = VCVTDQ2PDYrm                $rdi, 1, $noreg, 0, $noreg
811   $ymm0 = VCVTDQ2PDZ256rm                      $rdi, 1, $noreg, 0, $noreg
812   ; CHECK: $ymm0 = VCVTDQ2PDYrr                $xmm0
813   $ymm0 = VCVTDQ2PDZ256rr                      $xmm0                                          
814   ; CHECK: $ymm0 = VCVTDQ2PSYrm                $rdi, 1, $noreg, 0, $noreg
815   $ymm0 = VCVTDQ2PSZ256rm                      $rdi, 1, $noreg, 0, $noreg
816   ; CHECK: $ymm0 = VCVTDQ2PSYrr                $ymm0
817   $ymm0 = VCVTDQ2PSZ256rr                      $ymm0                                          
818   ; CHECK: $xmm0 = VCVTPD2DQYrm                $rdi, 1, $noreg, 0, $noreg
819   $xmm0 = VCVTPD2DQZ256rm                      $rdi, 1, $noreg, 0, $noreg
820   ; CHECK: $xmm0 = VCVTPD2DQYrr                $ymm0
821   $xmm0 = VCVTPD2DQZ256rr                      $ymm0                                          
822   ; CHECK: $xmm0 = VCVTPD2PSYrm                $rdi, 1, $noreg, 0, $noreg
823   $xmm0 = VCVTPD2PSZ256rm                      $rdi, 1, $noreg, 0, $noreg
824   ; CHECK: $xmm0 = VCVTPD2PSYrr                $ymm0
825   $xmm0 = VCVTPD2PSZ256rr                      $ymm0                                          
826   ; CHECK: $ymm0 = VCVTPS2DQYrm                $rdi, 1, $noreg, 0, $noreg
827   $ymm0 = VCVTPS2DQZ256rm                      $rdi, 1, $noreg, 0, $noreg
828   ; CHECK: $ymm0 = VCVTPS2DQYrr                $ymm0  
829   $ymm0 = VCVTPS2DQZ256rr                      $ymm0                                          
830   ; CHECK: $ymm0 = VCVTPS2PDYrm                $rdi, 1, $noreg, 0, $noreg
831   $ymm0 = VCVTPS2PDZ256rm                      $rdi, 1, $noreg, 0, $noreg
832   ; CHECK: $ymm0 = VCVTPS2PDYrr                $xmm0                                      
833   $ymm0 = VCVTPS2PDZ256rr                      $xmm0                                               
834   ; CHECK: VCVTPS2PHYmr                        $rdi, 1, $noreg, 0, $noreg, $ymm0, 0
835   VCVTPS2PHZ256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm0, 0
836   ; CHECK: $xmm0 = VCVTPS2PHYrr                $ymm0, 0
837   $xmm0 = VCVTPS2PHZ256rr                      $ymm0, 0
838   ; CHECK: $ymm0 = VCVTPH2PSYrm                $rdi, 1, $noreg, 0, $noreg
839   $ymm0 = VCVTPH2PSZ256rm                      $rdi, 1, $noreg, 0, $noreg
840   ; CHECK: $ymm0 = VCVTPH2PSYrr                $xmm0      
841   $ymm0 = VCVTPH2PSZ256rr                      $xmm0                                          
842   ; CHECK: $xmm0 = VCVTTPD2DQYrm               $rdi, 1, $noreg, 0, $noreg
843   $xmm0 = VCVTTPD2DQZ256rm                     $rdi, 1, $noreg, 0, $noreg
844   ; CHECK: $xmm0 = VCVTTPD2DQYrr               $ymm0
845   $xmm0 = VCVTTPD2DQZ256rr                     $ymm0                                          
846   ; CHECK: $ymm0 = VCVTTPS2DQYrm               $rdi, 1, $noreg, 0, $noreg
847   $ymm0 = VCVTTPS2DQZ256rm                     $rdi, 1, $noreg, 0, $noreg
848   ; CHECK: $ymm0 = VCVTTPS2DQYrr               $ymm0                                      
849   $ymm0 = VCVTTPS2DQZ256rr                     $ymm0                                               
850   ; CHECK: $ymm0 = VSQRTPDYm                   $rdi, 1, $noreg, 0, $noreg
851   $ymm0 = VSQRTPDZ256m                         $rdi, 1, $noreg, 0, $noreg
852   ; CHECK: $ymm0 = VSQRTPDYr                   $ymm0
853   $ymm0 = VSQRTPDZ256r                         $ymm0                                          
854   ; CHECK: $ymm0 = VSQRTPSYm                   $rdi, 1, $noreg, 0, $noreg
855   $ymm0 = VSQRTPSZ256m                         $rdi, 1, $noreg, 0, $noreg
856   ; CHECK: $ymm0 = VSQRTPSYr                   $ymm0                                      
857   $ymm0 = VSQRTPSZ256r                         $ymm0                                                 
858   ; CHECK: $ymm0 = VPALIGNRYrmi                $ymm0, $rdi, 1, $noreg, 0, $noreg, 1
859   $ymm0 = VPALIGNRZ256rmi                      $ymm0, $rdi, 1, $noreg, 0, $noreg, 1
860   ; CHECK: $ymm0 = VPALIGNRYrri                $ymm0, $ymm1, 1
861   $ymm0 = VPALIGNRZ256rri                      $ymm0, $ymm1, 1
862   ; CHECK: $ymm0 = VMOVUPSYrm                  $rdi, 1, $noreg, 0, $noreg       
863   $ymm0 = VMOVUPSZ256rm                        $rdi, 1, $noreg, 0, $noreg                               
864   ; CHECK: $ymm0 = VMOVUPSYrr                  $ymm0
865   $ymm0 = VMOVUPSZ256rr                        $ymm0                                          
866   ; CHECK: $ymm0 = VMOVUPSYrr_REV              $ymm0                                      
867   $ymm0 = VMOVUPSZ256rr_REV                    $ymm0                                                
868   ; CHECK: $ymm0 = VPSHUFBYrm                  $ymm0, $rdi, 1, $noreg, 0, $noreg
869   $ymm0 = VPSHUFBZ256rm                        $ymm0, $rdi, 1, $noreg, 0, $noreg
870   ; CHECK: $ymm0 = VPSHUFBYrr                  $ymm0, $ymm1
871   $ymm0 = VPSHUFBZ256rr                        $ymm0, $ymm1                                   
872   ; CHECK: $ymm0 = VPSHUFDYmi                  $rdi, 1, $noreg, 0, $noreg, -24
873   $ymm0 = VPSHUFDZ256mi                        $rdi, 1, $noreg, 0, $noreg, -24
874   ; CHECK: $ymm0 = VPSHUFDYri                  $ymm0, -24
875   $ymm0 = VPSHUFDZ256ri                        $ymm0, -24                                     
876   ; CHECK: $ymm0 = VPSHUFHWYmi                 $rdi, 1, $noreg, 0, $noreg, -24
877   $ymm0 = VPSHUFHWZ256mi                       $rdi, 1, $noreg, 0, $noreg, -24
878   ; CHECK: $ymm0 = VPSHUFHWYri                 $ymm0, -24
879   $ymm0 = VPSHUFHWZ256ri                       $ymm0, -24                                     
880   ; CHECK: $ymm0 = VPSHUFLWYmi                 $rdi, 1, $noreg, 0, $noreg, -24
881   $ymm0 = VPSHUFLWZ256mi                       $rdi, 1, $noreg, 0, $noreg, -24
882   ; CHECK: $ymm0 = VPSHUFLWYri                 $ymm0, -24
883   $ymm0 = VPSHUFLWZ256ri                       $ymm0, -24                                     
884   ; CHECK: $ymm0 = VSHUFPDYrmi                 $ymm0, $rdi, 1, $noreg, 0, $noreg, -24
885   $ymm0 = VSHUFPDZ256rmi                       $ymm0, $rdi, 1, $noreg, 0, $noreg, -24
886   ; CHECK: $ymm0 = VSHUFPDYrri                 $ymm0, $ymm1, -24
887   $ymm0 = VSHUFPDZ256rri                       $ymm0, $ymm1, -24
888   ; CHECK: $ymm0 = VSHUFPSYrmi                 $ymm0, $rdi, 1, $noreg, 0, $noreg, -24
889   $ymm0 = VSHUFPSZ256rmi                       $ymm0, $rdi, 1, $noreg, 0, $noreg, -24
890   ; CHECK: $ymm0 = VSHUFPSYrri                 $ymm0, $ymm1, -24
891   $ymm0 = VSHUFPSZ256rri                       $ymm0, $ymm1, -24
892   ; CHECK: $ymm0 = VROUNDPDYm                  $rip, 1, $rax, 0, $noreg, 15
893   $ymm0 = VRNDSCALEPDZ256rmi                   $rip, 1, $rax, 0, $noreg, 15
894   ; CHECK: $ymm0 = VROUNDPDYr                  $ymm0, 15
895   $ymm0 = VRNDSCALEPDZ256rri                   $ymm0, 15
896   ; CHECK: $ymm0 = VROUNDPSYm                  $rip, 1, $rax, 0, $noreg, 15
897   $ymm0 = VRNDSCALEPSZ256rmi                   $rip, 1, $rax, 0, $noreg, 15
898   ; CHECK: $ymm0 = VROUNDPSYr                  $ymm0, 15
899   $ymm0 = VRNDSCALEPSZ256rri                   $ymm0, 15
900   ; CHECK: $ymm0 = VPERM2F128rm                $ymm0, $rip, 1, $rax, 0, $noreg, 32
901   $ymm0 = VSHUFF32X4Z256rmi                    $ymm0, $rip, 1, $rax, 0, $noreg, 228
902   ; CHECK: $ymm0 = VPERM2F128rr                $ymm0, $ymm1, 32
903   $ymm0 = VSHUFF32X4Z256rri                    $ymm0, $ymm1, 228
904   ; CHECK: $ymm0 = VPERM2F128rm                $ymm0, $rip, 1, $rax, 0, $noreg, 32
905   $ymm0 = VSHUFF64X2Z256rmi                    $ymm0, $rip, 1, $rax, 0, $noreg, 228
906   ; CHECK: $ymm0 = VPERM2F128rr                $ymm0, $ymm1, 32
907   $ymm0 = VSHUFF64X2Z256rri                    $ymm0, $ymm1, 228
908   ; CHECK: $ymm0 = VPERM2I128rm                $ymm0, $rip, 1, $rax, 0, $noreg, 32
909   $ymm0 = VSHUFI32X4Z256rmi                    $ymm0, $rip, 1, $rax, 0, $noreg, 228
910   ; CHECK: $ymm0 = VPERM2I128rr                $ymm0, $ymm1, 32
911   $ymm0 = VSHUFI32X4Z256rri                    $ymm0, $ymm1, 228
912   ; CHECK: $ymm0 = VPERM2I128rm                $ymm0, $rip, 1, $rax, 0, $noreg, 32
913   $ymm0 = VSHUFI64X2Z256rmi                    $ymm0, $rip, 1, $rax, 0, $noreg, 228
914   ; CHECK: $ymm0 = VPERM2I128rr                $ymm0, $ymm1, 32
915   $ymm0 = VSHUFI64X2Z256rri                    $ymm0, $ymm1, 228
917     RET 0, $zmm0, $zmm1
920   # CHECK-LABEL: name: evex_z128_to_vex_test
921   # CHECK: bb.0:
923 name: evex_z128_to_vex_test
924 body: |
925   bb.0:
926   ; CHECK: VMOVAPDmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
927   VMOVAPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
928   ; CHECK: $xmm0 = VMOVAPDrm                   $rip, 1, $rax, 0, $noreg
929   $xmm0 = VMOVAPDZ128rm                        $rip, 1, $rax, 0, $noreg
930   ; CHECK: $xmm0 = VMOVAPDrr                   $xmm0
931   $xmm0 = VMOVAPDZ128rr                        $xmm0                                               
932   ; CHECK: VMOVAPSmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
933   VMOVAPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
934   ; CHECK: $xmm0 = VMOVAPSrm                   $rip, 1, $rax, 0, $noreg
935   $xmm0 = VMOVAPSZ128rm                        $rip, 1, $rax, 0, $noreg
936   ; CHECK: $xmm0 = VMOVAPSrr                   $xmm0  
937   $xmm0 = VMOVAPSZ128rr                        $xmm0                                               
938   ; CHECK: VMOVDQAmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
939   VMOVDQA32Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm0                             
940   ; CHECK: $xmm0 = VMOVDQArm                   $rip, 1, $rax, 0, $noreg
941   $xmm0 = VMOVDQA32Z128rm                      $rip, 1, $rax, 0, $noreg
942   ; CHECK: $xmm0 = VMOVDQArr                   $xmm0
943   $xmm0 = VMOVDQA32Z128rr                      $xmm0                                               
944   ; CHECK: VMOVDQAmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
945   VMOVDQA64Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm0                             
946   ; CHECK: $xmm0 = VMOVDQArm                   $rip, 1, $rax, 0, $noreg
947   $xmm0 = VMOVDQA64Z128rm                      $rip, 1, $rax, 0, $noreg
948   ; CHECK: $xmm0 = VMOVDQArr                   $xmm0
949   $xmm0 = VMOVDQA64Z128rr                      $xmm0                                               
950   ; CHECK: VMOVDQUmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
951   VMOVDQU16Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm0                             
952   ; CHECK: $xmm0 = VMOVDQUrm                   $rip, 1, $rax, 0, $noreg
953   $xmm0 = VMOVDQU16Z128rm                      $rip, 1, $rax, 0, $noreg
954   ; CHECK: $xmm0 = VMOVDQUrr                   $xmm0
955   $xmm0 = VMOVDQU16Z128rr                      $xmm0                                               
956   ; CHECK: VMOVDQUmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
957   VMOVDQU32Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm0                             
958   ; CHECK: $xmm0 = VMOVDQUrm                   $rip, 1, $rax, 0, $noreg
959   $xmm0 = VMOVDQU32Z128rm                      $rip, 1, $rax, 0, $noreg
960   ; CHECK: $xmm0 = VMOVDQUrr                   $xmm0
961   $xmm0 = VMOVDQU32Z128rr                      $xmm0                                               
962   ; CHECK: VMOVDQUmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
963   VMOVDQU64Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm0                             
964   ; CHECK: $xmm0 = VMOVDQUrm                   $rip, 1, $rax, 0, $noreg
965   $xmm0 = VMOVDQU64Z128rm                      $rip, 1, $rax, 0, $noreg
966   ; CHECK: $xmm0 = VMOVDQUrr                   $xmm0
967   $xmm0 = VMOVDQU64Z128rr                      $xmm0                                               
968   ; CHECK: VMOVDQUmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
969   VMOVDQU8Z128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm0                             
970   ; CHECK: $xmm0 = VMOVDQUrm                   $rip, 1, $rax, 0, $noreg
971   $xmm0 = VMOVDQU8Z128rm                       $rip, 1, $rax, 0, $noreg
972   ; CHECK: $xmm0 = VMOVDQUrr                   $xmm0
973   $xmm0 = VMOVDQU8Z128rr                       $xmm0                                               
974   ; CHECK: $xmm0 = VMOVDQUrr_REV               $xmm0
975   $xmm0 = VMOVDQU8Z128rr_REV                   $xmm0                                               
976   ; CHECK: $xmm0 = VMOVNTDQArm                 $rip, 1, $rax, 0, $noreg
977   $xmm0 = VMOVNTDQAZ128rm                      $rip, 1, $rax, 0, $noreg
978   ; CHECK: VMOVUPDmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
979   VMOVUPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
980   ; CHECK: $xmm0 = VMOVUPDrm                   $rip, 1, $rax, 0, $noreg
981   $xmm0 = VMOVUPDZ128rm                        $rip, 1, $rax, 0, $noreg
982   ; CHECK: $xmm0 = VMOVUPDrr                   $xmm0
983   $xmm0 = VMOVUPDZ128rr                        $xmm0                                               
984   ; CHECK: $xmm0 = VMOVUPDrr_REV               $xmm0
985   $xmm0 = VMOVUPDZ128rr_REV                    $xmm0                                               
986   ; CHECK: VMOVUPSmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
987   VMOVUPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
988   ; CHECK: $xmm0 = VMOVUPSrm                   $rip, 1, $rax, 0, $noreg
989   $xmm0 = VMOVUPSZ128rm                        $rip, 1, $rax, 0, $noreg
990   ; CHECK: $xmm0 = VMOVUPSrr                   $xmm0
991   $xmm0 = VMOVUPSZ128rr                        $xmm0                                               
992   ; CHECK: $xmm0 = VMOVUPSrr_REV               $xmm0
993   $xmm0 = VMOVUPSZ128rr_REV                    $xmm0                                               
994   ; CHECK: VMOVNTDQmr                          $rdi, 1, $noreg, 0, $noreg, $xmm0
995   VMOVNTDQZ128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm0                             
996   ; CHECK: VMOVNTPDmr                          $rdi, 1, $noreg, 0, $noreg, $xmm0
997   VMOVNTPDZ128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm0                             
998   ; CHECK: VMOVNTPSmr                          $rdi, 1, $noreg, 0, $noreg, $xmm0
999   VMOVNTPSZ128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm0                             
1000   ; CHECK: $xmm0 = VMOVAPDrr_REV               $xmm0
1001   $xmm0 = VMOVAPDZ128rr_REV                    $xmm0                                               
1002   ; CHECK: $xmm0 = VMOVAPSrr_REV               $xmm0
1003   $xmm0 = VMOVAPSZ128rr_REV                    $xmm0                                               
1004   ; CHECK: $xmm0 = VMOVDQArr_REV               $xmm0
1005   $xmm0 = VMOVDQA32Z128rr_REV                  $xmm0                                               
1006   ; CHECK: $xmm0 = VMOVDQArr_REV               $xmm0
1007   $xmm0 = VMOVDQA64Z128rr_REV                  $xmm0                                               
1008   ; CHECK: $xmm0 = VMOVDQUrr_REV               $xmm0
1009   $xmm0 = VMOVDQU16Z128rr_REV                  $xmm0                                               
1010   ; CHECK: $xmm0 = VMOVDQUrr_REV               $xmm0
1011   $xmm0 = VMOVDQU32Z128rr_REV                  $xmm0                                               
1012   ; CHECK: $xmm0 = VMOVDQUrr_REV               $xmm0  
1013   $xmm0 = VMOVDQU64Z128rr_REV                  $xmm0                                               
1014   ; CHECK: $xmm0 = VPMOVSXBDrm                 $rip, 1, $rax, 0, $noreg
1015   $xmm0 = VPMOVSXBDZ128rm                      $rip, 1, $rax, 0, $noreg
1016   ; CHECK: $xmm0 = VPMOVSXBDrr                 $xmm0
1017   $xmm0 = VPMOVSXBDZ128rr                      $xmm0                                               
1018   ; CHECK: $xmm0 = VPMOVSXBQrm                 $rip, 1, $rax, 0, $noreg
1019   $xmm0 = VPMOVSXBQZ128rm                      $rip, 1, $rax, 0, $noreg
1020   ; CHECK: $xmm0 = VPMOVSXBQrr                 $xmm0
1021   $xmm0 = VPMOVSXBQZ128rr                      $xmm0                                               
1022   ; CHECK: $xmm0 = VPMOVSXBWrm                 $rip, 1, $rax, 0, $noreg
1023   $xmm0 = VPMOVSXBWZ128rm                      $rip, 1, $rax, 0, $noreg
1024   ; CHECK: $xmm0 = VPMOVSXBWrr                 $xmm0
1025   $xmm0 = VPMOVSXBWZ128rr                      $xmm0                                               
1026   ; CHECK: $xmm0 = VPMOVSXDQrm                 $rip, 1, $rax, 0, $noreg
1027   $xmm0 = VPMOVSXDQZ128rm                      $rip, 1, $rax, 0, $noreg
1028   ; CHECK: $xmm0 = VPMOVSXDQrr                 $xmm0
1029   $xmm0 = VPMOVSXDQZ128rr                      $xmm0                                               
1030   ; CHECK: $xmm0 = VPMOVSXWDrm                 $rip, 1, $rax, 0, $noreg
1031   $xmm0 = VPMOVSXWDZ128rm                      $rip, 1, $rax, 0, $noreg
1032   ; CHECK: $xmm0 = VPMOVSXWDrr                 $xmm0
1033   $xmm0 = VPMOVSXWDZ128rr                      $xmm0                                               
1034   ; CHECK: $xmm0 = VPMOVSXWQrm                 $rip, 1, $rax, 0, $noreg
1035   $xmm0 = VPMOVSXWQZ128rm                      $rip, 1, $rax, 0, $noreg
1036   ; CHECK: $xmm0 = VPMOVSXWQrr                 $xmm0
1037   $xmm0 = VPMOVSXWQZ128rr                      $xmm0                                               
1038   ; CHECK: $xmm0 = VPMOVZXBDrm                 $rip, 1, $rax, 0, $noreg
1039   $xmm0 = VPMOVZXBDZ128rm                      $rip, 1, $rax, 0, $noreg
1040   ; CHECK: $xmm0 = VPMOVZXBDrr                 $xmm0
1041   $xmm0 = VPMOVZXBDZ128rr                      $xmm0                                               
1042   ; CHECK: $xmm0 = VPMOVZXBQrm                 $rip, 1, $rax, 0, $noreg
1043   $xmm0 = VPMOVZXBQZ128rm                      $rip, 1, $rax, 0, $noreg
1044   ; CHECK: $xmm0 = VPMOVZXBQrr                 $xmm0
1045   $xmm0 = VPMOVZXBQZ128rr                      $xmm0                                               
1046   ; CHECK: $xmm0 = VPMOVZXBWrm                 $rip, 1, $rax, 0, $noreg
1047   $xmm0 = VPMOVZXBWZ128rm                      $rip, 1, $rax, 0, $noreg
1048   ; CHECK: $xmm0 = VPMOVZXBWrr                 $xmm0
1049   $xmm0 = VPMOVZXBWZ128rr                      $xmm0                                               
1050   ; CHECK: $xmm0 = VPMOVZXDQrm                 $rip, 1, $rax, 0, $noreg
1051   $xmm0 = VPMOVZXDQZ128rm                      $rip, 1, $rax, 0, $noreg
1052   ; CHECK: $xmm0 = VPMOVZXDQrr                 $xmm0
1053   $xmm0 = VPMOVZXDQZ128rr                      $xmm0                                               
1054   ; CHECK: $xmm0 = VPMOVZXWDrm                 $rip, 1, $rax, 0, $noreg
1055   $xmm0 = VPMOVZXWDZ128rm                      $rip, 1, $rax, 0, $noreg
1056   ; CHECK: $xmm0 = VPMOVZXWDrr                 $xmm0
1057   $xmm0 = VPMOVZXWDZ128rr                      $xmm0                                               
1058   ; CHECK: $xmm0 = VPMOVZXWQrm                 $rip, 1, $rax, 0, $noreg
1059   $xmm0 = VPMOVZXWQZ128rm                      $rip, 1, $rax, 0, $noreg
1060   ; CHECK: $xmm0 = VPMOVZXWQrr                 $xmm0
1061   $xmm0 = VPMOVZXWQZ128rr                      $xmm0                                               
1062   ; CHECK: VMOVHPDmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
1063   VMOVHPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
1064   ; CHECK: $xmm0 = VMOVHPDrm                   $xmm0,  $rdi, 1, $noreg, 0, $noreg
1065   $xmm0 = VMOVHPDZ128rm                        $xmm0,  $rdi, 1, $noreg, 0, $noreg                            
1066   ; CHECK: VMOVHPSmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
1067   VMOVHPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
1068   ; CHECK: $xmm0 = VMOVHPSrm                   $xmm0,  $rdi, 1, $noreg, 0, $noreg
1069   $xmm0 = VMOVHPSZ128rm                        $xmm0,  $rdi, 1, $noreg, 0, $noreg                            
1070   ; CHECK: VMOVLPDmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
1071   VMOVLPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
1072   ; CHECK: $xmm0 = VMOVLPDrm                   $xmm0,  $rdi, 1, $noreg, 0, $noreg
1073   $xmm0 = VMOVLPDZ128rm                        $xmm0,  $rdi, 1, $noreg, 0, $noreg                            
1074   ; CHECK: VMOVLPSmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0
1075   VMOVLPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm0                             
1076   ; CHECK: $xmm0 = VMOVLPSrm                   $xmm0,  $rdi, 1, $noreg, 0, $noreg                
1077   $xmm0 = VMOVLPSZ128rm                        $xmm0,  $rdi, 1, $noreg, 0, $noreg                                               
1078   ; CHECK: $xmm0 = VMAXCPDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1079   $xmm0 = VMAXCPDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1080   ; CHECK: $xmm0 = VMAXCPDrr                   $xmm0, $xmm1  
1081   $xmm0 = VMAXCPDZ128rr                        $xmm0, $xmm1                                        
1082   ; CHECK: $xmm0 = VMAXCPSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1083   $xmm0 = VMAXCPSZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1084   ; CHECK: $xmm0 = VMAXCPSrr                   $xmm0, $xmm1
1085   $xmm0 = VMAXCPSZ128rr                        $xmm0, $xmm1                                        
1086   ; CHECK: $xmm0 = VMAXCPDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1087   $xmm0 = VMAXPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1088   ; CHECK: $xmm0 = VMAXCPDrr                   $xmm0, $xmm1
1089   $xmm0 = VMAXPDZ128rr                         $xmm0, $xmm1                                        
1090   ; CHECK: $xmm0 = VMAXCPSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1091   $xmm0 = VMAXPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1092   ; CHECK: $xmm0 = VMAXCPSrr                   $xmm0, $xmm1
1093   $xmm0 = VMAXPSZ128rr                         $xmm0, $xmm1                                        
1094   ; CHECK: $xmm0 = VMINCPDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1095   $xmm0 = VMINCPDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1096   ; CHECK: $xmm0 = VMINCPDrr                   $xmm0, $xmm1  
1097   $xmm0 = VMINCPDZ128rr                        $xmm0, $xmm1                                        
1098   ; CHECK: $xmm0 = VMINCPSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1099   $xmm0 = VMINCPSZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1100   ; CHECK: $xmm0 = VMINCPSrr                   $xmm0, $xmm1
1101   $xmm0 = VMINCPSZ128rr                        $xmm0, $xmm1                                        
1102   ; CHECK: $xmm0 = VMINCPDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1103   $xmm0 = VMINPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1104   ; CHECK: $xmm0 = VMINCPDrr                   $xmm0, $xmm1
1105   $xmm0 = VMINPDZ128rr                         $xmm0, $xmm1                                        
1106   ; CHECK: $xmm0 = VMINCPSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1107   $xmm0 = VMINPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1108   ; CHECK: $xmm0 = VMINCPSrr                   $xmm0, $xmm1
1109   $xmm0 = VMINPSZ128rr                         $xmm0, $xmm1                                        
1110   ; CHECK: $xmm0 = VMULPDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1111   $xmm0 = VMULPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1112   ; CHECK: $xmm0 = VMULPDrr                    $xmm0, $xmm1
1113   $xmm0 = VMULPDZ128rr                         $xmm0, $xmm1                                        
1114   ; CHECK: $xmm0 = VMULPSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1115   $xmm0 = VMULPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1116   ; CHECK: $xmm0 = VMULPSrr                    $xmm0, $xmm1
1117   $xmm0 = VMULPSZ128rr                         $xmm0, $xmm1                                        
1118   ; CHECK: $xmm0 = VORPDrm                     $xmm0, $rip, 1, $rax, 0, $noreg
1119   $xmm0 = VORPDZ128rm                          $xmm0, $rip, 1, $rax, 0, $noreg
1120   ; CHECK: $xmm0 = VORPDrr                     $xmm0, $xmm1
1121   $xmm0 = VORPDZ128rr                          $xmm0, $xmm1                                        
1122   ; CHECK: $xmm0 = VORPSrm                     $xmm0, $rip, 1, $rax, 0, $noreg
1123   $xmm0 = VORPSZ128rm                          $xmm0, $rip, 1, $rax, 0, $noreg
1124   ; CHECK: $xmm0 = VORPSrr                     $xmm0, $xmm1
1125   $xmm0 = VORPSZ128rr                          $xmm0, $xmm1                                        
1126   ; CHECK: $xmm0 = VPADDBrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1127   $xmm0 = VPADDBZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1128   ; CHECK: $xmm0 = VPADDBrr                    $xmm0, $xmm1
1129   $xmm0 = VPADDBZ128rr                         $xmm0, $xmm1                                        
1130   ; CHECK: $xmm0 = VPADDDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1131   $xmm0 = VPADDDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1132   ; CHECK: $xmm0 = VPADDDrr                    $xmm0, $xmm1
1133   $xmm0 = VPADDDZ128rr                         $xmm0, $xmm1                                        
1134   ; CHECK: $xmm0 = VPADDQrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1135   $xmm0 = VPADDQZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1136   ; CHECK: $xmm0 = VPADDQrr                    $xmm0, $xmm1
1137   $xmm0 = VPADDQZ128rr                         $xmm0, $xmm1                                        
1138   ; CHECK: $xmm0 = VPADDSBrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1139   $xmm0 = VPADDSBZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1140   ; CHECK: $xmm0 = VPADDSBrr                   $xmm0, $xmm1
1141   $xmm0 = VPADDSBZ128rr                        $xmm0, $xmm1                                        
1142   ; CHECK: $xmm0 = VPADDSWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1143   $xmm0 = VPADDSWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1144   ; CHECK: $xmm0 = VPADDSWrr                   $xmm0, $xmm1
1145   $xmm0 = VPADDSWZ128rr                        $xmm0, $xmm1                                        
1146   ; CHECK: $xmm0 = VPADDUSBrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1147   $xmm0 = VPADDUSBZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1148   ; CHECK: $xmm0 = VPADDUSBrr                  $xmm0, $xmm1
1149   $xmm0 = VPADDUSBZ128rr                       $xmm0, $xmm1                                        
1150   ; CHECK: $xmm0 = VPADDUSWrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1151   $xmm0 = VPADDUSWZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1152   ; CHECK: $xmm0 = VPADDUSWrr                  $xmm0, $xmm1
1153   $xmm0 = VPADDUSWZ128rr                       $xmm0, $xmm1                                        
1154   ; CHECK: $xmm0 = VPADDWrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1155   $xmm0 = VPADDWZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1156   ; CHECK: $xmm0 = VPADDWrr                    $xmm0, $xmm1
1157   $xmm0 = VPADDWZ128rr                         $xmm0, $xmm1                                        
1158   ; CHECK: $xmm0 = VPANDrm                     $xmm0, $rip, 1, $rax, 0, $noreg
1159   $xmm0 = VPANDDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1160   ; CHECK: $xmm0 = VPANDrr                     $xmm0, $xmm1
1161   $xmm0 = VPANDDZ128rr                         $xmm0, $xmm1                                        
1162   ; CHECK: $xmm0 = VPANDrm                     $xmm0, $rip, 1, $rax, 0, $noreg
1163   $xmm0 = VPANDQZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1164   ; CHECK: $xmm0 = VPANDrr                     $xmm0, $xmm1  
1165   $xmm0 = VPANDQZ128rr                         $xmm0, $xmm1                                        
1166   ; CHECK: $xmm0 = VPANDNrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1167   $xmm0 = VPANDNDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1168   ; CHECK: $xmm0 = VPANDNrr                    $xmm0, $xmm1
1169   $xmm0 = VPANDNDZ128rr                        $xmm0, $xmm1                                        
1170   ; CHECK: $xmm0 = VPANDNrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1171   $xmm0 = VPANDNQZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1172   ; CHECK: $xmm0 = VPANDNrr                    $xmm0, $xmm1  
1173   $xmm0 = VPANDNQZ128rr                        $xmm0, $xmm1                                        
1174   ; CHECK: $xmm0 = VPAVGBrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1175   $xmm0 = VPAVGBZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1176   ; CHECK: $xmm0 = VPAVGBrr                    $xmm0, $xmm1  
1177   $xmm0 = VPAVGBZ128rr                         $xmm0, $xmm1                                        
1178   ; CHECK: $xmm0 = VPAVGWrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1179   $xmm0 = VPAVGWZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1180   ; CHECK: $xmm0 = VPAVGWrr                    $xmm0, $xmm1
1181   $xmm0 = VPAVGWZ128rr                         $xmm0, $xmm1                                        
1182   ; CHECK: $xmm0 = VPMAXSBrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1183   $xmm0 = VPMAXSBZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1184   ; CHECK: $xmm0 = VPMAXSBrr                   $xmm0, $xmm1
1185   $xmm0 = VPMAXSBZ128rr                        $xmm0, $xmm1                                        
1186   ; CHECK: $xmm0 = VPMAXSDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1187   $xmm0 = VPMAXSDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1188   ; CHECK: $xmm0 = VPMAXSDrr                   $xmm0, $xmm1
1189   $xmm0 = VPMAXSDZ128rr                        $xmm0, $xmm1                                        
1190   ; CHECK: $xmm0 = VPMAXSWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1191   $xmm0 = VPMAXSWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1192   ; CHECK: $xmm0 = VPMAXSWrr                   $xmm0, $xmm1  
1193   $xmm0 = VPMAXSWZ128rr                        $xmm0, $xmm1                                        
1194   ; CHECK: $xmm0 = VPMAXUBrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1195   $xmm0 = VPMAXUBZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1196   ; CHECK: $xmm0 = VPMAXUBrr                   $xmm0, $xmm1
1197   $xmm0 = VPMAXUBZ128rr                        $xmm0, $xmm1                                        
1198   ; CHECK: $xmm0 = VPMAXUDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1199   $xmm0 = VPMAXUDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1200   ; CHECK: $xmm0 = VPMAXUDrr                   $xmm0, $xmm1
1201   $xmm0 = VPMAXUDZ128rr                        $xmm0, $xmm1                                        
1202   ; CHECK: $xmm0 = VPMAXUWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1203   $xmm0 = VPMAXUWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1204   ; CHECK: $xmm0 = VPMAXUWrr                   $xmm0, $xmm1
1205   $xmm0 = VPMAXUWZ128rr                        $xmm0, $xmm1                                        
1206   ; CHECK: $xmm0 = VPMINSBrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1207   $xmm0 = VPMINSBZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1208   ; CHECK: $xmm0 = VPMINSBrr                   $xmm0, $xmm1
1209   $xmm0 = VPMINSBZ128rr                        $xmm0, $xmm1                                        
1210   ; CHECK: $xmm0 = VPMINSDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1211   $xmm0 = VPMINSDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1212   ; CHECK: $xmm0 = VPMINSDrr                   $xmm0, $xmm1
1213   $xmm0 = VPMINSDZ128rr                        $xmm0, $xmm1                                        
1214   ; CHECK: $xmm0 = VPMINSWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1215   $xmm0 = VPMINSWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1216   ; CHECK: $xmm0 = VPMINSWrr                   $xmm0, $xmm1
1217   $xmm0 = VPMINSWZ128rr                        $xmm0, $xmm1                                        
1218   ; CHECK: $xmm0 = VPMINUBrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1219   $xmm0 = VPMINUBZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1220   ; CHECK: $xmm0 = VPMINUBrr                   $xmm0, $xmm1
1221   $xmm0 = VPMINUBZ128rr                        $xmm0, $xmm1                                        
1222   ; CHECK: $xmm0 = VPMINUDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1223   $xmm0 = VPMINUDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1224   ; CHECK: $xmm0 = VPMINUDrr                   $xmm0, $xmm1
1225   $xmm0 = VPMINUDZ128rr                        $xmm0, $xmm1                                        
1226   ; CHECK: $xmm0 = VPMINUWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1227   $xmm0 = VPMINUWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1228   ; CHECK: $xmm0 = VPMINUWrr                   $xmm0, $xmm1
1229   $xmm0 = VPMINUWZ128rr                        $xmm0, $xmm1                                        
1230   ; CHECK: $xmm0 = VPMULDQrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1231   $xmm0 = VPMULDQZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1232   ; CHECK: $xmm0 = VPMULDQrr                   $xmm0, $xmm1
1233   $xmm0 = VPMULDQZ128rr                        $xmm0, $xmm1                                        
1234   ; CHECK: $xmm0 = VPMULHRSWrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1235   $xmm0 = VPMULHRSWZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1236   ; CHECK: $xmm0 = VPMULHRSWrr                 $xmm0, $xmm1
1237   $xmm0 = VPMULHRSWZ128rr                      $xmm0, $xmm1                                        
1238   ; CHECK: $xmm0 = VPMULHUWrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1239   $xmm0 = VPMULHUWZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1240   ; CHECK: $xmm0 = VPMULHUWrr                  $xmm0, $xmm1
1241   $xmm0 = VPMULHUWZ128rr                       $xmm0, $xmm1                                        
1242   ; CHECK: $xmm0 = VPMULHWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1243   $xmm0 = VPMULHWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1244   ; CHECK: $xmm0 = VPMULHWrr                   $xmm0, $xmm1
1245   $xmm0 = VPMULHWZ128rr                        $xmm0, $xmm1                                        
1246   ; CHECK: $xmm0 = VPMULLDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1247   $xmm0 = VPMULLDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1248   ; CHECK: $xmm0 = VPMULLDrr                   $xmm0, $xmm1
1249   $xmm0 = VPMULLDZ128rr                        $xmm0, $xmm1                                        
1250   ; CHECK: $xmm0 = VPMULLWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1251   $xmm0 = VPMULLWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1252   ; CHECK: $xmm0 = VPMULLWrr                   $xmm0, $xmm1
1253   $xmm0 = VPMULLWZ128rr                        $xmm0, $xmm1                                        
1254   ; CHECK: $xmm0 = VPMULUDQrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1255   $xmm0 = VPMULUDQZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1256   ; CHECK: $xmm0 = VPMULUDQrr                  $xmm0, $xmm1
1257   $xmm0 = VPMULUDQZ128rr                       $xmm0, $xmm1                                        
1258   ; CHECK: $xmm0 = VPORrm                      $xmm0, $rip, 1, $rax, 0, $noreg
1259   $xmm0 = VPORDZ128rm                          $xmm0, $rip, 1, $rax, 0, $noreg
1260   ; CHECK: $xmm0 = VPORrr                      $xmm0, $xmm1
1261   $xmm0 = VPORDZ128rr                          $xmm0, $xmm1                                        
1262   ; CHECK: $xmm0 = VPORrm                      $xmm0, $rip, 1, $rax, 0, $noreg
1263   $xmm0 = VPORQZ128rm                          $xmm0, $rip, 1, $rax, 0, $noreg
1264   ; CHECK: $xmm0 = VPORrr                      $xmm0, $xmm1  
1265   $xmm0 = VPORQZ128rr                          $xmm0, $xmm1                                        
1266   ; CHECK: $xmm0 = VPSUBBrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1267   $xmm0 = VPSUBBZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1268   ; CHECK: $xmm0 = VPSUBBrr                    $xmm0, $xmm1
1269   $xmm0 = VPSUBBZ128rr                         $xmm0, $xmm1                                        
1270   ; CHECK: $xmm0 = VPSUBDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1271   $xmm0 = VPSUBDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1272   ; CHECK: $xmm0 = VPSUBDrr                    $xmm0, $xmm1
1273   $xmm0 = VPSUBDZ128rr                         $xmm0, $xmm1                                        
1274   ; CHECK: $xmm0 = VPSUBQrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1275   $xmm0 = VPSUBQZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1276   ; CHECK: $xmm0 = VPSUBQrr                    $xmm0, $xmm1
1277   $xmm0 = VPSUBQZ128rr                         $xmm0, $xmm1                                        
1278   ; CHECK: $xmm0 = VPSUBSBrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1279   $xmm0 = VPSUBSBZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1280   ; CHECK: $xmm0 = VPSUBSBrr                   $xmm0, $xmm1  
1281   $xmm0 = VPSUBSBZ128rr                        $xmm0, $xmm1                                        
1282   ; CHECK: $xmm0 = VPSUBSWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1283   $xmm0 = VPSUBSWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1284   ; CHECK: $xmm0 = VPSUBSWrr                   $xmm0, $xmm1
1285   $xmm0 = VPSUBSWZ128rr                        $xmm0, $xmm1                                        
1286   ; CHECK: $xmm0 = VPSUBUSBrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1287   $xmm0 = VPSUBUSBZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1288   ; CHECK: $xmm0 = VPSUBUSBrr                  $xmm0, $xmm1  
1289   $xmm0 = VPSUBUSBZ128rr                       $xmm0, $xmm1                                        
1290   ; CHECK: $xmm0 = VPSUBUSWrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1291   $xmm0 = VPSUBUSWZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1292   ; CHECK: $xmm0 = VPSUBUSWrr                  $xmm0, $xmm1
1293   $xmm0 = VPSUBUSWZ128rr                       $xmm0, $xmm1                                        
1294   ; CHECK: $xmm0 = VPSUBWrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1295   $xmm0 = VPSUBWZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1296   ; CHECK: $xmm0 = VPSUBWrr                    $xmm0, $xmm1                            
1297   $xmm0 = VPSUBWZ128rr                         $xmm0, $xmm1                                        
1298   ; CHECK: $xmm0 = VADDPDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1299   $xmm0 = VADDPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1300   ; CHECK: $xmm0 = VADDPDrr                    $xmm0, $xmm1  
1301   $xmm0 = VADDPDZ128rr                         $xmm0, $xmm1                                        
1302   ; CHECK: $xmm0 = VADDPSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1303   $xmm0 = VADDPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1304   ; CHECK: $xmm0 = VADDPSrr                    $xmm0, $xmm1
1305   $xmm0 = VADDPSZ128rr                         $xmm0, $xmm1                                        
1306   ; CHECK: $xmm0 = VANDNPDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1307   $xmm0 = VANDNPDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1308   ; CHECK: $xmm0 = VANDNPDrr                   $xmm0, $xmm1
1309   $xmm0 = VANDNPDZ128rr                        $xmm0, $xmm1                                        
1310   ; CHECK: $xmm0 = VANDNPSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1311   $xmm0 = VANDNPSZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1312   ; CHECK: $xmm0 = VANDNPSrr                   $xmm0, $xmm1
1313   $xmm0 = VANDNPSZ128rr                        $xmm0, $xmm1                                        
1314   ; CHECK: $xmm0 = VANDPDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1315   $xmm0 = VANDPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1316   ; CHECK: $xmm0 = VANDPDrr                    $xmm0, $xmm1  
1317   $xmm0 = VANDPDZ128rr                         $xmm0, $xmm1                                        
1318   ; CHECK: $xmm0 = VANDPSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1319   $xmm0 = VANDPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1320   ; CHECK: $xmm0 = VANDPSrr                    $xmm0, $xmm1
1321   $xmm0 = VANDPSZ128rr                         $xmm0, $xmm1                                        
1322   ; CHECK: $xmm0 = VDIVPDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1323   $xmm0 = VDIVPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1324   ; CHECK: $xmm0 = VDIVPDrr                    $xmm0, $xmm1
1325   $xmm0 = VDIVPDZ128rr                         $xmm0, $xmm1                                        
1326   ; CHECK: $xmm0 = VDIVPSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1327   $xmm0 = VDIVPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1328   ; CHECK: $xmm0 = VDIVPSrr                    $xmm0, $xmm1
1329   $xmm0 = VDIVPSZ128rr                         $xmm0, $xmm1                                        
1330   ; CHECK: $xmm0 = VPXORrm                     $xmm0, $rip, 1, $rax, 0, $noreg
1331   $xmm0 = VPXORDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1332   ; CHECK: $xmm0 = VPXORrr                     $xmm0, $xmm1
1333   $xmm0 = VPXORDZ128rr                         $xmm0, $xmm1                                        
1334   ; CHECK: $xmm0 = VPXORrm                     $xmm0, $rip, 1, $rax, 0, $noreg
1335   $xmm0 = VPXORQZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1336   ; CHECK: $xmm0 = VPXORrr                     $xmm0, $xmm1
1337   $xmm0 = VPXORQZ128rr                         $xmm0, $xmm1                                        
1338   ; CHECK: $xmm0 = VSUBPDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1339   $xmm0 = VSUBPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1340   ; CHECK: $xmm0 = VSUBPDrr                    $xmm0, $xmm1
1341   $xmm0 = VSUBPDZ128rr                         $xmm0, $xmm1                                        
1342   ; CHECK: $xmm0 = VSUBPSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1343   $xmm0 = VSUBPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1344   ; CHECK: $xmm0 = VSUBPSrr                    $xmm0, $xmm1                  
1345   $xmm0 = VSUBPSZ128rr                         $xmm0, $xmm1                                        
1346   ; CHECK: $xmm0 = VXORPDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1347   $xmm0 = VXORPDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1348   ; CHECK: $xmm0 = VXORPDrr                    $xmm0, $xmm1
1349   $xmm0 = VXORPDZ128rr                         $xmm0, $xmm1                                        
1350   ; CHECK: $xmm0 = VXORPSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1351   $xmm0 = VXORPSZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1352   ; CHECK: $xmm0 = VXORPSrr                    $xmm0, $xmm1
1353   $xmm0 = VXORPSZ128rr                         $xmm0, $xmm1                                        
1354   ; CHECK: $xmm0 = VPMADDUBSWrm                $xmm0, $rip, 1, $rax, 0, $noreg
1355   $xmm0 = VPMADDUBSWZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1356   ; CHECK: $xmm0 = VPMADDUBSWrr                $xmm0, $xmm1
1357   $xmm0 = VPMADDUBSWZ128rr                     $xmm0, $xmm1                                        
1358   ; CHECK: $xmm0 = VPMADDWDrm                  $xmm0, $rip, 1, $rax, 0, $noreg
1359   $xmm0 = VPMADDWDZ128rm                       $xmm0, $rip, 1, $rax, 0, $noreg
1360   ; CHECK: $xmm0 = VPMADDWDrr                  $xmm0, $xmm1                            
1361   $xmm0 = VPMADDWDZ128rr                       $xmm0, $xmm1                                                 
1362   ; CHECK: $xmm0 = VPACKSSDWrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1363   $xmm0 = VPACKSSDWZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1364   ; CHECK: $xmm0 = VPACKSSDWrr                 $xmm0, $xmm1
1365   $xmm0 = VPACKSSDWZ128rr                      $xmm0, $xmm1                                        
1366   ; CHECK: $xmm0 = VPACKSSWBrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1367   $xmm0 = VPACKSSWBZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1368   ; CHECK: $xmm0 = VPACKSSWBrr                 $xmm0, $xmm1
1369   $xmm0 = VPACKSSWBZ128rr                      $xmm0, $xmm1                                        
1370   ; CHECK: $xmm0 = VPACKUSDWrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1371   $xmm0 = VPACKUSDWZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1372   ; CHECK: $xmm0 = VPACKUSDWrr                 $xmm0, $xmm1
1373   $xmm0 = VPACKUSDWZ128rr                      $xmm0, $xmm1                                        
1374   ; CHECK: $xmm0 = VPACKUSWBrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1375   $xmm0 = VPACKUSWBZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1376   ; CHECK: $xmm0 = VPACKUSWBrr                 $xmm0, $xmm1
1377   $xmm0 = VPACKUSWBZ128rr                      $xmm0, $xmm1                                        
1378   ; CHECK: $xmm0 = VPUNPCKHBWrm                $xmm0, $rip, 1, $rax, 0, $noreg
1379   $xmm0 = VPUNPCKHBWZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1380   ; CHECK: $xmm0 = VPUNPCKHBWrr                $xmm0, $xmm1
1381   $xmm0 = VPUNPCKHBWZ128rr                     $xmm0, $xmm1                                        
1382   ; CHECK: $xmm0 = VPUNPCKHDQrm                $xmm0, $rip, 1, $rax, 0, $noreg
1383   $xmm0 = VPUNPCKHDQZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1384   ; CHECK: $xmm0 = VPUNPCKHDQrr                $xmm0, $xmm1
1385   $xmm0 = VPUNPCKHDQZ128rr                     $xmm0, $xmm1                                        
1386   ; CHECK: $xmm0 = VPUNPCKHQDQrm               $xmm0, $rip, 1, $rax, 0, $noreg
1387   $xmm0 = VPUNPCKHQDQZ128rm                    $xmm0, $rip, 1, $rax, 0, $noreg
1388   ; CHECK: $xmm0 = VPUNPCKHQDQrr               $xmm0, $xmm1
1389   $xmm0 = VPUNPCKHQDQZ128rr                    $xmm0, $xmm1                                        
1390   ; CHECK: $xmm0 = VPUNPCKHWDrm                $xmm0, $rip, 1, $rax, 0, $noreg
1391   $xmm0 = VPUNPCKHWDZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1392   ; CHECK: $xmm0 = VPUNPCKHWDrr                $xmm0, $xmm1
1393   $xmm0 = VPUNPCKHWDZ128rr                     $xmm0, $xmm1                                        
1394   ; CHECK: $xmm0 = VPUNPCKLBWrm                $xmm0, $rip, 1, $rax, 0, $noreg
1395   $xmm0 = VPUNPCKLBWZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1396   ; CHECK: $xmm0 = VPUNPCKLBWrr                $xmm0, $xmm1
1397   $xmm0 = VPUNPCKLBWZ128rr                     $xmm0, $xmm1                                        
1398   ; CHECK: $xmm0 = VPUNPCKLDQrm                $xmm0, $rip, 1, $rax, 0, $noreg
1399   $xmm0 = VPUNPCKLDQZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1400   ; CHECK: $xmm0 = VPUNPCKLDQrr                $xmm0, $xmm1
1401   $xmm0 = VPUNPCKLDQZ128rr                     $xmm0, $xmm1                                        
1402   ; CHECK: $xmm0 = VPUNPCKLQDQrm               $xmm0, $rip, 1, $rax, 0, $noreg
1403   $xmm0 = VPUNPCKLQDQZ128rm                    $xmm0, $rip, 1, $rax, 0, $noreg
1404   ; CHECK: $xmm0 = VPUNPCKLQDQrr               $xmm0, $xmm1
1405   $xmm0 = VPUNPCKLQDQZ128rr                    $xmm0, $xmm1                                        
1406   ; CHECK: $xmm0 = VPUNPCKLWDrm                $xmm0, $rip, 1, $rax, 0, $noreg
1407   $xmm0 = VPUNPCKLWDZ128rm                     $xmm0, $rip, 1, $rax, 0, $noreg
1408   ; CHECK: $xmm0 = VPUNPCKLWDrr                $xmm0, $xmm1
1409   $xmm0 = VPUNPCKLWDZ128rr                     $xmm0, $xmm1                                        
1410   ; CHECK: $xmm0 = VUNPCKHPDrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1411   $xmm0 = VUNPCKHPDZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1412   ; CHECK: $xmm0 = VUNPCKHPDrr                 $xmm0, $xmm1
1413   $xmm0 = VUNPCKHPDZ128rr                      $xmm0, $xmm1                                        
1414   ; CHECK: $xmm0 = VUNPCKHPSrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1415   $xmm0 = VUNPCKHPSZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1416   ; CHECK: $xmm0 = VUNPCKHPSrr                 $xmm0, $xmm1
1417   $xmm0 = VUNPCKHPSZ128rr                      $xmm0, $xmm1                                        
1418   ; CHECK: $xmm0 = VUNPCKLPDrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1419   $xmm0 = VUNPCKLPDZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1420   ; CHECK: $xmm0 = VUNPCKLPDrr                 $xmm0, $xmm1
1421   $xmm0 = VUNPCKLPDZ128rr                      $xmm0, $xmm1                                        
1422   ; CHECK: $xmm0 = VUNPCKLPSrm                 $xmm0, $rip, 1, $rax, 0, $noreg
1423   $xmm0 = VUNPCKLPSZ128rm                      $xmm0, $rip, 1, $rax, 0, $noreg
1424   ; CHECK: $xmm0 = VUNPCKLPSrr                 $xmm0, $xmm1                            
1425   $xmm0 = VUNPCKLPSZ128rr                      $xmm0, $xmm1                                                                                              
1426   ; CHECK: $xmm0 = VFMADD132PDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1427   $xmm0 = VFMADD132PDZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1428   ; CHECK: $xmm0 = VFMADD132PDr                $xmm0, $xmm1, $xmm2
1429   $xmm0 = VFMADD132PDZ128r                     $xmm0, $xmm1, $xmm2                                 
1430   ; CHECK: $xmm0 = VFMADD132PSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1431   $xmm0 = VFMADD132PSZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1432   ; CHECK: $xmm0 = VFMADD132PSr                $xmm0, $xmm1, $xmm2
1433   $xmm0 = VFMADD132PSZ128r                     $xmm0, $xmm1, $xmm2                                 
1434   ; CHECK: $xmm0 = VFMADD213PDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1435   $xmm0 = VFMADD213PDZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1436   ; CHECK: $xmm0 = VFMADD213PDr                $xmm0, $xmm1, $xmm2
1437   $xmm0 = VFMADD213PDZ128r                     $xmm0, $xmm1, $xmm2                                 
1438   ; CHECK: $xmm0 = VFMADD213PSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1439   $xmm0 = VFMADD213PSZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1440   ; CHECK: $xmm0 = VFMADD213PSr                $xmm0, $xmm1, $xmm2
1441   $xmm0 = VFMADD213PSZ128r                     $xmm0, $xmm1, $xmm2                                 
1442   ; CHECK: $xmm0 = VFMADD231PDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1443   $xmm0 = VFMADD231PDZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1444   ; CHECK: $xmm0 = VFMADD231PDr                $xmm0, $xmm1, $xmm2
1445   $xmm0 = VFMADD231PDZ128r                     $xmm0, $xmm1, $xmm2                                 
1446   ; CHECK: $xmm0 = VFMADD231PSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1447   $xmm0 = VFMADD231PSZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1448   ; CHECK: $xmm0 = VFMADD231PSr                $xmm0, $xmm1, $xmm2
1449   $xmm0 = VFMADD231PSZ128r                     $xmm0, $xmm1, $xmm2                                 
1450   ; CHECK: $xmm0 = VFMADDSUB132PDm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1451   $xmm0 = VFMADDSUB132PDZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1452   ; CHECK: $xmm0 = VFMADDSUB132PDr             $xmm0, $xmm1, $xmm2
1453   $xmm0 = VFMADDSUB132PDZ128r                  $xmm0, $xmm1, $xmm2                                 
1454   ; CHECK: $xmm0 = VFMADDSUB132PSm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1455   $xmm0 = VFMADDSUB132PSZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1456   ; CHECK: $xmm0 = VFMADDSUB132PSr             $xmm0, $xmm1, $xmm2
1457   $xmm0 = VFMADDSUB132PSZ128r                  $xmm0, $xmm1, $xmm2                                 
1458   ; CHECK: $xmm0 = VFMADDSUB213PDm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1459   $xmm0 = VFMADDSUB213PDZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1460   ; CHECK: $xmm0 = VFMADDSUB213PDr             $xmm0, $xmm1, $xmm2
1461   $xmm0 = VFMADDSUB213PDZ128r                  $xmm0, $xmm1, $xmm2                                 
1462   ; CHECK: $xmm0 = VFMADDSUB213PSm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1463   $xmm0 = VFMADDSUB213PSZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1464   ; CHECK: $xmm0 = VFMADDSUB213PSr             $xmm0, $xmm1, $xmm2
1465   $xmm0 = VFMADDSUB213PSZ128r                  $xmm0, $xmm1, $xmm2                                 
1466   ; CHECK: $xmm0 = VFMADDSUB231PDm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1467   $xmm0 = VFMADDSUB231PDZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1468   ; CHECK: $xmm0 = VFMADDSUB231PDr             $xmm0, $xmm1, $xmm2
1469   $xmm0 = VFMADDSUB231PDZ128r                  $xmm0, $xmm1, $xmm2                                 
1470   ; CHECK: $xmm0 = VFMADDSUB231PSm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1471   $xmm0 = VFMADDSUB231PSZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1472   ; CHECK: $xmm0 = VFMADDSUB231PSr             $xmm0, $xmm1, $xmm2
1473   $xmm0 = VFMADDSUB231PSZ128r                  $xmm0, $xmm1, $xmm2                                 
1474   ; CHECK: $xmm0 = VFMSUB132PDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1475   $xmm0 = VFMSUB132PDZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1476   ; CHECK: $xmm0 = VFMSUB132PDr                $xmm0, $xmm1, $xmm2
1477   $xmm0 = VFMSUB132PDZ128r                     $xmm0, $xmm1, $xmm2                                 
1478   ; CHECK: $xmm0 = VFMSUB132PSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1479   $xmm0 = VFMSUB132PSZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1480   ; CHECK: $xmm0 = VFMSUB132PSr                $xmm0, $xmm1, $xmm2
1481   $xmm0 = VFMSUB132PSZ128r                     $xmm0, $xmm1, $xmm2                                 
1482   ; CHECK: $xmm0 = VFMSUB213PDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1483   $xmm0 = VFMSUB213PDZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1484   ; CHECK: $xmm0 = VFMSUB213PDr                $xmm0, $xmm1, $xmm2
1485   $xmm0 = VFMSUB213PDZ128r                     $xmm0, $xmm1, $xmm2                                 
1486   ; CHECK: $xmm0 = VFMSUB213PSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1487   $xmm0 = VFMSUB213PSZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1488   ; CHECK: $xmm0 = VFMSUB213PSr                $xmm0, $xmm1, $xmm2
1489   $xmm0 = VFMSUB213PSZ128r                     $xmm0, $xmm1, $xmm2                                 
1490   ; CHECK: $xmm0 = VFMSUB231PDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1491   $xmm0 = VFMSUB231PDZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1492   ; CHECK: $xmm0 = VFMSUB231PDr                $xmm0, $xmm1, $xmm2
1493   $xmm0 = VFMSUB231PDZ128r                     $xmm0, $xmm1, $xmm2                                 
1494   ; CHECK: $xmm0 = VFMSUB231PSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1495   $xmm0 = VFMSUB231PSZ128m                     $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1496   ; CHECK: $xmm0 = VFMSUB231PSr                $xmm0, $xmm1, $xmm2
1497   $xmm0 = VFMSUB231PSZ128r                     $xmm0, $xmm1, $xmm2                                 
1498   ; CHECK: $xmm0 = VFMSUBADD132PDm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1499   $xmm0 = VFMSUBADD132PDZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1500   ; CHECK: $xmm0 = VFMSUBADD132PDr             $xmm0, $xmm1, $xmm2
1501   $xmm0 = VFMSUBADD132PDZ128r                  $xmm0, $xmm1, $xmm2                                 
1502   ; CHECK: $xmm0 = VFMSUBADD132PSm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1503   $xmm0 = VFMSUBADD132PSZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1504   ; CHECK: $xmm0 = VFMSUBADD132PSr             $xmm0, $xmm1, $xmm2
1505   $xmm0 = VFMSUBADD132PSZ128r                  $xmm0, $xmm1, $xmm2                                 
1506   ; CHECK: $xmm0 = VFMSUBADD213PDm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1507   $xmm0 = VFMSUBADD213PDZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1508   ; CHECK: $xmm0 = VFMSUBADD213PDr             $xmm0, $xmm1, $xmm2
1509   $xmm0 = VFMSUBADD213PDZ128r                  $xmm0, $xmm1, $xmm2                                 
1510   ; CHECK: $xmm0 = VFMSUBADD213PSm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1511   $xmm0 = VFMSUBADD213PSZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1512   ; CHECK: $xmm0 = VFMSUBADD213PSr             $xmm0, $xmm1, $xmm2
1513   $xmm0 = VFMSUBADD213PSZ128r                  $xmm0, $xmm1, $xmm2                                 
1514   ; CHECK: $xmm0 = VFMSUBADD231PDm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1515   $xmm0 = VFMSUBADD231PDZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1516   ; CHECK: $xmm0 = VFMSUBADD231PDr             $xmm0, $xmm1, $xmm2
1517   $xmm0 = VFMSUBADD231PDZ128r                  $xmm0, $xmm1, $xmm2                                 
1518   ; CHECK: $xmm0 = VFMSUBADD231PSm             $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1519   $xmm0 = VFMSUBADD231PSZ128m                  $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1520   ; CHECK: $xmm0 = VFMSUBADD231PSr             $xmm0, $xmm1, $xmm2
1521   $xmm0 = VFMSUBADD231PSZ128r                  $xmm0, $xmm1, $xmm2                                 
1522   ; CHECK: $xmm0 = VFNMADD132PDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1523   $xmm0 = VFNMADD132PDZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1524   ; CHECK: $xmm0 = VFNMADD132PDr               $xmm0, $xmm1, $xmm2
1525   $xmm0 = VFNMADD132PDZ128r                    $xmm0, $xmm1, $xmm2                                 
1526   ; CHECK: $xmm0 = VFNMADD132PSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1527   $xmm0 = VFNMADD132PSZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1528   ; CHECK: $xmm0 = VFNMADD132PSr               $xmm0, $xmm1, $xmm2
1529   $xmm0 = VFNMADD132PSZ128r                    $xmm0, $xmm1, $xmm2                                 
1530   ; CHECK: $xmm0 = VFNMADD213PDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1531   $xmm0 = VFNMADD213PDZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1532   ; CHECK: $xmm0 = VFNMADD213PDr               $xmm0, $xmm1, $xmm2
1533   $xmm0 = VFNMADD213PDZ128r                    $xmm0, $xmm1, $xmm2                                 
1534   ; CHECK: $xmm0 = VFNMADD213PSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1535   $xmm0 = VFNMADD213PSZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1536   ; CHECK: $xmm0 = VFNMADD213PSr               $xmm0, $xmm1, $xmm2
1537   $xmm0 = VFNMADD213PSZ128r                    $xmm0, $xmm1, $xmm2                                 
1538   ; CHECK: $xmm0 = VFNMADD231PDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1539   $xmm0 = VFNMADD231PDZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1540   ; CHECK: $xmm0 = VFNMADD231PDr               $xmm0, $xmm1, $xmm2
1541   $xmm0 = VFNMADD231PDZ128r                    $xmm0, $xmm1, $xmm2                                 
1542   ; CHECK: $xmm0 = VFNMADD231PSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1543   $xmm0 = VFNMADD231PSZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1544   ; CHECK: $xmm0 = VFNMADD231PSr               $xmm0, $xmm1, $xmm2
1545   $xmm0 = VFNMADD231PSZ128r                    $xmm0, $xmm1, $xmm2                                 
1546   ; CHECK: $xmm0 = VFNMSUB132PDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1547   $xmm0 = VFNMSUB132PDZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1548   ; CHECK: $xmm0 = VFNMSUB132PDr               $xmm0, $xmm1, $xmm2
1549   $xmm0 = VFNMSUB132PDZ128r                    $xmm0, $xmm1, $xmm2                                 
1550   ; CHECK: $xmm0 = VFNMSUB132PSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1551   $xmm0 = VFNMSUB132PSZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1552   ; CHECK: $xmm0 = VFNMSUB132PSr               $xmm0, $xmm1, $xmm2
1553   $xmm0 = VFNMSUB132PSZ128r                    $xmm0, $xmm1, $xmm2                                 
1554   ; CHECK: $xmm0 = VFNMSUB213PDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1555   $xmm0 = VFNMSUB213PDZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1556   ; CHECK: $xmm0 = VFNMSUB213PDr               $xmm0, $xmm1, $xmm2
1557   $xmm0 = VFNMSUB213PDZ128r                    $xmm0, $xmm1, $xmm2                                 
1558   ; CHECK: $xmm0 = VFNMSUB213PSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1559   $xmm0 = VFNMSUB213PSZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1560   ; CHECK: $xmm0 = VFNMSUB213PSr               $xmm0, $xmm1, $xmm2
1561   $xmm0 = VFNMSUB213PSZ128r                    $xmm0, $xmm1, $xmm2                                 
1562   ; CHECK: $xmm0 = VFNMSUB231PDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1563   $xmm0 = VFNMSUB231PDZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1564   ; CHECK: $xmm0 = VFNMSUB231PDr               $xmm0, $xmm1, $xmm2
1565   $xmm0 = VFNMSUB231PDZ128r                    $xmm0, $xmm1, $xmm2                                 
1566   ; CHECK: $xmm0 = VFNMSUB231PSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1567   $xmm0 = VFNMSUB231PSZ128m                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                      
1568   ; CHECK: $xmm0 = VFNMSUB231PSr               $xmm0, $xmm1, $xmm2                     
1569   $xmm0 = VFNMSUB231PSZ128r                    $xmm0, $xmm1, $xmm2                                               
1570   ; CHECK: $xmm0 = VPSLLDri                    $xmm0, 7
1571   $xmm0 = VPSLLDZ128ri                         $xmm0, 7                                            
1572   ; CHECK: $xmm0 = VPSLLDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1573   $xmm0 = VPSLLDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1574   ; CHECK: $xmm0 = VPSLLDrr                    $xmm0, $xmm0
1575   $xmm0 = VPSLLDZ128rr                         $xmm0, $xmm0
1576   ; CHECK: $xmm0 = VPSLLQri                    $xmm0, 7
1577   $xmm0 = VPSLLQZ128ri                         $xmm0, 7                                            
1578   ; CHECK: $xmm0 = VPSLLQrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1579   $xmm0 = VPSLLQZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1580   ; CHECK: $xmm0 = VPSLLQrr                    $xmm0, $xmm0
1581   $xmm0 = VPSLLQZ128rr                         $xmm0, $xmm0
1582   ; CHECK: $xmm0 = VPSLLVDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1583   $xmm0 = VPSLLVDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1584   ; CHECK: $xmm0 = VPSLLVDrr                   $xmm0, $xmm0
1585   $xmm0 = VPSLLVDZ128rr                        $xmm0, $xmm0
1586   ; CHECK: $xmm0 = VPSLLVQrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1587   $xmm0 = VPSLLVQZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1588   ; CHECK: $xmm0 = VPSLLVQrr                   $xmm0, $xmm0
1589   $xmm0 = VPSLLVQZ128rr                        $xmm0, $xmm0
1590   ; CHECK: $xmm0 = VPSLLWri                    $xmm0, 7
1591   $xmm0 = VPSLLWZ128ri                         $xmm0, 7                                            
1592   ; CHECK: $xmm0 = VPSLLWrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1593   $xmm0 = VPSLLWZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1594   ; CHECK: $xmm0 = VPSLLWrr                    $xmm0, $xmm0
1595   $xmm0 = VPSLLWZ128rr                         $xmm0, $xmm0
1596   ; CHECK: $xmm0 = VPSRADri                    $xmm0, 7
1597   $xmm0 = VPSRADZ128ri                         $xmm0, 7                                            
1598   ; CHECK: $xmm0 = VPSRADrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1599   $xmm0 = VPSRADZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1600   ; CHECK: $xmm0 = VPSRADrr                    $xmm0, $xmm0
1601   $xmm0 = VPSRADZ128rr                         $xmm0, $xmm0
1602   ; CHECK: $xmm0 = VPSRAVDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1603   $xmm0 = VPSRAVDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1604   ; CHECK: $xmm0 = VPSRAVDrr                   $xmm0, $xmm0
1605   $xmm0 = VPSRAVDZ128rr                        $xmm0, $xmm0
1606   ; CHECK: $xmm0 = VPSRAWri                    $xmm0, 7 
1607   $xmm0 = VPSRAWZ128ri                         $xmm0, 7                                            
1608   ; CHECK: $xmm0 = VPSRAWrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1609   $xmm0 = VPSRAWZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1610   ; CHECK: $xmm0 = VPSRAWrr                    $xmm0, $xmm0
1611   $xmm0 = VPSRAWZ128rr                         $xmm0, $xmm0
1612   ; CHECK: $xmm0 = VPSRLDQri                   $xmm0, 14
1613   $xmm0 = VPSRLDQZ128rr                        $xmm0, 14                                           
1614   ; CHECK: $xmm0 = VPSRLDri                    $xmm0, 7 
1615   $xmm0 = VPSRLDZ128ri                         $xmm0, 7                                            
1616   ; CHECK: $xmm0 = VPSRLDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1617   $xmm0 = VPSRLDZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1618   ; CHECK: $xmm0 = VPSRLDrr                    $xmm0, $xmm0
1619   $xmm0 = VPSRLDZ128rr                         $xmm0, $xmm0
1620   ; CHECK: $xmm0 = VPSRLQri                    $xmm0, 7 
1621   $xmm0 = VPSRLQZ128ri                         $xmm0, 7                                            
1622   ; CHECK: $xmm0 = VPSRLQrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1623   $xmm0 = VPSRLQZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1624   ; CHECK: $xmm0 = VPSRLQrr                    $xmm0, $xmm0
1625   $xmm0 = VPSRLQZ128rr                         $xmm0, $xmm0
1626   ; CHECK: $xmm0 = VPSRLVDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1627   $xmm0 = VPSRLVDZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1628   ; CHECK: $xmm0 = VPSRLVDrr                   $xmm0, $xmm0
1629   $xmm0 = VPSRLVDZ128rr                        $xmm0, $xmm0
1630   ; CHECK: $xmm0 = VPSRLVQrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1631   $xmm0 = VPSRLVQZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1632   ; CHECK: $xmm0 = VPSRLVQrr                   $xmm0, $xmm0
1633   $xmm0 = VPSRLVQZ128rr                        $xmm0, $xmm0
1634   ; CHECK: $xmm0 = VPSRLWri                    $xmm0, 7
1635   $xmm0 = VPSRLWZ128ri                         $xmm0, 7                                            
1636   ; CHECK: $xmm0 = VPSRLWrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1637   $xmm0 = VPSRLWZ128rm                         $xmm0, $rip, 1, $rax, 0, $noreg
1638   ; CHECK: $xmm0 = VPSRLWrr                    $xmm0, $xmm0
1639   $xmm0 = VPSRLWZ128rr                         $xmm0, $xmm0
1640   ; CHECK: $xmm0 = VPERMILPDmi                 $rdi, 1, $noreg, 0, $noreg, 9
1641   $xmm0 = VPERMILPDZ128mi                      $rdi, 1, $noreg, 0, $noreg, 9
1642   ; CHECK: $xmm0 = VPERMILPDri                 $xmm0, 9
1643   $xmm0 = VPERMILPDZ128ri                      $xmm0, 9                                            
1644   ; CHECK: $xmm0 = VPERMILPDrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg
1645   $xmm0 = VPERMILPDZ128rm                      $xmm0, $rdi, 1, $noreg, 0, $noreg                             
1646   ; CHECK: $xmm0 = VPERMILPDrr                 $xmm0, $xmm1
1647   $xmm0 = VPERMILPDZ128rr                      $xmm0, $xmm1                                        
1648   ; CHECK: $xmm0 = VPERMILPSmi                 $rdi, 1, $noreg, 0, $noreg, 9
1649   $xmm0 = VPERMILPSZ128mi                      $rdi, 1, $noreg, 0, $noreg, 9
1650   ; CHECK: $xmm0 = VPERMILPSri                 $xmm0, 9
1651   $xmm0 = VPERMILPSZ128ri                      $xmm0, 9                                            
1652   ; CHECK: $xmm0 = VPERMILPSrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg
1653   $xmm0 = VPERMILPSZ128rm                      $xmm0, $rdi, 1, $noreg, 0, $noreg                             
1654   ; CHECK: $xmm0 = VPERMILPSrr                 $xmm0, $xmm1                            
1655   $xmm0 = VPERMILPSZ128rr                      $xmm0, $xmm1                                               
1656   ; CHECK: $xmm0 = VCVTPH2PSrm                 $rdi, 1, $noreg, 0, $noreg
1657   $xmm0 = VCVTPH2PSZ128rm                      $rdi, 1, $noreg, 0, $noreg
1658   ; CHECK: $xmm0 = VCVTPH2PSrr                 $xmm0
1659   $xmm0 = VCVTPH2PSZ128rr                      $xmm0                                               
1660   ; CHECK: $xmm0 = VCVTDQ2PDrm                 $rdi, 1, $noreg, 0, $noreg
1661   $xmm0 = VCVTDQ2PDZ128rm                      $rdi, 1, $noreg, 0, $noreg
1662   ; CHECK: $xmm0 = VCVTDQ2PDrr                 $xmm0     
1663   $xmm0 = VCVTDQ2PDZ128rr                      $xmm0                                               
1664   ; CHECK: $xmm0 = VCVTDQ2PSrm                 $rdi, 1, $noreg, 0, $noreg
1665   $xmm0 = VCVTDQ2PSZ128rm                      $rdi, 1, $noreg, 0, $noreg
1666   ; CHECK: $xmm0 = VCVTDQ2PSrr                 $xmm0   
1667   $xmm0 = VCVTDQ2PSZ128rr                      $xmm0                                               
1668   ; CHECK: $xmm0 = VCVTPD2DQrm                 $rdi, 1, $noreg, 0, $noreg
1669   $xmm0 = VCVTPD2DQZ128rm                      $rdi, 1, $noreg, 0, $noreg
1670   ; CHECK: $xmm0 = VCVTPD2DQrr                 $xmm0   
1671   $xmm0 = VCVTPD2DQZ128rr                      $xmm0                                               
1672   ; CHECK: $xmm0 = VCVTPD2PSrm                 $rdi, 1, $noreg, 0, $noreg
1673   $xmm0 = VCVTPD2PSZ128rm                      $rdi, 1, $noreg, 0, $noreg
1674   ; CHECK: $xmm0 = VCVTPD2PSrr                 $xmm0   
1675   $xmm0 = VCVTPD2PSZ128rr                      $xmm0                                               
1676   ; CHECK: $xmm0 = VCVTPS2DQrm                 $rdi, 1, $noreg, 0, $noreg
1677   $xmm0 = VCVTPS2DQZ128rm                      $rdi, 1, $noreg, 0, $noreg
1678   ; CHECK: $xmm0 = VCVTPS2DQrr                 $xmm0   
1679   $xmm0 = VCVTPS2DQZ128rr                      $xmm0                                               
1680   ; CHECK: $xmm0 = VCVTPS2PDrm                 $rdi, 1, $noreg, 0, $noreg
1681   $xmm0 = VCVTPS2PDZ128rm                      $rdi, 1, $noreg, 0, $noreg
1682   ; CHECK: $xmm0 = VCVTPS2PDrr                 $xmm0
1683   $xmm0 = VCVTPS2PDZ128rr                      $xmm0                                               
1684   ; CHECK: $xmm0 = VCVTTPD2DQrm                $rdi, 1, $noreg, 0, $noreg
1685   $xmm0 = VCVTTPD2DQZ128rm                     $rdi, 1, $noreg, 0, $noreg
1686   ; CHECK: $xmm0 = VCVTTPD2DQrr                $xmm0  
1687   $xmm0 = VCVTTPD2DQZ128rr                     $xmm0                                               
1688   ; CHECK: $xmm0 = VCVTTPS2DQrm                $rdi, 1, $noreg, 0, $noreg
1689   $xmm0 = VCVTTPS2DQZ128rm                     $rdi, 1, $noreg, 0, $noreg
1690   ; CHECK: $xmm0 = VCVTTPS2DQrr                $xmm0                                   
1691   $xmm0 = VCVTTPS2DQZ128rr                     $xmm0                                               
1692   ; CHECK: $xmm0 = VSQRTPDm                    $rdi, 1, $noreg, 0, $noreg
1693   $xmm0 = VSQRTPDZ128m                         $rdi, 1, $noreg, 0, $noreg
1694   ; CHECK: $xmm0 = VSQRTPDr                    $xmm0
1695   $xmm0 = VSQRTPDZ128r                         $xmm0                                               
1696   ; CHECK: $xmm0 = VSQRTPSm                    $rdi, 1, $noreg, 0, $noreg
1697   $xmm0 = VSQRTPSZ128m                         $rdi, 1, $noreg, 0, $noreg
1698   ; CHECK: $xmm0 = VSQRTPSr                    $xmm0                                   
1699   $xmm0 = VSQRTPSZ128r                         $xmm0                                               
1700   ; CHECK: $xmm0 = VMOVDDUPrm                  $rdi, 1, $noreg, 0, $noreg     
1701   $xmm0 = VMOVDDUPZ128rm                       $rdi, 1, $noreg, 0, $noreg                                    
1702   ; CHECK: $xmm0 = VMOVDDUPrr                  $xmm0    
1703   $xmm0 = VMOVDDUPZ128rr                       $xmm0                                               
1704   ; CHECK: $xmm0 = VMOVSHDUPrm                 $rdi, 1, $noreg, 0, $noreg    
1705   $xmm0 = VMOVSHDUPZ128rm                      $rdi, 1, $noreg, 0, $noreg                                    
1706   ; CHECK: $xmm0 = VMOVSHDUPrr                 $xmm0    
1707   $xmm0 = VMOVSHDUPZ128rr                      $xmm0                                               
1708   ; CHECK: $xmm0 = VMOVSLDUPrm                 $rdi, 1, $noreg, 0, $noreg     
1709   $xmm0 = VMOVSLDUPZ128rm                      $rdi, 1, $noreg, 0, $noreg                                    
1710   ; CHECK: $xmm0 = VMOVSLDUPrr                 $xmm0                                   
1711   $xmm0 = VMOVSLDUPZ128rr                      $xmm0                                                                  
1712   ; CHECK: $xmm0 = VPSHUFBrm                   $xmm0, $rdi, 1, $noreg, 0, $noreg
1713   $xmm0 = VPSHUFBZ128rm                        $xmm0, $rdi, 1, $noreg, 0, $noreg
1714   ; CHECK: $xmm0 = VPSHUFBrr                   $xmm0, $xmm1
1715   $xmm0 = VPSHUFBZ128rr                        $xmm0, $xmm1                                        
1716   ; CHECK: $xmm0 = VPSHUFDmi                   $rdi, 1, $noreg, 0, $noreg, -24
1717   $xmm0 = VPSHUFDZ128mi                        $rdi, 1, $noreg, 0, $noreg, -24
1718   ; CHECK: $xmm0 = VPSHUFDri                   $xmm0, -24
1719   $xmm0 = VPSHUFDZ128ri                        $xmm0, -24                                          
1720   ; CHECK: $xmm0 = VPSHUFHWmi                  $rdi, 1, $noreg, 0, $noreg, -24
1721   $xmm0 = VPSHUFHWZ128mi                       $rdi, 1, $noreg, 0, $noreg, -24
1722   ; CHECK: $xmm0 = VPSHUFHWri                  $xmm0, -24
1723   $xmm0 = VPSHUFHWZ128ri                       $xmm0, -24                                          
1724   ; CHECK: $xmm0 = VPSHUFLWmi                  $rdi, 1, $noreg, 0, $noreg, -24
1725   $xmm0 = VPSHUFLWZ128mi                       $rdi, 1, $noreg, 0, $noreg, -24
1726   ; CHECK: $xmm0 = VPSHUFLWri                  $xmm0, -24
1727   $xmm0 = VPSHUFLWZ128ri                       $xmm0, -24                                          
1728   ; CHECK: $xmm0 = VPSLLDQri                   $xmm0, 7
1729   $xmm0 = VPSLLDQZ128rr                        $xmm0, 7
1730   ; CHECK: $xmm0 = VSHUFPDrmi                  $xmm0, $rip, 1, $rax, 0, $noreg, -24
1731   $xmm0 = VSHUFPDZ128rmi                       $xmm0, $rip, 1, $rax, 0, $noreg, -24
1732   ; CHECK: $xmm0 = VSHUFPDrri                  $xmm0, $xmm1, -24
1733   $xmm0 = VSHUFPDZ128rri                       $xmm0, $xmm1, -24
1734   ; CHECK: $xmm0 = VSHUFPSrmi                  $xmm0, $rip, 1, $rax, 0, $noreg, -24
1735   $xmm0 = VSHUFPSZ128rmi                       $xmm0, $rip, 1, $rax, 0, $noreg, -24
1736   ; CHECK: $xmm0 = VSHUFPSrri                  $xmm0, $xmm1, -24
1737   $xmm0 = VSHUFPSZ128rri                       $xmm0, $xmm1, -24
1738   ; CHECK: $xmm0 = VPSADBWrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1739   $xmm0 = VPSADBWZ128rm                        $xmm0, $rip, 1, $rax, 0, $noreg
1740   ; CHECK: $xmm0 = VPSADBWrr                   $xmm0, $xmm1                            
1741   $xmm0 = VPSADBWZ128rr                        $xmm0, $xmm1                                               
1742   ; CHECK: $xmm0 = VBROADCASTSSrm              $rip, 1, $rax, 0, $noreg
1743   $xmm0 = VBROADCASTSSZ128m                    $rip, 1, $rax, 0, $noreg
1744   ; CHECK: $xmm0 = VBROADCASTSSrr              $xmm0
1745   $xmm0 = VBROADCASTSSZ128r                    $xmm0                                               
1746   ; CHECK: $xmm0 = VPBROADCASTBrm              $rip, 1, $rax, 0, $noreg
1747   $xmm0 = VPBROADCASTBZ128m                    $rip, 1, $rax, 0, $noreg
1748   ; CHECK: $xmm0 = VPBROADCASTBrr              $xmm0
1749   $xmm0 = VPBROADCASTBZ128r                    $xmm0                                               
1750   ; CHECK: $xmm0 = VPBROADCASTDrm              $rip, 1, $rax, 0, $noreg
1751   $xmm0 = VPBROADCASTDZ128m                    $rip, 1, $rax, 0, $noreg
1752   ; CHECK: $xmm0 = VPBROADCASTDrr              $xmm0
1753   $xmm0 = VPBROADCASTDZ128r                    $xmm0                                               
1754   ; CHECK: $xmm0 = VPBROADCASTQrm              $rip, 1, $rax, 0, $noreg
1755   $xmm0 = VPBROADCASTQZ128m                    $rip, 1, $rax, 0, $noreg
1756   ; CHECK: $xmm0 = VPBROADCASTQrr              $xmm0
1757   $xmm0 = VPBROADCASTQZ128r                    $xmm0                                               
1758   ; CHECK: $xmm0 = VPBROADCASTWrm              $rip, 1, $rax, 0, $noreg
1759   $xmm0 = VPBROADCASTWZ128m                    $rip, 1, $rax, 0, $noreg
1760   ; CHECK: $xmm0 = VPBROADCASTWrr              $xmm0                                   
1761   $xmm0 = VPBROADCASTWZ128r                    $xmm0                                                                                             
1762   ; CHECK: $xmm0 = VPBROADCASTQrm              $rip, 1, $rax, 0, $noreg
1763   $xmm0 = VBROADCASTI32X2Z128m                 $rip, 1, $rax, 0, $noreg
1764   ; CHECK: $xmm0 = VPBROADCASTQrr              $xmm0
1765   $xmm0 = VBROADCASTI32X2Z128r                 $xmm0
1766   ; CHECK: $xmm0 = VCVTPS2PHrr                 $xmm0, 2
1767   $xmm0 = VCVTPS2PHZ128rr                      $xmm0, 2                                            
1768   ; CHECK: VCVTPS2PHmr                         $rdi, 1, $noreg, 0, $noreg, $xmm0, 2
1769   VCVTPS2PHZ128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm0, 2
1770   ; CHECK: $xmm0 = VPABSBrm                    $rip, 1, $rax, 0, $noreg
1771   $xmm0 = VPABSBZ128rm                         $rip, 1, $rax, 0, $noreg
1772   ; CHECK: $xmm0 = VPABSBrr                    $xmm0
1773   $xmm0 = VPABSBZ128rr                         $xmm0                                               
1774   ; CHECK: $xmm0 = VPABSDrm                    $rip, 1, $rax, 0, $noreg
1775   $xmm0 = VPABSDZ128rm                         $rip, 1, $rax, 0, $noreg
1776   ; CHECK: $xmm0 = VPABSDrr                    $xmm0
1777   $xmm0 = VPABSDZ128rr                         $xmm0                                               
1778   ; CHECK: $xmm0 = VPABSWrm                    $rip, 1, $rax, 0, $noreg
1779   $xmm0 = VPABSWZ128rm                         $rip, 1, $rax, 0, $noreg
1780   ; CHECK: $xmm0 = VPABSWrr                    $xmm0
1781   $xmm0 = VPABSWZ128rr                         $xmm0                                               
1782   ; CHECK: $xmm0 = VPALIGNRrmi                 $xmm0, $rip, 1, $rax, 0, $noreg, 15
1783   $xmm0 = VPALIGNRZ128rmi                      $xmm0, $rip, 1, $rax, 0, $noreg, 15
1784   ; CHECK: $xmm0 = VPALIGNRrri                 $xmm0, $xmm1, 15
1785   $xmm0 = VPALIGNRZ128rri                      $xmm0, $xmm1, 15
1786   ; CHECK: $xmm0 = VPALIGNRrmi                 $xmm0, $rip, 1, $rax, 0, $noreg, 4
1787   $xmm0 = VALIGNDZ128rmi                       $xmm0, $rip, 1, $rax, 0, $noreg, 1
1788   ; CHECK: $xmm0 = VPALIGNRrri                 $xmm0, $xmm1, 4
1789   $xmm0 = VALIGNDZ128rri                       $xmm0, $xmm1, 1
1790   ; CHECK: $xmm0 = VPALIGNRrmi                 $xmm0, $rip, 1, $rax, 0, $noreg, 8
1791   $xmm0 = VALIGNQZ128rmi                       $xmm0, $rip, 1, $rax, 0, $noreg, 1
1792   ; CHECK: $xmm0 = VPALIGNRrri                 $xmm0, $xmm1, 8
1793   $xmm0 = VALIGNQZ128rri                       $xmm0, $xmm1, 1
1794   ; CHECK: $xmm0 = VROUNDPDm                   $rip, 1, $rax, 0, $noreg, 15
1795   $xmm0 = VRNDSCALEPDZ128rmi                   $rip, 1, $rax, 0, $noreg, 15
1796   ; CHECK: $xmm0 = VROUNDPDr                   $xmm0, 15
1797   $xmm0 = VRNDSCALEPDZ128rri                   $xmm0, 15
1798   ; CHECK: $xmm0 = VROUNDPSm                   $rip, 1, $rax, 0, $noreg, 15
1799   $xmm0 = VRNDSCALEPSZ128rmi                   $rip, 1, $rax, 0, $noreg, 15
1800   ; CHECK: $xmm0 = VROUNDPSr                   $xmm0, 15
1801   $xmm0 = VRNDSCALEPSZ128rri                   $xmm0, 15
1803       RET 0, $zmm0, $zmm1
1806   # CHECK-LABEL: name: evex_scalar_to_vex_test
1807   # CHECK: bb.0:
1809 name: evex_scalar_to_vex_test
1810 body: |
1811   bb.0:
1813   ; CHECK: $xmm0 = VADDSDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1814   $xmm0 = VADDSDZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1815   ; CHECK: $xmm0 = VADDSDrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1816   $xmm0 = VADDSDZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1817   ; CHECK: $xmm0 = VADDSDrr                    $xmm0, $xmm1  
1818   $xmm0 = VADDSDZrr                            $xmm0, $xmm1                                            
1819   ; CHECK: $xmm0 = VADDSDrr_Int                $xmm0, $xmm1
1820   $xmm0 = VADDSDZrr_Int                        $xmm0, $xmm1                                            
1821   ; CHECK: $xmm0 = VADDSSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1822   $xmm0 = VADDSSZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1823   ; CHECK: $xmm0 = VADDSSrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1824   $xmm0 = VADDSSZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1825   ; CHECK: $xmm0 = VADDSSrr                    $xmm0, $xmm1
1826   $xmm0 = VADDSSZrr                            $xmm0, $xmm1                                            
1827   ; CHECK: $xmm0 = VADDSSrr_Int                $xmm0, $xmm1
1828   $xmm0 = VADDSSZrr_Int                        $xmm0, $xmm1                                            
1829   ; CHECK: $xmm0 = VDIVSDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1830   $xmm0 = VDIVSDZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1831   ; CHECK: $xmm0 = VDIVSDrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1832   $xmm0 = VDIVSDZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1833   ; CHECK: $xmm0 = VDIVSDrr                    $xmm0, $xmm1  
1834   $xmm0 = VDIVSDZrr                            $xmm0, $xmm1                                            
1835   ; CHECK: $xmm0 = VDIVSDrr_Int                $xmm0, $xmm1
1836   $xmm0 = VDIVSDZrr_Int                        $xmm0, $xmm1                                            
1837   ; CHECK: $xmm0 = VDIVSSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1838   $xmm0 = VDIVSSZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1839   ; CHECK: $xmm0 = VDIVSSrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1840   $xmm0 = VDIVSSZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1841   ; CHECK: $xmm0 = VDIVSSrr                    $xmm0, $xmm1
1842   $xmm0 = VDIVSSZrr                            $xmm0, $xmm1                                            
1843   ; CHECK: $xmm0 = VDIVSSrr_Int                $xmm0, $xmm1
1844   $xmm0 = VDIVSSZrr_Int                        $xmm0, $xmm1                                            
1845   ; CHECK: $xmm0 = VMAXCSDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1846   $xmm0 = VMAXCSDZrm                           $xmm0, $rip, 1, $rax, 0, $noreg
1847   ; CHECK: $xmm0 = VMAXCSDrr                   $xmm0, $xmm1
1848   $xmm0 = VMAXCSDZrr                           $xmm0, $xmm1                                            
1849   ; CHECK: $xmm0 = VMAXCSSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1850   $xmm0 = VMAXCSSZrm                           $xmm0, $rip, 1, $rax, 0, $noreg
1851   ; CHECK: $xmm0 = VMAXCSSrr                   $xmm0, $xmm1
1852   $xmm0 = VMAXCSSZrr                           $xmm0, $xmm1                                            
1853   ; CHECK: $xmm0 = VMAXCSDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1854   $xmm0 = VMAXSDZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1855   ; CHECK: $xmm0 = VMAXSDrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1856   $xmm0 = VMAXSDZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1857   ; CHECK: $xmm0 = VMAXCSDrr                   $xmm0, $xmm1
1858   $xmm0 = VMAXSDZrr                            $xmm0, $xmm1                                            
1859   ; CHECK: $xmm0 = VMAXSDrr_Int                $xmm0, $xmm1
1860   $xmm0 = VMAXSDZrr_Int                        $xmm0, $xmm1                                            
1861   ; CHECK: $xmm0 = VMAXCSSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1862   $xmm0 = VMAXSSZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1863   ; CHECK: $xmm0 = VMAXSSrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1864   $xmm0 = VMAXSSZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1865   ; CHECK: $xmm0 = VMAXCSSrr                   $xmm0, $xmm1
1866   $xmm0 = VMAXSSZrr                            $xmm0, $xmm1                                            
1867   ; CHECK: $xmm0 = VMAXSSrr_Int                $xmm0, $xmm1
1868   $xmm0 = VMAXSSZrr_Int                        $xmm0, $xmm1                                            
1869   ; CHECK: $xmm0 = VMINCSDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1870   $xmm0 = VMINCSDZrm                           $xmm0, $rip, 1, $rax, 0, $noreg
1871   ; CHECK: $xmm0 = VMINCSDrr                   $xmm0, $xmm1
1872   $xmm0 = VMINCSDZrr                           $xmm0, $xmm1                                            
1873   ; CHECK: $xmm0 = VMINCSSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1874   $xmm0 = VMINCSSZrm                           $xmm0, $rip, 1, $rax, 0, $noreg
1875   ; CHECK: $xmm0 = VMINCSSrr                   $xmm0, $xmm1
1876   $xmm0 = VMINCSSZrr                           $xmm0, $xmm1                                            
1877   ; CHECK: $xmm0 = VMINCSDrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1878   $xmm0 = VMINSDZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1879   ; CHECK: $xmm0 = VMINSDrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1880   $xmm0 = VMINSDZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1881   ; CHECK: $xmm0 = VMINCSDrr                   $xmm0, $xmm1
1882   $xmm0 = VMINSDZrr                            $xmm0, $xmm1                                            
1883   ; CHECK: $xmm0 = VMINSDrr_Int                $xmm0, $xmm1
1884   $xmm0 = VMINSDZrr_Int                        $xmm0, $xmm1                                            
1885   ; CHECK: $xmm0 = VMINCSSrm                   $xmm0, $rip, 1, $rax, 0, $noreg
1886   $xmm0 = VMINSSZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1887   ; CHECK: $xmm0 = VMINSSrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1888   $xmm0 = VMINSSZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1889   ; CHECK: $xmm0 = VMINCSSrr                   $xmm0, $xmm1
1890   $xmm0 = VMINSSZrr                            $xmm0, $xmm1                                            
1891   ; CHECK: $xmm0 = VMINSSrr_Int                $xmm0, $xmm1
1892   $xmm0 = VMINSSZrr_Int                        $xmm0, $xmm1                                            
1893   ; CHECK: $xmm0 = VMULSDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1894   $xmm0 = VMULSDZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1895   ; CHECK: $xmm0 = VMULSDrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1896   $xmm0 = VMULSDZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1897   ; CHECK: $xmm0 = VMULSDrr                    $xmm0, $xmm1
1898   $xmm0 = VMULSDZrr                            $xmm0, $xmm1                                            
1899   ; CHECK: $xmm0 = VMULSDrr_Int                $xmm0, $xmm1
1900   $xmm0 = VMULSDZrr_Int                        $xmm0, $xmm1                                            
1901   ; CHECK: $xmm0 = VMULSSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1902   $xmm0 = VMULSSZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1903   ; CHECK: $xmm0 = VMULSSrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1904   $xmm0 = VMULSSZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1905   ; CHECK: $xmm0 = VMULSSrr                    $xmm0, $xmm1  
1906   $xmm0 = VMULSSZrr                            $xmm0, $xmm1                                            
1907   ; CHECK: $xmm0 = VMULSSrr_Int                $xmm0, $xmm1
1908   $xmm0 = VMULSSZrr_Int                        $xmm0, $xmm1                                            
1909   ; CHECK: $xmm0 = VSUBSDrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1910   $xmm0 = VSUBSDZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1911   ; CHECK: $xmm0 = VSUBSDrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1912   $xmm0 = VSUBSDZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1913   ; CHECK: $xmm0 = VSUBSDrr                    $xmm0, $xmm1  
1914   $xmm0 = VSUBSDZrr                            $xmm0, $xmm1                                            
1915   ; CHECK: $xmm0 = VSUBSDrr_Int                $xmm0, $xmm1
1916   $xmm0 = VSUBSDZrr_Int                        $xmm0, $xmm1                                            
1917   ; CHECK: $xmm0 = VSUBSSrm                    $xmm0, $rip, 1, $rax, 0, $noreg
1918   $xmm0 = VSUBSSZrm                            $xmm0, $rip, 1, $rax, 0, $noreg
1919   ; CHECK: $xmm0 = VSUBSSrm_Int                $xmm0, $rip, 1, $rax, 0, $noreg
1920   $xmm0 = VSUBSSZrm_Int                        $xmm0, $rip, 1, $rax, 0, $noreg
1921   ; CHECK: $xmm0 = VSUBSSrr                    $xmm0, $xmm1
1922   $xmm0 = VSUBSSZrr                            $xmm0, $xmm1                                            
1923   ; CHECK: $xmm0 = VSUBSSrr_Int                $xmm0, $xmm1                                               
1924   $xmm0 = VSUBSSZrr_Int                        $xmm0, $xmm1                                               
1925   ; CHECK: $xmm0 = VFMADD132SDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1926   $xmm0 = VFMADD132SDZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1927   ; CHECK: $xmm0 = VFMADD132SDm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1928   $xmm0 = VFMADD132SDZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1929   ; CHECK: $xmm0 = VFMADD132SDr                $xmm0, $xmm1, $xmm2
1930   $xmm0 = VFMADD132SDZr                        $xmm0, $xmm1, $xmm2                                     
1931   ; CHECK: $xmm0 = VFMADD132SDr_Int            $xmm0, $xmm1, $xmm2
1932   $xmm0 = VFMADD132SDZr_Int                    $xmm0, $xmm1, $xmm2                                     
1933   ; CHECK: $xmm0 = VFMADD132SSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1934   $xmm0 = VFMADD132SSZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1935   ; CHECK: $xmm0 = VFMADD132SSm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1936   $xmm0 = VFMADD132SSZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1937   ; CHECK: $xmm0 = VFMADD132SSr                $xmm0, $xmm1, $xmm2
1938   $xmm0 = VFMADD132SSZr                        $xmm0, $xmm1, $xmm2                                     
1939   ; CHECK: $xmm0 = VFMADD132SSr_Int            $xmm0, $xmm1, $xmm2
1940   $xmm0 = VFMADD132SSZr_Int                    $xmm0, $xmm1, $xmm2                                     
1941   ; CHECK: $xmm0 = VFMADD213SDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1942   $xmm0 = VFMADD213SDZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1943   ; CHECK: $xmm0 = VFMADD213SDm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1944   $xmm0 = VFMADD213SDZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1945   ; CHECK: $xmm0 = VFMADD213SDr                $xmm0, $xmm1, $xmm2
1946   $xmm0 = VFMADD213SDZr                        $xmm0, $xmm1, $xmm2                                     
1947   ; CHECK: $xmm0 = VFMADD213SDr_Int            $xmm0, $xmm1, $xmm2
1948   $xmm0 = VFMADD213SDZr_Int                    $xmm0, $xmm1, $xmm2                                     
1949   ; CHECK: $xmm0 = VFMADD213SSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1950   $xmm0 = VFMADD213SSZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1951   ; CHECK: $xmm0 = VFMADD213SSm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1952   $xmm0 = VFMADD213SSZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1953   ; CHECK: $xmm0 = VFMADD213SSr                $xmm0, $xmm1, $xmm2
1954   $xmm0 = VFMADD213SSZr                        $xmm0, $xmm1, $xmm2                                     
1955   ; CHECK: $xmm0 = VFMADD213SSr_Int            $xmm0, $xmm1, $xmm2
1956   $xmm0 = VFMADD213SSZr_Int                    $xmm0, $xmm1, $xmm2                                     
1957   ; CHECK: $xmm0 = VFMADD231SDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1958   $xmm0 = VFMADD231SDZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1959   ; CHECK: $xmm0 = VFMADD231SDm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1960   $xmm0 = VFMADD231SDZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1961   ; CHECK: $xmm0 = VFMADD231SDr                $xmm0, $xmm1, $xmm2
1962   $xmm0 = VFMADD231SDZr                        $xmm0, $xmm1, $xmm2                                     
1963   ; CHECK: $xmm0 = VFMADD231SDr_Int            $xmm0, $xmm1, $xmm2
1964   $xmm0 = VFMADD231SDZr_Int                    $xmm0, $xmm1, $xmm2                                     
1965   ; CHECK: $xmm0 = VFMADD231SSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1966   $xmm0 = VFMADD231SSZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1967   ; CHECK: $xmm0 = VFMADD231SSm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1968   $xmm0 = VFMADD231SSZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1969   ; CHECK: $xmm0 = VFMADD231SSr                $xmm0, $xmm1, $xmm2
1970   $xmm0 = VFMADD231SSZr                        $xmm0, $xmm1, $xmm2                                     
1971   ; CHECK: $xmm0 = VFMADD231SSr_Int            $xmm0, $xmm1, $xmm2
1972   $xmm0 = VFMADD231SSZr_Int                    $xmm0, $xmm1, $xmm2                                     
1973   ; CHECK: $xmm0 = VFMSUB132SDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1974   $xmm0 = VFMSUB132SDZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1975   ; CHECK: $xmm0 = VFMSUB132SDm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1976   $xmm0 = VFMSUB132SDZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1977   ; CHECK: $xmm0 = VFMSUB132SDr                $xmm0, $xmm1, $xmm2
1978   $xmm0 = VFMSUB132SDZr                        $xmm0, $xmm1, $xmm2                                     
1979   ; CHECK: $xmm0 = VFMSUB132SDr_Int            $xmm0, $xmm1, $xmm2
1980   $xmm0 = VFMSUB132SDZr_Int                    $xmm0, $xmm1, $xmm2                                     
1981   ; CHECK: $xmm0 = VFMSUB132SSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1982   $xmm0 = VFMSUB132SSZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1983   ; CHECK: $xmm0 = VFMSUB132SSm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1984   $xmm0 = VFMSUB132SSZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1985   ; CHECK: $xmm0 = VFMSUB132SSr                $xmm0, $xmm1, $xmm2
1986   $xmm0 = VFMSUB132SSZr                        $xmm0, $xmm1, $xmm2                                     
1987   ; CHECK: $xmm0 = VFMSUB132SSr_Int            $xmm0, $xmm1, $xmm2
1988   $xmm0 = VFMSUB132SSZr_Int                    $xmm0, $xmm1, $xmm2                                     
1989   ; CHECK: $xmm0 = VFMSUB213SDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1990   $xmm0 = VFMSUB213SDZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1991   ; CHECK: $xmm0 = VFMSUB213SDm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1992   $xmm0 = VFMSUB213SDZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1993   ; CHECK: $xmm0 = VFMSUB213SDr                $xmm0, $xmm1, $xmm2
1994   $xmm0 = VFMSUB213SDZr                        $xmm0, $xmm1, $xmm2                                     
1995   ; CHECK: $xmm0 = VFMSUB213SDr_Int            $xmm0, $xmm1, $xmm2
1996   $xmm0 = VFMSUB213SDZr_Int                    $xmm0, $xmm1, $xmm2                                     
1997   ; CHECK: $xmm0 = VFMSUB213SSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
1998   $xmm0 = VFMSUB213SSZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
1999   ; CHECK: $xmm0 = VFMSUB213SSm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2000   $xmm0 = VFMSUB213SSZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2001   ; CHECK: $xmm0 = VFMSUB213SSr                $xmm0, $xmm1, $xmm2
2002   $xmm0 = VFMSUB213SSZr                        $xmm0, $xmm1, $xmm2                                     
2003   ; CHECK: $xmm0 = VFMSUB213SSr_Int            $xmm0, $xmm1, $xmm2
2004   $xmm0 = VFMSUB213SSZr_Int                    $xmm0, $xmm1, $xmm2                                     
2005   ; CHECK: $xmm0 = VFMSUB231SDm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2006   $xmm0 = VFMSUB231SDZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2007   ; CHECK: $xmm0 = VFMSUB231SDm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2008   $xmm0 = VFMSUB231SDZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2009   ; CHECK: $xmm0 = VFMSUB231SDr                $xmm0, $xmm1, $xmm2
2010   $xmm0 = VFMSUB231SDZr                        $xmm0, $xmm1, $xmm2                                     
2011   ; CHECK: $xmm0 = VFMSUB231SDr_Int            $xmm0, $xmm1, $xmm2
2012   $xmm0 = VFMSUB231SDZr_Int                    $xmm0, $xmm1, $xmm2                                     
2013   ; CHECK: $xmm0 = VFMSUB231SSm                $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2014   $xmm0 = VFMSUB231SSZm                        $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2015   ; CHECK: $xmm0 = VFMSUB231SSm_Int            $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2016   $xmm0 = VFMSUB231SSZm_Int                    $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2017   ; CHECK: $xmm0 = VFMSUB231SSr                $xmm0, $xmm1, $xmm2
2018   $xmm0 = VFMSUB231SSZr                        $xmm0, $xmm1, $xmm2                                     
2019   ; CHECK: $xmm0 = VFMSUB231SSr_Int            $xmm0, $xmm1, $xmm2
2020   $xmm0 = VFMSUB231SSZr_Int                    $xmm0, $xmm1, $xmm2                                     
2021   ; CHECK: $xmm0 = VFNMADD132SDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2022   $xmm0 = VFNMADD132SDZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2023   ; CHECK: $xmm0 = VFNMADD132SDm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2024   $xmm0 = VFNMADD132SDZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2025   ; CHECK: $xmm0 = VFNMADD132SDr               $xmm0, $xmm1, $xmm2
2026   $xmm0 = VFNMADD132SDZr                       $xmm0, $xmm1, $xmm2                                     
2027   ; CHECK: $xmm0 = VFNMADD132SDr_Int           $xmm0, $xmm1, $xmm2
2028   $xmm0 = VFNMADD132SDZr_Int                   $xmm0, $xmm1, $xmm2                                     
2029   ; CHECK: $xmm0 = VFNMADD132SSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2030   $xmm0 = VFNMADD132SSZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2031   ; CHECK: $xmm0 = VFNMADD132SSm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2032   $xmm0 = VFNMADD132SSZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2033   ; CHECK: $xmm0 = VFNMADD132SSr               $xmm0, $xmm1, $xmm2
2034   $xmm0 = VFNMADD132SSZr                       $xmm0, $xmm1, $xmm2                                     
2035   ; CHECK: $xmm0 = VFNMADD132SSr_Int           $xmm0, $xmm1, $xmm2
2036   $xmm0 = VFNMADD132SSZr_Int                   $xmm0, $xmm1, $xmm2                                     
2037   ; CHECK: $xmm0 = VFNMADD213SDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2038   $xmm0 = VFNMADD213SDZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2039   ; CHECK: $xmm0 = VFNMADD213SDm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2040   $xmm0 = VFNMADD213SDZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2041   ; CHECK: $xmm0 = VFNMADD213SDr               $xmm0, $xmm1, $xmm2
2042   $xmm0 = VFNMADD213SDZr                       $xmm0, $xmm1, $xmm2                                     
2043   ; CHECK: $xmm0 = VFNMADD213SDr_Int           $xmm0, $xmm1, $xmm2
2044   $xmm0 = VFNMADD213SDZr_Int                   $xmm0, $xmm1, $xmm2                                     
2045   ; CHECK: $xmm0 = VFNMADD213SSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2046   $xmm0 = VFNMADD213SSZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2047   ; CHECK: $xmm0 = VFNMADD213SSm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2048   $xmm0 = VFNMADD213SSZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2049   ; CHECK: $xmm0 = VFNMADD213SSr               $xmm0, $xmm1, $xmm2
2050   $xmm0 = VFNMADD213SSZr                       $xmm0, $xmm1, $xmm2                                     
2051   ; CHECK: $xmm0 = VFNMADD213SSr_Int           $xmm0, $xmm1, $xmm2
2052   $xmm0 = VFNMADD213SSZr_Int                   $xmm0, $xmm1, $xmm2                                     
2053   ; CHECK: $xmm0 = VFNMADD231SDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2054   $xmm0 = VFNMADD231SDZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2055   ; CHECK: $xmm0 = VFNMADD231SDm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2056   $xmm0 = VFNMADD231SDZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2057   ; CHECK: $xmm0 = VFNMADD231SDr               $xmm0, $xmm1, $xmm2
2058   $xmm0 = VFNMADD231SDZr                       $xmm0, $xmm1, $xmm2                                     
2059   ; CHECK: $xmm0 = VFNMADD231SDr_Int           $xmm0, $xmm1, $xmm2
2060   $xmm0 = VFNMADD231SDZr_Int                   $xmm0, $xmm1, $xmm2                                     
2061   ; CHECK: $xmm0 = VFNMADD231SSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2062   $xmm0 = VFNMADD231SSZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2063   ; CHECK: $xmm0 = VFNMADD231SSm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2064   $xmm0 = VFNMADD231SSZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2065   ; CHECK: $xmm0 = VFNMADD231SSr               $xmm0, $xmm1, $xmm2
2066   $xmm0 = VFNMADD231SSZr                       $xmm0, $xmm1, $xmm2                                     
2067   ; CHECK: $xmm0 = VFNMADD231SSr_Int           $xmm0, $xmm1, $xmm2
2068   $xmm0 = VFNMADD231SSZr_Int                   $xmm0, $xmm1, $xmm2                                     
2069   ; CHECK: $xmm0 = VFNMSUB132SDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2070   $xmm0 = VFNMSUB132SDZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2071   ; CHECK: $xmm0 = VFNMSUB132SDm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2072   $xmm0 = VFNMSUB132SDZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2073   ; CHECK: $xmm0 = VFNMSUB132SDr               $xmm0, $xmm1, $xmm2
2074   $xmm0 = VFNMSUB132SDZr                       $xmm0, $xmm1, $xmm2                                     
2075   ; CHECK: $xmm0 = VFNMSUB132SDr_Int           $xmm0, $xmm1, $xmm2
2076   $xmm0 = VFNMSUB132SDZr_Int                   $xmm0, $xmm1, $xmm2                                     
2077   ; CHECK: $xmm0 = VFNMSUB132SSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2078   $xmm0 = VFNMSUB132SSZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2079   ; CHECK: $xmm0 = VFNMSUB132SSm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2080   $xmm0 = VFNMSUB132SSZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2081   ; CHECK: $xmm0 = VFNMSUB132SSr               $xmm0, $xmm1, $xmm2
2082   $xmm0 = VFNMSUB132SSZr                       $xmm0, $xmm1, $xmm2                                     
2083   ; CHECK: $xmm0 = VFNMSUB132SSr_Int           $xmm0, $xmm1, $xmm2
2084   $xmm0 = VFNMSUB132SSZr_Int                   $xmm0, $xmm1, $xmm2                                     
2085   ; CHECK: $xmm0 = VFNMSUB213SDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2086   $xmm0 = VFNMSUB213SDZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2087   ; CHECK: $xmm0 = VFNMSUB213SDm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2088   $xmm0 = VFNMSUB213SDZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2089   ; CHECK: $xmm0 = VFNMSUB213SDr               $xmm0, $xmm1, $xmm2
2090   $xmm0 = VFNMSUB213SDZr                       $xmm0, $xmm1, $xmm2                                     
2091   ; CHECK: $xmm0 = VFNMSUB213SDr_Int           $xmm0, $xmm1, $xmm2
2092   $xmm0 = VFNMSUB213SDZr_Int                   $xmm0, $xmm1, $xmm2                                     
2093   ; CHECK: $xmm0 = VFNMSUB213SSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2094   $xmm0 = VFNMSUB213SSZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2095   ; CHECK: $xmm0 = VFNMSUB213SSm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2096   $xmm0 = VFNMSUB213SSZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2097   ; CHECK: $xmm0 = VFNMSUB213SSr               $xmm0, $xmm1, $xmm2
2098   $xmm0 = VFNMSUB213SSZr                       $xmm0, $xmm1, $xmm2                                     
2099   ; CHECK: $xmm0 = VFNMSUB213SSr_Int           $xmm0, $xmm1, $xmm2
2100   $xmm0 = VFNMSUB213SSZr_Int                   $xmm0, $xmm1, $xmm2                                     
2101   ; CHECK: $xmm0 = VFNMSUB231SDm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2102   $xmm0 = VFNMSUB231SDZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2103   ; CHECK: $xmm0 = VFNMSUB231SDm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2104   $xmm0 = VFNMSUB231SDZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2105   ; CHECK: $xmm0 = VFNMSUB231SDr               $xmm0, $xmm1, $xmm2
2106   $xmm0 = VFNMSUB231SDZr                       $xmm0, $xmm1, $xmm2                                     
2107   ; CHECK: $xmm0 = VFNMSUB231SDr_Int           $xmm0, $xmm1, $xmm2
2108   $xmm0 = VFNMSUB231SDZr_Int                   $xmm0, $xmm1, $xmm2                                     
2109   ; CHECK: $xmm0 = VFNMSUB231SSm               $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2110   $xmm0 = VFNMSUB231SSZm                       $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2111   ; CHECK: $xmm0 = VFNMSUB231SSm_Int           $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg
2112   $xmm0 = VFNMSUB231SSZm_Int                   $xmm0, $xmm0, $rsi, 1, $noreg, 0, $noreg                          
2113   ; CHECK: $xmm0 = VFNMSUB231SSr               $xmm0, $xmm1, $xmm2
2114   $xmm0 = VFNMSUB231SSZr                       $xmm0, $xmm1, $xmm2                                     
2115   ; CHECK: $xmm0 = VFNMSUB231SSr_Int           $xmm0, $xmm1, $xmm2                                               
2116   $xmm0 = VFNMSUB231SSZr_Int                   $xmm0, $xmm1, $xmm2                                               
2117   ; CHECK: VPEXTRBmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0, 3       
2118   VPEXTRBZmr                                   $rdi, 1, $noreg, 0, $noreg, $xmm0, 3                              
2119   ; CHECK: $eax = VPEXTRBrr                    $xmm0, 1    
2120   $eax = VPEXTRBZrr                            $xmm0, 1                                                
2121   ; CHECK: VPEXTRDmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0, 3      
2122   VPEXTRDZmr                                   $rdi, 1, $noreg, 0, $noreg, $xmm0, 3                              
2123   ; CHECK: $eax = VPEXTRDrr                    $xmm0, 1     
2124   $eax = VPEXTRDZrr                            $xmm0, 1                                                
2125   ; CHECK: VPEXTRQmr                           $rdi, 1, $noreg, 0, $noreg, $xmm0, 3       
2126   VPEXTRQZmr                                   $rdi, 1, $noreg, 0, $noreg, $xmm0, 3                              
2127   ; CHECK: $rax = VPEXTRQrr                    $xmm0, 1      
2128   $rax = VPEXTRQZrr                            $xmm0, 1                                                
2129   ; CHECK: VPEXTRWmr                           $rdi, 1, $noreg, 0, $noreg,  $xmm0, 3       
2130   VPEXTRWZmr                                   $rdi, 1, $noreg, 0, $noreg,  $xmm0, 3                             
2131   ; CHECK: $eax = VPEXTRWrr                    $xmm0, 1                                                     
2132   $eax = VPEXTRWZrr                            $xmm0, 1                                                    
2133   ; CHECK: $eax = VPEXTRWrr_REV               $xmm0, 1      
2134   $eax = VPEXTRWZrr_REV                        $xmm0, 1                                                     
2135   ; CHECK: $xmm0 = VPINSRBrm                   $xmm0, $rsi, 1, $noreg, 0, $noreg, 3      
2136   $xmm0 = VPINSRBZrm                           $xmm0, $rsi, 1, $noreg, 0, $noreg, 3                              
2137   ; CHECK: $xmm0 = VPINSRBrr                   $xmm0, $edi, 5      
2138   $xmm0 = VPINSRBZrr                           $xmm0, $edi, 5                                          
2139   ; CHECK: $xmm0 = VPINSRDrm                   $xmm0, $rsi, 1, $noreg, 0, $noreg, 3      
2140   $xmm0 = VPINSRDZrm                           $xmm0, $rsi, 1, $noreg, 0, $noreg, 3                              
2141   ; CHECK: $xmm0 = VPINSRDrr                   $xmm0, $edi, 5            
2142   $xmm0 = VPINSRDZrr                           $xmm0, $edi, 5                                          
2143   ; CHECK: $xmm0 = VPINSRQrm                   $xmm0, $rsi, 1, $noreg, 0, $noreg, 3      
2144   $xmm0 = VPINSRQZrm                           $xmm0, $rsi, 1, $noreg, 0, $noreg, 3                              
2145   ; CHECK: $xmm0 = VPINSRQrr                   $xmm0, $rdi, 5            
2146   $xmm0 = VPINSRQZrr                           $xmm0, $rdi, 5                                          
2147   ; CHECK: $xmm0 = VPINSRWrm                   $xmm0, $rsi, 1, $noreg, 0, $noreg, 3      
2148   $xmm0 = VPINSRWZrm                           $xmm0, $rsi, 1, $noreg, 0, $noreg, 3                              
2149   ; CHECK: $xmm0 = VPINSRWrr                   $xmm0, $edi, 5                                               
2150   $xmm0 = VPINSRWZrr                           $xmm0, $edi, 5                                              
2151   ; CHECK: $xmm0 = VSQRTSDm                    $xmm0, $rdi, 1, $noreg, 0, $noreg
2152   $xmm0 = VSQRTSDZm                            $xmm0, $rdi, 1, $noreg, 0, $noreg
2153   ; CHECK: $xmm0 = VSQRTSDm_Int                $xmm0, $rdi, 1, $noreg, 0, $noreg
2154   $xmm0 = VSQRTSDZm_Int                        $xmm0, $rdi, 1, $noreg, 0, $noreg
2155   ; CHECK: $xmm0 = VSQRTSDr                    $xmm0, $noreg 
2156   $xmm0 = VSQRTSDZr                            $xmm0, $noreg                                                
2157   ; CHECK: $xmm0 = VSQRTSDr_Int                $xmm0, $noreg
2158   $xmm0 = VSQRTSDZr_Int                        $xmm0, $noreg                                                
2159   ; CHECK: $xmm0 = VSQRTSSm                    $xmm0, $rdi, 1, $noreg, 0, $noreg
2160   $xmm0 = VSQRTSSZm                            $xmm0, $rdi, 1, $noreg, 0, $noreg
2161   ; CHECK: $xmm0 = VSQRTSSm_Int                $xmm0, $rdi, 1, $noreg, 0, $noreg
2162   $xmm0 = VSQRTSSZm_Int                        $xmm0, $rdi, 1, $noreg, 0, $noreg
2163   ; CHECK: $xmm0 = VSQRTSSr                    $xmm0, $xmm1
2164   $xmm0 = VSQRTSSZr                            $xmm0, $xmm1
2165   ; CHECK: $xmm0 = VSQRTSSr_Int                $xmm0, $xmm1
2166   $xmm0 = VSQRTSSZr_Int                        $xmm0, $xmm1
2167   ; CHECK: $rdi = VCVTSD2SI64rr_Int            $xmm0
2168   $rdi = VCVTSD2SI64Zrr_Int                    $xmm0                                                   
2169   ; CHECK: $edi = VCVTSD2SIrr_Int              $xmm0
2170   $edi = VCVTSD2SIZrr_Int                      $xmm0                                                   
2171   ; CHECK: $xmm0 = VCVTSD2SSrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg
2172   $xmm0 = VCVTSD2SSZrm                         $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2173   ; CHECK: $xmm0 = VCVTSD2SSrm_Int             $xmm0, $rdi, 1, $noreg, 0, $noreg
2174   $xmm0 = VCVTSD2SSZrm_Int                     $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2175   ; CHECK: $xmm0 = VCVTSD2SSrr                 $xmm0, $xmm1
2176   $xmm0 = VCVTSD2SSZrr                         $xmm0, $xmm1
2177   ; CHECK: $xmm0 = VCVTSD2SSrr_Int             $xmm0, $xmm1
2178   $xmm0 = VCVTSD2SSZrr_Int                     $xmm0, $xmm1
2179   ; CHECK: $xmm0 = VCVTSI2SDrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg
2180   $xmm0 = VCVTSI2SDZrm                         $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2181   ; CHECK: $xmm0 = VCVTSI2SDrm_Int             $xmm0, $rdi, 1, $noreg, 0, $noreg
2182   $xmm0 = VCVTSI2SDZrm_Int                     $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2183   ; CHECK: $xmm0 = VCVTSI2SDrr                 $xmm0, $edi
2184   $xmm0 = VCVTSI2SDZrr                         $xmm0, $edi
2185   ; CHECK: $xmm0 = VCVTSI2SDrr_Int             $xmm0, $edi
2186   $xmm0 = VCVTSI2SDZrr_Int                     $xmm0, $edi
2187   ; CHECK: $xmm0 = VCVTSI2SSrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg
2188   $xmm0 = VCVTSI2SSZrm                         $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2189   ; CHECK: $xmm0 = VCVTSI2SSrm_Int             $xmm0, $rdi, 1, $noreg, 0, $noreg
2190   $xmm0 = VCVTSI2SSZrm_Int                     $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2191   ; CHECK: $xmm0 = VCVTSI2SSrr                 $xmm0, $edi
2192   $xmm0 = VCVTSI2SSZrr                         $xmm0, $edi
2193   ; CHECK: $xmm0 = VCVTSI2SSrr_Int             $xmm0, $edi
2194   $xmm0 = VCVTSI2SSZrr_Int                     $xmm0, $edi
2195   ; CHECK: $xmm0 = VCVTSI642SDrm               $xmm0, $rdi, 1, $noreg, 0, $noreg
2196   $xmm0 = VCVTSI642SDZrm                       $xmm0, $rdi, 1, $noreg, 0, $noreg
2197   ; CHECK: $xmm0 = VCVTSI642SDrm_Int           $xmm0, $rdi, 1, $noreg, 0, $noreg
2198   $xmm0 = VCVTSI642SDZrm_Int                   $xmm0, $rdi, 1, $noreg, 0, $noreg
2199   ; CHECK: $xmm0 = VCVTSI642SDrr               $xmm0, $rdi
2200   $xmm0 = VCVTSI642SDZrr                       $xmm0, $rdi
2201   ; CHECK: $xmm0 = VCVTSI642SDrr_Int           $xmm0, $rdi
2202   $xmm0 = VCVTSI642SDZrr_Int                   $xmm0, $rdi
2203   ; CHECK: $xmm0 = VCVTSI642SSrm               $xmm0, $rdi, 1, $noreg, 0, $noreg 
2204   $xmm0 = VCVTSI642SSZrm                       $xmm0, $rdi, 1, $noreg, 0, $noreg
2205   ; CHECK: $xmm0 = VCVTSI642SSrm_Int           $xmm0, $rdi, 1, $noreg, 0, $noreg
2206   $xmm0 = VCVTSI642SSZrm_Int                   $xmm0, $rdi, 1, $noreg, 0, $noreg
2207   ; CHECK: $xmm0 = VCVTSI642SSrr               $xmm0, $rdi
2208   $xmm0 = VCVTSI642SSZrr                       $xmm0, $rdi
2209   ; CHECK: $xmm0 = VCVTSI642SSrr_Int           $xmm0, $rdi
2210   $xmm0 = VCVTSI642SSZrr_Int                   $xmm0, $rdi
2211   ; CHECK: $xmm0 = VCVTSS2SDrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg
2212   $xmm0 = VCVTSS2SDZrm                         $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2213   ; CHECK: $xmm0 = VCVTSS2SDrm_Int             $xmm0, $rdi, 1, $noreg, 0, $noreg
2214   $xmm0 = VCVTSS2SDZrm_Int                     $xmm0, $rdi, 1, $noreg, 0, $noreg                                 
2215   ; CHECK: $xmm0 = VCVTSS2SDrr                 $xmm0, $xmm1
2216   $xmm0 = VCVTSS2SDZrr                         $xmm0, $xmm1
2217   ; CHECK: $xmm0 = VCVTSS2SDrr_Int             $xmm0, $xmm1
2218   $xmm0 = VCVTSS2SDZrr_Int                     $xmm0, $xmm1
2219   ; CHECK: $rdi = VCVTSS2SI64rm_Int            $rdi, 1, $noreg, 0, $noreg
2220   $rdi = VCVTSS2SI64Zrm_Int                    $rdi, 1, $noreg, 0, $noreg
2221   ; CHECK: $rdi = VCVTSS2SI64rr_Int            $xmm0
2222   $rdi = VCVTSS2SI64Zrr_Int                    $xmm0                                                   
2223   ; CHECK: $edi = VCVTSS2SIrm_Int              $rdi, 1, $noreg, 0, $noreg
2224   $edi = VCVTSS2SIZrm_Int                      $rdi, 1, $noreg, 0, $noreg
2225   ; CHECK: $edi = VCVTSS2SIrr_Int              $xmm0
2226   $edi = VCVTSS2SIZrr_Int                      $xmm0                                                   
2227   ; CHECK: $rdi = VCVTTSD2SI64rm               $rdi, 1, $noreg, 0, $noreg
2228   $rdi = VCVTTSD2SI64Zrm                       $rdi, 1, $noreg, 0, $noreg
2229   ; CHECK: $rdi = VCVTTSD2SI64rm_Int           $rdi, 1, $noreg, 0, $noreg
2230   $rdi = VCVTTSD2SI64Zrm_Int                   $rdi, 1, $noreg, 0, $noreg
2231   ; CHECK: $rdi = VCVTTSD2SI64rr               $xmm0
2232   $rdi = VCVTTSD2SI64Zrr                       $xmm0                                                   
2233   ; CHECK: $rdi = VCVTTSD2SI64rr_Int           $xmm0
2234   $rdi = VCVTTSD2SI64Zrr_Int                   $xmm0                                                   
2235   ; CHECK: $edi = VCVTTSD2SIrm                 $rdi, 1, $noreg, 0, $noreg
2236   $edi = VCVTTSD2SIZrm                         $rdi, 1, $noreg, 0, $noreg
2237   ; CHECK: $edi = VCVTTSD2SIrm_Int             $rdi, 1, $noreg, 0, $noreg
2238   $edi = VCVTTSD2SIZrm_Int                     $rdi, 1, $noreg, 0, $noreg
2239   ; CHECK: $edi = VCVTTSD2SIrr                 $xmm0
2240   $edi = VCVTTSD2SIZrr                         $xmm0                                                   
2241   ; CHECK: $edi = VCVTTSD2SIrr_Int             $xmm0
2242   $edi = VCVTTSD2SIZrr_Int                     $xmm0                                                   
2243   ; CHECK: $rdi = VCVTTSS2SI64rm               $rdi, 1, $noreg, 0, $noreg
2244   $rdi = VCVTTSS2SI64Zrm                       $rdi, 1, $noreg, 0, $noreg
2245   ; CHECK: $rdi = VCVTTSS2SI64rm_Int           $rdi, 1, $noreg, 0, $noreg
2246   $rdi = VCVTTSS2SI64Zrm_Int                   $rdi, 1, $noreg, 0, $noreg
2247   ; CHECK: $rdi = VCVTTSS2SI64rr               $xmm0
2248   $rdi = VCVTTSS2SI64Zrr                       $xmm0                                                   
2249   ; CHECK: $rdi = VCVTTSS2SI64rr_Int           $xmm0
2250   $rdi = VCVTTSS2SI64Zrr_Int                   $xmm0                                                   
2251   ; CHECK: $edi = VCVTTSS2SIrm                 $rdi, 1, $noreg, 0, $noreg
2252   $edi = VCVTTSS2SIZrm                         $rdi, 1, $noreg, 0, $noreg
2253   ; CHECK: $edi = VCVTTSS2SIrm_Int             $rdi, 1, $noreg, 0, $noreg
2254   $edi = VCVTTSS2SIZrm_Int                     $rdi, 1, $noreg, 0, $noreg
2255   ; CHECK: $edi = VCVTTSS2SIrr                 $xmm0
2256   $edi = VCVTTSS2SIZrr                         $xmm0                                                   
2257   ; CHECK: $edi = VCVTTSS2SIrr_Int             $xmm0                                               
2258   $edi = VCVTTSS2SIZrr_Int                     $xmm0                                                   
2259   ; CHECK: $xmm0 = VMOV64toSDrr                $rdi    
2260   $xmm0 = VMOV64toSDZrr                        $rdi                                                    
2261   ; CHECK: $xmm0 = VMOVDI2SSrr                 $eax
2262   $xmm0 = VMOVDI2SSZrr                         $eax                                                    
2263   ; CHECK: VMOVSDmr                            $rdi, 1, $noreg, 0, $noreg, $xmm0
2264   VMOVSDZmr                                    $rdi, 1, $noreg, 0, $noreg, $xmm0
2265   ; CHECK: $xmm0 = VMOVSDrm                    $rip, 1, $noreg, 0, $noreg
2266   $xmm0 = VMOVSDZrm                            $rip, 1, $noreg, 0, $noreg
2267   ; CHECK: $xmm0 = VMOVSDrm_alt                $rip, 1, $noreg, 0, $noreg
2268   $xmm0 = VMOVSDZrm_alt                        $rip, 1, $noreg, 0, $noreg
2269   ; CHECK: $xmm0 = VMOVSDrr                    $xmm0, $xmm1
2270   $xmm0 = VMOVSDZrr                            $xmm0, $xmm1
2271   ; CHECK: $xmm0 = VMOVSDrr_REV                $xmm0, $xmm1
2272   $xmm0 = VMOVSDZrr_REV                        $xmm0, $xmm1
2273   ; CHECK: $rax = VMOVSDto64rr                 $xmm0
2274   $rax = VMOVSDto64Zrr                         $xmm0
2275   ; CHECK: VMOVSSmr                            $rdi, 1, $noreg, 0, $noreg, $xmm0
2276   VMOVSSZmr                                    $rdi, 1, $noreg, 0, $noreg, $xmm0
2277   ; CHECK: $xmm0 = VMOVSSrm                    $rip, 1, $noreg, 0, $noreg
2278   $xmm0 = VMOVSSZrm                            $rip, 1, $noreg, 0, $noreg
2279   ; CHECK: $xmm0 = VMOVSSrm_alt                $rip, 1, $noreg, 0, $noreg
2280   $xmm0 = VMOVSSZrm_alt                        $rip, 1, $noreg, 0, $noreg
2281   ; CHECK: $xmm0 = VMOVSSrr                    $xmm0, $xmm1
2282   $xmm0 = VMOVSSZrr                            $xmm0, $xmm1
2283   ; CHECK: $xmm0 = VMOVSSrr_REV                $xmm0, $xmm1
2284   $xmm0 = VMOVSSZrr_REV                        $xmm0, $xmm1
2285   ; CHECK: $eax = VMOVSS2DIrr                  $xmm0
2286   $eax = VMOVSS2DIZrr                          $xmm0
2287   ; CHECK: $xmm0 = VMOV64toPQIrr               $rdi
2288   $xmm0 = VMOV64toPQIZrr                       $rdi                                                    
2289   ; CHECK: $xmm0 = VMOV64toPQIrm               $rdi, 1, $noreg, 0, $noreg
2290   $xmm0 = VMOV64toPQIZrm                       $rdi, 1, $noreg, 0, $noreg
2291   ; CHECK: $xmm0 = VMOV64toSDrr                $rdi 
2292   $xmm0 = VMOV64toSDZrr                        $rdi                                                    
2293   ; CHECK: $xmm0 = VMOVDI2PDIrm                $rip, 1, $rax, 0, $noreg
2294   $xmm0 = VMOVDI2PDIZrm                        $rip, 1, $rax, 0, $noreg
2295   ; CHECK: $xmm0 = VMOVDI2PDIrr                $edi
2296   $xmm0 = VMOVDI2PDIZrr                        $edi                                                    
2297   ; CHECK: $xmm0 = VMOVLHPSrr                  $xmm0, $xmm1
2298   $xmm0 = VMOVLHPSZrr                          $xmm0, $xmm1
2299   ; CHECK: $xmm0 = VMOVHLPSrr                  $xmm0, $xmm1
2300   $xmm0 = VMOVHLPSZrr                          $xmm0, $xmm1
2301   ; CHECK: VMOVPDI2DImr                        $rdi, 1, $noreg, 0, $noreg, $xmm0
2302   VMOVPDI2DIZmr                                $rdi, 1, $noreg, 0, $noreg, $xmm0
2303   ; CHECK: $edi = VMOVPDI2DIrr                 $xmm0
2304   $edi = VMOVPDI2DIZrr                         $xmm0
2305   ; CHECK: $xmm0 = VMOVPQI2QIrr                $xmm0
2306   $xmm0 = VMOVPQI2QIZrr                        $xmm0
2307   ; CHECK: VMOVPQI2QImr                        $rdi, 1, $noreg, 0, $noreg, $xmm0
2308   VMOVPQI2QIZmr                                $rdi, 1, $noreg, 0, $noreg, $xmm0
2309   ; CHECK: $rdi = VMOVPQIto64rr                $xmm0
2310   $rdi = VMOVPQIto64Zrr                        $xmm0                                                   
2311   ; CHECK: VMOVPQIto64mr                       $rdi, 1, $noreg, 0, $noreg, $xmm0
2312   VMOVPQIto64Zmr                               $rdi, 1, $noreg, 0, $noreg, $xmm0
2313   ; CHECK: $xmm0 = VMOVQI2PQIrm                $rip, 1, $rax, 0, $noreg
2314   $xmm0 = VMOVQI2PQIZrm                        $rip, 1, $rax, 0, $noreg
2315   ; CHECK: $xmm0 = VMOVZPQILo2PQIrr            $xmm0                                               
2316   $xmm0 = VMOVZPQILo2PQIZrr                    $xmm0                                                   
2317   ; CHECK: VCOMISDrm_Int                       $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2318   VCOMISDZrm_Int                               $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2319   ; CHECK: VCOMISDrr_Int                       $xmm0, $xmm1, implicit-def $eflags  
2320   VCOMISDZrr_Int                               $xmm0, $xmm1, implicit-def $eflags                      
2321   ; CHECK: VCOMISSrm_Int                       $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2322   VCOMISSZrm_Int                               $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2323   ; CHECK: VCOMISSrr_Int                       $xmm0, $xmm1, implicit-def $eflags 
2324   VCOMISSZrr_Int                               $xmm0, $xmm1, implicit-def $eflags                      
2325   ; CHECK: VUCOMISDrm_Int                      $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2326   VUCOMISDZrm_Int                              $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2327   ; CHECK: VUCOMISDrr_Int                      $xmm0, $xmm1, implicit-def $eflags
2328   VUCOMISDZrr_Int                              $xmm0, $xmm1, implicit-def $eflags                      
2329   ; CHECK: VUCOMISSrm_Int                      $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2330   VUCOMISSZrm_Int                              $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2331   ; CHECK: VUCOMISSrr_Int                      $xmm0, $xmm1, implicit-def $eflags 
2332   VUCOMISSZrr_Int                              $xmm0, $xmm1, implicit-def $eflags                      
2333   ; CHECK: VCOMISDrm                           $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2334   VCOMISDZrm                                   $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2335   ; CHECK: VCOMISDrr                           $xmm0, $xmm1, implicit-def $eflags 
2336   VCOMISDZrr                                   $xmm0, $xmm1, implicit-def $eflags                      
2337   ; CHECK: VCOMISSrm                           $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2338   VCOMISSZrm                                   $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2339   ; CHECK: VCOMISSrr                           $xmm0, $xmm1, implicit-def $eflags 
2340   VCOMISSZrr                                   $xmm0, $xmm1, implicit-def $eflags                      
2341   ; CHECK: VUCOMISDrm                          $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2342   VUCOMISDZrm                                  $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2343   ; CHECK: VUCOMISDrr                          $xmm0, $xmm1, implicit-def $eflags 
2344   VUCOMISDZrr                                  $xmm0, $xmm1, implicit-def $eflags                      
2345   ; CHECK: VUCOMISSrm                          $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2346   VUCOMISSZrm                                  $xmm0, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
2347   ; CHECK: VUCOMISSrr                          $xmm0, $xmm1, implicit-def $eflags 
2348   VUCOMISSZrr                                  $xmm0, $xmm1, implicit-def $eflags 
2349   ; CHECK: VEXTRACTPSmr                        $rdi, 1, $noreg, 0, $noreg, $xmm0, 1
2350   VEXTRACTPSZmr                                $rdi, 1, $noreg, 0, $noreg, $xmm0, 1
2351   ; CHECK: $eax = VEXTRACTPSrr                 $xmm0, 1
2352   $eax = VEXTRACTPSZrr                         $xmm0, 1
2353   ; CHECK: $xmm0 = VINSERTPSrm                 $xmm0, $rdi, 1, $noreg, 0, $noreg, 1
2354   $xmm0 = VINSERTPSZrm                         $xmm0, $rdi, 1, $noreg, 0, $noreg, 1
2355   ; CHECK: $xmm0 = VINSERTPSrr                 $xmm0, $xmm0, 1
2356   $xmm0 = VINSERTPSZrr                         $xmm0, $xmm0, 1
2357   ; CHECK: $xmm0 = VROUNDSDm                   $xmm0, $rip, 1, $rax, 0, $noreg, 15
2358   $xmm0 = VRNDSCALESDZm                        $xmm0, $rip, 1, $rax, 0, $noreg, 15
2359   ; CHECK: $xmm0 = VROUNDSDr                   $xmm0, $xmm1, 15
2360   $xmm0 = VRNDSCALESDZr                        $xmm0, $xmm1, 15
2361   ; CHECK: $xmm0 = VROUNDSSm                   $xmm0, $rip, 1, $rax, 0, $noreg, 15
2362   $xmm0 = VRNDSCALESSZm                        $xmm0, $rip, 1, $rax, 0, $noreg, 15
2363   ; CHECK: $xmm0 = VROUNDSSr                   $xmm0, $xmm1, 15
2364   $xmm0 = VRNDSCALESSZr                        $xmm0, $xmm1, 15
2365   ; CHECK: $xmm0 = VROUNDSDm_Int               $xmm0, $rip, 1, $rax, 0, $noreg, 15
2366   $xmm0 = VRNDSCALESDZm_Int                    $xmm0, $rip, 1, $rax, 0, $noreg, 15
2367   ; CHECK: $xmm0 = VROUNDSDr_Int               $xmm0, $xmm1, 15
2368   $xmm0 = VRNDSCALESDZr_Int                    $xmm0, $xmm1, 15
2369   ; CHECK: $xmm0 = VROUNDSSm_Int               $xmm0, $rip, 1, $rax, 0, $noreg, 15
2370   $xmm0 = VRNDSCALESSZm_Int                    $xmm0, $rip, 1, $rax, 0, $noreg, 15
2371   ; CHECK: $xmm0 = VROUNDSSr_Int               $xmm0, $xmm1, 15
2372   $xmm0 = VRNDSCALESSZr_Int                    $xmm0, $xmm1, 15
2374   RET 0, $zmm0, $zmm1                          
2377   # CHECK-LABEL: name: evex_z256_to_evex_test
2378   # CHECK: bb.0:
2380 name: evex_z256_to_evex_test
2381 body: |
2382   bb.0:
2383   ; CHECK: VMOVAPDZ256mr                       $rdi, 1, $noreg, 0, $noreg, $ymm16
2384   VMOVAPDZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2385   ; CHECK: $ymm16 = VMOVAPDZ256rm              $rip, 1, $rax, 0, $noreg
2386   $ymm16 = VMOVAPDZ256rm                       $rip, 1, $rax, 0, $noreg
2387   ; CHECK: $ymm16 = VMOVAPDZ256rr              $ymm16
2388   $ymm16 = VMOVAPDZ256rr                       $ymm16                                        
2389   ; CHECK: $ymm16 = VMOVAPDZ256rr_REV          $ymm16
2390   $ymm16 = VMOVAPDZ256rr_REV                   $ymm16                                        
2391   ; CHECK: VMOVAPSZ256mr                       $rdi, 1, $noreg, 0, $noreg, $ymm16
2392   VMOVAPSZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2393   ; CHECK: $ymm16 = VMOVAPSZ256rm              $rip, 1, $rax, 0, $noreg
2394   $ymm16 = VMOVAPSZ256rm                       $rip, 1, $rax, 0, $noreg
2395   ; CHECK: $ymm16 = VMOVAPSZ256rr              $ymm16
2396   $ymm16 = VMOVAPSZ256rr                       $ymm16                                        
2397   ; CHECK: $ymm16 = VMOVAPSZ256rr_REV          $ymm16
2398   $ymm16 = VMOVAPSZ256rr_REV                   $ymm16                                        
2399   ; CHECK: $ymm16 = VMOVDDUPZ256rm             $rip, 1, $rax, 0, $noreg
2400   $ymm16 = VMOVDDUPZ256rm                      $rip, 1, $rax, 0, $noreg
2401   ; CHECK: $ymm16 = VMOVDDUPZ256rr             $ymm16
2402   $ymm16 = VMOVDDUPZ256rr                      $ymm16                                        
2403   ; CHECK: VMOVDQA32Z256mr                     $rdi, 1, $noreg, 0, $noreg, $ymm16
2404   VMOVDQA32Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2405   ; CHECK: $ymm16 = VMOVDQA32Z256rm            $rip, 1, $rax, 0, $noreg
2406   $ymm16 = VMOVDQA32Z256rm                     $rip, 1, $rax, 0, $noreg
2407   ; CHECK: $ymm16 = VMOVDQA32Z256rr            $ymm16
2408   $ymm16 = VMOVDQA32Z256rr                     $ymm16                                        
2409   ; CHECK: $ymm16 = VMOVDQA32Z256rr_REV        $ymm16
2410   $ymm16 = VMOVDQA32Z256rr_REV                 $ymm16                                        
2411   ; CHECK: VMOVDQA64Z256mr                     $rdi, 1, $noreg, 0, $noreg, $ymm16
2412   VMOVDQA64Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2413   ; CHECK: $ymm16 = VMOVDQA64Z256rm            $rip, 1, $rax, 0, $noreg
2414   $ymm16 = VMOVDQA64Z256rm                     $rip, 1, $rax, 0, $noreg
2415   ; CHECK: $ymm16 = VMOVDQA64Z256rr            $ymm16
2416   $ymm16 = VMOVDQA64Z256rr                     $ymm16                                        
2417   ; CHECK: $ymm16 = VMOVDQA64Z256rr_REV        $ymm16
2418   $ymm16 = VMOVDQA64Z256rr_REV                 $ymm16                                        
2419   ; CHECK: VMOVDQU16Z256mr                     $rdi, 1, $noreg, 0, $noreg, $ymm16
2420   VMOVDQU16Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2421   ; CHECK: $ymm16 = VMOVDQU16Z256rm            $rip, 1, $rax, 0, $noreg
2422   $ymm16 = VMOVDQU16Z256rm                     $rip, 1, $rax, 0, $noreg
2423   ; CHECK: $ymm16 = VMOVDQU16Z256rr            $ymm16
2424   $ymm16 = VMOVDQU16Z256rr                     $ymm16                                        
2425   ; CHECK: $ymm16 = VMOVDQU16Z256rr_REV        $ymm16
2426   $ymm16 = VMOVDQU16Z256rr_REV                 $ymm16                                        
2427   ; CHECK: VMOVDQU32Z256mr                     $rdi, 1, $noreg, 0, $noreg, $ymm16
2428   VMOVDQU32Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2429   ; CHECK: $ymm16 = VMOVDQU32Z256rm            $rip, 1, $rax, 0, $noreg
2430   $ymm16 = VMOVDQU32Z256rm                     $rip, 1, $rax, 0, $noreg
2431   ; CHECK: $ymm16 = VMOVDQU32Z256rr            $ymm16
2432   $ymm16 = VMOVDQU32Z256rr                     $ymm16                                        
2433   ; CHECK: $ymm16 = VMOVDQU32Z256rr_REV        $ymm16
2434   $ymm16 = VMOVDQU32Z256rr_REV                 $ymm16                                        
2435   ; CHECK: VMOVDQU64Z256mr                     $rdi, 1, $noreg, 0, $noreg, $ymm16
2436   VMOVDQU64Z256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2437   ; CHECK: $ymm16 = VMOVDQU64Z256rm            $rip, 1, $rax, 0, $noreg
2438   $ymm16 = VMOVDQU64Z256rm                     $rip, 1, $rax, 0, $noreg                           
2439   ; CHECK: $ymm16 = VMOVDQU64Z256rr            $ymm16
2440   $ymm16 = VMOVDQU64Z256rr                     $ymm16                                        
2441   ; CHECK: $ymm16 = VMOVDQU64Z256rr_REV        $ymm16
2442   $ymm16 = VMOVDQU64Z256rr_REV                 $ymm16                                        
2443   ; CHECK: VMOVDQU8Z256mr                      $rdi, 1, $noreg, 0, $noreg, $ymm16
2444   VMOVDQU8Z256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2445   ; CHECK: $ymm16 = VMOVDQU8Z256rm             $rip, 1, $rax, 0, $noreg
2446   $ymm16 = VMOVDQU8Z256rm                      $rip, 1, $rax, 0, $noreg
2447   ; CHECK: $ymm16 = VMOVDQU8Z256rr             $ymm16
2448   $ymm16 = VMOVDQU8Z256rr                      $ymm16                                        
2449   ; CHECK: $ymm16 = VMOVDQU8Z256rr_REV         $ymm16
2450   $ymm16 = VMOVDQU8Z256rr_REV                  $ymm16                                        
2451   ; CHECK: $ymm16 = VMOVNTDQAZ256rm            $rip, 1, $rax, 0, $noreg
2452   $ymm16 = VMOVNTDQAZ256rm                     $rip, 1, $rax, 0, $noreg
2453   ; CHECK: VMOVNTDQZ256mr                      $rdi, 1, $noreg, 0, $noreg, $ymm16
2454   VMOVNTDQZ256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2455   ; CHECK: VMOVNTPDZ256mr                      $rdi, 1, $noreg, 0, $noreg, $ymm16
2456   VMOVNTPDZ256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2457   ; CHECK: VMOVNTPSZ256mr                      $rdi, 1, $noreg, 0, $noreg, $ymm16
2458   VMOVNTPSZ256mr                               $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2459   ; CHECK: $ymm16 = VMOVSHDUPZ256rm            $rip, 1, $rax, 0, $noreg
2460   $ymm16 = VMOVSHDUPZ256rm                     $rip, 1, $rax, 0, $noreg                           
2461   ; CHECK: $ymm16 = VMOVSHDUPZ256rr            $ymm16
2462   $ymm16 = VMOVSHDUPZ256rr                     $ymm16                                        
2463   ; CHECK: $ymm16 = VMOVSLDUPZ256rm            $rip, 1, $rax, 0, $noreg
2464   $ymm16 = VMOVSLDUPZ256rm                     $rip, 1, $rax, 0, $noreg
2465   ; CHECK: $ymm16 = VMOVSLDUPZ256rr            $ymm16
2466   $ymm16 = VMOVSLDUPZ256rr                     $ymm16                                        
2467   ; CHECK: VMOVUPDZ256mr                       $rdi, 1, $noreg, 0, $noreg, $ymm16
2468   VMOVUPDZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm16                      
2469   ; CHECK: $ymm16 = VMOVUPDZ256rm              $rip, 1, $rax, 0, $noreg
2470   $ymm16 = VMOVUPDZ256rm                       $rip, 1, $rax, 0, $noreg
2471   ; CHECK: $ymm16 = VMOVUPDZ256rr              $ymm16
2472   $ymm16 = VMOVUPDZ256rr                       $ymm16                                        
2473   ; CHECK: $ymm16 = VMOVUPDZ256rr_REV          $ymm16
2474   $ymm16 = VMOVUPDZ256rr_REV                   $ymm16                                        
2475   ; CHECK: VMOVUPSZ256mr                       $rdi, 1, $noreg, 0, $noreg, $ymm16  
2476   VMOVUPSZ256mr                                $rdi, 1, $noreg, 0, $noreg, $ymm16                                               
2477   ; CHECK: $ymm16 = VPANDDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2478   $ymm16 = VPANDDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2479   ; CHECK: $ymm16 = VPANDDZ256rr               $ymm16, $ymm1  
2480   $ymm16 = VPANDDZ256rr                        $ymm16, $ymm1                                 
2481   ; CHECK: $ymm16 = VPANDQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2482   $ymm16 = VPANDQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2483   ; CHECK: $ymm16 = VPANDQZ256rr               $ymm16, $ymm1
2484   $ymm16 = VPANDQZ256rr                        $ymm16, $ymm1                                 
2485   ; CHECK: $ymm16 = VPANDNDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2486   $ymm16 = VPANDNDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2487   ; CHECK: $ymm16 = VPANDNDZ256rr               $ymm16, $ymm1  
2488   $ymm16 = VPANDNDZ256rr                        $ymm16, $ymm1                                 
2489   ; CHECK: $ymm16 = VPANDNQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2490   $ymm16 = VPANDNQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2491   ; CHECK: $ymm16 = VPANDNQZ256rr               $ymm16, $ymm1
2492   $ymm16 = VPANDNQZ256rr                        $ymm16, $ymm1                                 
2493   ; CHECK: $ymm16 = VPAVGBZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2494   $ymm16 = VPAVGBZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2495   ; CHECK: $ymm16 = VPAVGBZ256rr               $ymm16, $ymm1
2496   $ymm16 = VPAVGBZ256rr                        $ymm16, $ymm1                                 
2497   ; CHECK: $ymm16 = VPAVGWZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2498   $ymm16 = VPAVGWZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2499   ; CHECK: $ymm16 = VPAVGWZ256rr               $ymm16, $ymm1
2500   $ymm16 = VPAVGWZ256rr                        $ymm16, $ymm1                                 
2501   ; CHECK: $ymm16 = VPADDBZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2502   $ymm16 = VPADDBZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2503   ; CHECK: $ymm16 = VPADDBZ256rr               $ymm16, $ymm1  
2504   $ymm16 = VPADDBZ256rr                        $ymm16, $ymm1                                 
2505   ; CHECK: $ymm16 = VPADDDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2506   $ymm16 = VPADDDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2507   ; CHECK: $ymm16 = VPADDDZ256rr               $ymm16, $ymm1
2508   $ymm16 = VPADDDZ256rr                        $ymm16, $ymm1                                 
2509   ; CHECK: $ymm16 = VPADDQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2510   $ymm16 = VPADDQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2511   ; CHECK: $ymm16 = VPADDQZ256rr               $ymm16, $ymm1
2512   $ymm16 = VPADDQZ256rr                        $ymm16, $ymm1                                 
2513   ; CHECK: $ymm16 = VPADDSBZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2514   $ymm16 = VPADDSBZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2515   ; CHECK: $ymm16 = VPADDSBZ256rr              $ymm16, $ymm1
2516   $ymm16 = VPADDSBZ256rr                       $ymm16, $ymm1                                 
2517   ; CHECK: $ymm16 = VPADDSWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2518   $ymm16 = VPADDSWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2519   ; CHECK: $ymm16 = VPADDSWZ256rr              $ymm16, $ymm1
2520   $ymm16 = VPADDSWZ256rr                       $ymm16, $ymm1                                 
2521   ; CHECK: $ymm16 = VPADDUSBZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2522   $ymm16 = VPADDUSBZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2523   ; CHECK: $ymm16 = VPADDUSBZ256rr             $ymm16, $ymm1
2524   $ymm16 = VPADDUSBZ256rr                      $ymm16, $ymm1                                 
2525   ; CHECK: $ymm16 = VPADDUSWZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2526   $ymm16 = VPADDUSWZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2527   ; CHECK: $ymm16 = VPADDUSWZ256rr             $ymm16, $ymm1
2528   $ymm16 = VPADDUSWZ256rr                      $ymm16, $ymm1                                 
2529   ; CHECK: $ymm16 = VPADDWZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2530   $ymm16 = VPADDWZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2531   ; CHECK: $ymm16 = VPADDWZ256rr               $ymm16, $ymm1
2532   $ymm16 = VPADDWZ256rr                        $ymm16, $ymm1                                 
2533   ; CHECK: $ymm16 = VMULPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2534   $ymm16 = VMULPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2535   ; CHECK: $ymm16 = VMULPDZ256rr               $ymm16, $ymm1
2536   $ymm16 = VMULPDZ256rr                        $ymm16, $ymm1                                 
2537   ; CHECK: $ymm16 = VMULPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2538   $ymm16 = VMULPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2539   ; CHECK: $ymm16 = VMULPSZ256rr               $ymm16, $ymm1
2540   $ymm16 = VMULPSZ256rr                        $ymm16, $ymm1                                 
2541   ; CHECK: $ymm16 = VORPDZ256rm                $ymm16, $rip, 1, $rax, 0, $noreg
2542   $ymm16 = VORPDZ256rm                         $ymm16, $rip, 1, $rax, 0, $noreg
2543   ; CHECK: $ymm16 = VORPDZ256rr                $ymm16, $ymm1
2544   $ymm16 = VORPDZ256rr                         $ymm16, $ymm1                                 
2545   ; CHECK: $ymm16 = VORPSZ256rm                $ymm16, $rip, 1, $rax, 0, $noreg
2546   $ymm16 = VORPSZ256rm                         $ymm16, $rip, 1, $rax, 0, $noreg
2547   ; CHECK: $ymm16 = VORPSZ256rr                $ymm16, $ymm1
2548   $ymm16 = VORPSZ256rr                         $ymm16, $ymm1                                 
2549   ; CHECK: $ymm16 = VPMADDUBSWZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2550   $ymm16 = VPMADDUBSWZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2551   ; CHECK: $ymm16 = VPMADDUBSWZ256rr           $ymm16, $ymm1
2552   $ymm16 = VPMADDUBSWZ256rr                    $ymm16, $ymm1                                 
2553   ; CHECK: $ymm16 = VPMADDWDZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2554   $ymm16 = VPMADDWDZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2555   ; CHECK: $ymm16 = VPMADDWDZ256rr             $ymm16, $ymm1
2556   $ymm16 = VPMADDWDZ256rr                      $ymm16, $ymm1                                 
2557   ; CHECK: $ymm16 = VPMAXSBZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2558   $ymm16 = VPMAXSBZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2559   ; CHECK: $ymm16 = VPMAXSBZ256rr              $ymm16, $ymm1
2560   $ymm16 = VPMAXSBZ256rr                       $ymm16, $ymm1                                 
2561   ; CHECK: $ymm16 = VPMAXSDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2562   $ymm16 = VPMAXSDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2563   ; CHECK: $ymm16 = VPMAXSDZ256rr              $ymm16, $ymm1
2564   $ymm16 = VPMAXSDZ256rr                       $ymm16, $ymm1                                 
2565   ; CHECK: $ymm16 = VPMAXSWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2566   $ymm16 = VPMAXSWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2567   ; CHECK: $ymm16 = VPMAXSWZ256rr              $ymm16, $ymm1
2568   $ymm16 = VPMAXSWZ256rr                       $ymm16, $ymm1                                 
2569   ; CHECK: $ymm16 = VPMAXUBZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2570   $ymm16 = VPMAXUBZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2571   ; CHECK: $ymm16 = VPMAXUBZ256rr              $ymm16, $ymm1
2572   $ymm16 = VPMAXUBZ256rr                       $ymm16, $ymm1                                 
2573   ; CHECK: $ymm16 = VPMAXUDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2574   $ymm16 = VPMAXUDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2575   ; CHECK: $ymm16 = VPMAXUDZ256rr              $ymm16, $ymm1
2576   $ymm16 = VPMAXUDZ256rr                       $ymm16, $ymm1                                 
2577   ; CHECK: $ymm16 = VPMAXUWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2578   $ymm16 = VPMAXUWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2579   ; CHECK: $ymm16 = VPMAXUWZ256rr              $ymm16, $ymm1
2580   $ymm16 = VPMAXUWZ256rr                       $ymm16, $ymm1                                 
2581   ; CHECK: $ymm16 = VPMINSBZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2582   $ymm16 = VPMINSBZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2583   ; CHECK: $ymm16 = VPMINSBZ256rr              $ymm16, $ymm1
2584   $ymm16 = VPMINSBZ256rr                       $ymm16, $ymm1                                 
2585   ; CHECK: $ymm16 = VPMINSDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2586   $ymm16 = VPMINSDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2587   ; CHECK: $ymm16 = VPMINSDZ256rr              $ymm16, $ymm1
2588   $ymm16 = VPMINSDZ256rr                       $ymm16, $ymm1                                 
2589   ; CHECK: $ymm16 = VPMINSWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2590   $ymm16 = VPMINSWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2591   ; CHECK: $ymm16 = VPMINSWZ256rr              $ymm16, $ymm1
2592   $ymm16 = VPMINSWZ256rr                       $ymm16, $ymm1                                 
2593   ; CHECK: $ymm16 = VPMINUBZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2594   $ymm16 = VPMINUBZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2595   ; CHECK: $ymm16 = VPMINUBZ256rr              $ymm16, $ymm1
2596   $ymm16 = VPMINUBZ256rr                       $ymm16, $ymm1                                 
2597   ; CHECK: $ymm16 = VPMINUDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2598   $ymm16 = VPMINUDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2599   ; CHECK: $ymm16 = VPMINUDZ256rr              $ymm16, $ymm1
2600   $ymm16 = VPMINUDZ256rr                       $ymm16, $ymm1                                 
2601   ; CHECK: $ymm16 = VPMINUWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2602   $ymm16 = VPMINUWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2603   ; CHECK: $ymm16 = VPMINUWZ256rr              $ymm16, $ymm1
2604   $ymm16 = VPMINUWZ256rr                       $ymm16, $ymm1                                 
2605   ; CHECK: $ymm16 = VPMULDQZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2606   $ymm16 = VPMULDQZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2607   ; CHECK: $ymm16 = VPMULDQZ256rr              $ymm16, $ymm1  
2608   $ymm16 = VPMULDQZ256rr                       $ymm16, $ymm1                                 
2609   ; CHECK: $ymm16 = VPMULHRSWZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2610   $ymm16 = VPMULHRSWZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2611   ; CHECK: $ymm16 = VPMULHRSWZ256rr            $ymm16, $ymm1
2612   $ymm16 = VPMULHRSWZ256rr                     $ymm16, $ymm1                                 
2613   ; CHECK: $ymm16 = VPMULHUWZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2614   $ymm16 = VPMULHUWZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2615   ; CHECK: $ymm16 = VPMULHUWZ256rr             $ymm16, $ymm1
2616   $ymm16 = VPMULHUWZ256rr                      $ymm16, $ymm1                                 
2617   ; CHECK: $ymm16 = VPMULHWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2618   $ymm16 = VPMULHWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2619   ; CHECK: $ymm16 = VPMULHWZ256rr              $ymm16, $ymm1
2620   $ymm16 = VPMULHWZ256rr                       $ymm16, $ymm1                                 
2621   ; CHECK: $ymm16 = VPMULLDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2622   $ymm16 = VPMULLDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2623   ; CHECK: $ymm16 = VPMULLDZ256rr              $ymm16, $ymm1
2624   $ymm16 = VPMULLDZ256rr                       $ymm16, $ymm1                                 
2625   ; CHECK: $ymm16 = VPMULLWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2626   $ymm16 = VPMULLWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2627   ; CHECK: $ymm16 = VPMULLWZ256rr              $ymm16, $ymm1  
2628   $ymm16 = VPMULLWZ256rr                       $ymm16, $ymm1                                 
2629   ; CHECK: $ymm16 = VPMULUDQZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2630   $ymm16 = VPMULUDQZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2631   ; CHECK: $ymm16 = VPMULUDQZ256rr             $ymm16, $ymm1
2632   $ymm16 = VPMULUDQZ256rr                      $ymm16, $ymm1                                 
2633   ; CHECK: $ymm16 = VPORDZ256rm                $ymm16, $rip, 1, $rax, 0, $noreg
2634   $ymm16 = VPORDZ256rm                         $ymm16, $rip, 1, $rax, 0, $noreg
2635   ; CHECK: $ymm16 = VPORDZ256rr                $ymm16, $ymm1
2636   $ymm16 = VPORDZ256rr                         $ymm16, $ymm1                                 
2637   ; CHECK: $ymm16 = VPORQZ256rm                $ymm16, $rip, 1, $rax, 0, $noreg
2638   $ymm16 = VPORQZ256rm                         $ymm16, $rip, 1, $rax, 0, $noreg
2639   ; CHECK: $ymm16 = VPORQZ256rr                $ymm16, $ymm1
2640   $ymm16 = VPORQZ256rr                         $ymm16, $ymm1                                 
2641   ; CHECK: $ymm16 = VPSUBBZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2642   $ymm16 = VPSUBBZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2643   ; CHECK: $ymm16 = VPSUBBZ256rr               $ymm16, $ymm1
2644   $ymm16 = VPSUBBZ256rr                        $ymm16, $ymm1                                 
2645   ; CHECK: $ymm16 = VPSUBDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2646   $ymm16 = VPSUBDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2647   ; CHECK: $ymm16 = VPSUBDZ256rr               $ymm16, $ymm1
2648   $ymm16 = VPSUBDZ256rr                        $ymm16, $ymm1                                 
2649   ; CHECK: $ymm16 = VPSUBQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2650   $ymm16 = VPSUBQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2651   ; CHECK: $ymm16 = VPSUBQZ256rr               $ymm16, $ymm1
2652   $ymm16 = VPSUBQZ256rr                        $ymm16, $ymm1                                 
2653   ; CHECK: $ymm16 = VPSUBSBZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2654   $ymm16 = VPSUBSBZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2655   ; CHECK: $ymm16 = VPSUBSBZ256rr              $ymm16, $ymm1
2656   $ymm16 = VPSUBSBZ256rr                       $ymm16, $ymm1                                 
2657   ; CHECK: $ymm16 = VPSUBSWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2658   $ymm16 = VPSUBSWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2659   ; CHECK: $ymm16 = VPSUBSWZ256rr              $ymm16, $ymm1
2660   $ymm16 = VPSUBSWZ256rr                       $ymm16, $ymm1                                 
2661   ; CHECK: $ymm16 = VPSUBUSBZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2662   $ymm16 = VPSUBUSBZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2663   ; CHECK: $ymm16 = VPSUBUSBZ256rr             $ymm16, $ymm1
2664   $ymm16 = VPSUBUSBZ256rr                      $ymm16, $ymm1                                 
2665   ; CHECK: $ymm16 = VPSUBUSWZ256rm             $ymm16, $rip, 1, $rax, 0, $noreg
2666   $ymm16 = VPSUBUSWZ256rm                      $ymm16, $rip, 1, $rax, 0, $noreg
2667   ; CHECK: $ymm16 = VPSUBUSWZ256rr             $ymm16, $ymm1
2668   $ymm16 = VPSUBUSWZ256rr                      $ymm16, $ymm1                                 
2669   ; CHECK: $ymm16 = VPSUBWZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2670   $ymm16 = VPSUBWZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2671   ; CHECK: $ymm16 = VPSUBWZ256rr               $ymm16, $ymm1
2672   $ymm16 = VPSUBWZ256rr                        $ymm16, $ymm1                                 
2673   ; CHECK: $ymm16 = VPXORDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2674   $ymm16 = VPXORDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2675   ; CHECK: $ymm16 = VPXORDZ256rr               $ymm16, $ymm1
2676   $ymm16 = VPXORDZ256rr                        $ymm16, $ymm1                                 
2677   ; CHECK: $ymm16 = VPXORQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2678   $ymm16 = VPXORQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2679   ; CHECK: $ymm16 = VPXORQZ256rr               $ymm16, $ymm1  
2680   $ymm16 = VPXORQZ256rr                        $ymm16, $ymm1                                 
2681   ; CHECK: $ymm16 = VADDPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2682   $ymm16 = VADDPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2683   ; CHECK: $ymm16 = VADDPDZ256rr               $ymm16, $ymm1
2684   $ymm16 = VADDPDZ256rr                        $ymm16, $ymm1                                 
2685   ; CHECK: $ymm16 = VADDPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2686   $ymm16 = VADDPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2687   ; CHECK: $ymm16 = VADDPSZ256rr               $ymm16, $ymm1
2688   $ymm16 = VADDPSZ256rr                        $ymm16, $ymm1                                 
2689   ; CHECK: $ymm16 = VANDNPDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2690   $ymm16 = VANDNPDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2691   ; CHECK: $ymm16 = VANDNPDZ256rr              $ymm16, $ymm1
2692   $ymm16 = VANDNPDZ256rr                       $ymm16, $ymm1                                 
2693   ; CHECK: $ymm16 = VANDNPSZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2694   $ymm16 = VANDNPSZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2695   ; CHECK: $ymm16 = VANDNPSZ256rr              $ymm16, $ymm1
2696   $ymm16 = VANDNPSZ256rr                       $ymm16, $ymm1                                 
2697   ; CHECK: $ymm16 = VANDPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2698   $ymm16 = VANDPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2699   ; CHECK: $ymm16 = VANDPDZ256rr               $ymm16, $ymm1
2700   $ymm16 = VANDPDZ256rr                        $ymm16, $ymm1                                 
2701   ; CHECK: $ymm16 = VANDPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2702   $ymm16 = VANDPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2703   ; CHECK: $ymm16 = VANDPSZ256rr               $ymm16, $ymm1
2704   $ymm16 = VANDPSZ256rr                        $ymm16, $ymm1                                 
2705   ; CHECK: $ymm16 = VDIVPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2706   $ymm16 = VDIVPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2707   ; CHECK: $ymm16 = VDIVPDZ256rr               $ymm16, $ymm1  
2708   $ymm16 = VDIVPDZ256rr                        $ymm16, $ymm1                                 
2709   ; CHECK: $ymm16 = VDIVPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2710   $ymm16 = VDIVPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2711   ; CHECK: $ymm16 = VDIVPSZ256rr               $ymm16, $ymm1
2712   $ymm16 = VDIVPSZ256rr                        $ymm16, $ymm1                                 
2713   ; CHECK: $ymm16 = VMAXCPDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2714   $ymm16 = VMAXCPDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2715   ; CHECK: $ymm16 = VMAXCPDZ256rr              $ymm16, $ymm1
2716   $ymm16 = VMAXCPDZ256rr                       $ymm16, $ymm1                                 
2717   ; CHECK: $ymm16 = VMAXCPSZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2718   $ymm16 = VMAXCPSZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2719   ; CHECK: $ymm16 = VMAXCPSZ256rr              $ymm16, $ymm1
2720   $ymm16 = VMAXCPSZ256rr                       $ymm16, $ymm1                                 
2721   ; CHECK: $ymm16 = VMAXPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2722   $ymm16 = VMAXPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2723   ; CHECK: $ymm16 = VMAXPDZ256rr               $ymm16, $ymm1
2724   $ymm16 = VMAXPDZ256rr                        $ymm16, $ymm1                                 
2725   ; CHECK: $ymm16 = VMAXPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2726   $ymm16 = VMAXPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2727   ; CHECK: $ymm16 = VMAXPSZ256rr               $ymm16, $ymm1
2728   $ymm16 = VMAXPSZ256rr                        $ymm16, $ymm1                                 
2729   ; CHECK: $ymm16 = VMINCPDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2730   $ymm16 = VMINCPDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2731   ; CHECK: $ymm16 = VMINCPDZ256rr              $ymm16, $ymm1
2732   $ymm16 = VMINCPDZ256rr                       $ymm16, $ymm1                                 
2733   ; CHECK: $ymm16 = VMINCPSZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2734   $ymm16 = VMINCPSZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2735   ; CHECK: $ymm16 = VMINCPSZ256rr              $ymm16, $ymm1
2736   $ymm16 = VMINCPSZ256rr                       $ymm16, $ymm1                                 
2737   ; CHECK: $ymm16 = VMINPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2738   $ymm16 = VMINPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2739   ; CHECK: $ymm16 = VMINPDZ256rr               $ymm16, $ymm1
2740   $ymm16 = VMINPDZ256rr                        $ymm16, $ymm1                                 
2741   ; CHECK: $ymm16 = VMINPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2742   $ymm16 = VMINPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2743   ; CHECK: $ymm16 = VMINPSZ256rr               $ymm16, $ymm1
2744   $ymm16 = VMINPSZ256rr                        $ymm16, $ymm1                                 
2745   ; CHECK: $ymm16 = VXORPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2746   $ymm16 = VXORPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2747   ; CHECK: $ymm16 = VXORPDZ256rr               $ymm16, $ymm1
2748   $ymm16 = VXORPDZ256rr                        $ymm16, $ymm1                                 
2749   ; CHECK: $ymm16 = VXORPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2750   $ymm16 = VXORPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2751   ; CHECK: $ymm16 = VXORPSZ256rr               $ymm16, $ymm1
2752   $ymm16 = VXORPSZ256rr                        $ymm16, $ymm1                                 
2753   ; CHECK: $ymm16 = VPACKSSDWZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2754   $ymm16 = VPACKSSDWZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2755   ; CHECK: $ymm16 = VPACKSSDWZ256rr            $ymm16, $ymm1
2756   $ymm16 = VPACKSSDWZ256rr                     $ymm16, $ymm1                                 
2757   ; CHECK: $ymm16 = VPACKSSWBZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2758   $ymm16 = VPACKSSWBZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2759   ; CHECK: $ymm16 = VPACKSSWBZ256rr            $ymm16, $ymm1
2760   $ymm16 = VPACKSSWBZ256rr                     $ymm16, $ymm1                                 
2761   ; CHECK: $ymm16 = VPACKUSDWZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2762   $ymm16 = VPACKUSDWZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2763   ; CHECK: $ymm16 = VPACKUSDWZ256rr            $ymm16, $ymm1
2764   $ymm16 = VPACKUSDWZ256rr                     $ymm16, $ymm1                                 
2765   ; CHECK: $ymm16 = VPACKUSWBZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2766   $ymm16 = VPACKUSWBZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2767   ; CHECK: $ymm16 = VPACKUSWBZ256rr            $ymm16, $ymm1
2768   $ymm16 = VPACKUSWBZ256rr                     $ymm16, $ymm1                                 
2769   ; CHECK: $ymm16 = VUNPCKHPDZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2770   $ymm16 = VUNPCKHPDZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2771   ; CHECK: $ymm16 = VUNPCKHPDZ256rr            $ymm16, $ymm1
2772   $ymm16 = VUNPCKHPDZ256rr                     $ymm16, $ymm1                                 
2773   ; CHECK: $ymm16 = VUNPCKHPSZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2774   $ymm16 = VUNPCKHPSZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2775   ; CHECK: $ymm16 = VUNPCKHPSZ256rr            $ymm16, $ymm1
2776   $ymm16 = VUNPCKHPSZ256rr                     $ymm16, $ymm1                                 
2777   ; CHECK: $ymm16 = VUNPCKLPDZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2778   $ymm16 = VUNPCKLPDZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2779   ; CHECK: $ymm16 = VUNPCKLPDZ256rr            $ymm16, $ymm1
2780   $ymm16 = VUNPCKLPDZ256rr                     $ymm16, $ymm1                                 
2781   ; CHECK: $ymm16 = VUNPCKLPSZ256rm            $ymm16, $rip, 1, $rax, 0, $noreg
2782   $ymm16 = VUNPCKLPSZ256rm                     $ymm16, $rip, 1, $rax, 0, $noreg
2783   ; CHECK: $ymm16 = VUNPCKLPSZ256rr            $ymm16, $ymm1
2784   $ymm16 = VUNPCKLPSZ256rr                     $ymm16, $ymm1                                 
2785   ; CHECK: $ymm16 = VSUBPDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg 
2786   $ymm16 = VSUBPDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2787   ; CHECK: $ymm16 = VSUBPDZ256rr               $ymm16, $ymm1 
2788   $ymm16 = VSUBPDZ256rr                        $ymm16, $ymm1                                 
2789   ; CHECK: $ymm16 = VSUBPSZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg 
2790   $ymm16 = VSUBPSZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2791   ; CHECK: $ymm16 = VSUBPSZ256rr               $ymm16, $ymm1   
2792   $ymm16 = VSUBPSZ256rr                        $ymm16, $ymm1                                                
2793   ; CHECK: $ymm16 = VPUNPCKHBWZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2794   $ymm16 = VPUNPCKHBWZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2795   ; CHECK: $ymm16 = VPUNPCKHBWZ256rr           $ymm16, $ymm1
2796   $ymm16 = VPUNPCKHBWZ256rr                    $ymm16, $ymm1                                 
2797   ; CHECK: $ymm16 = VPUNPCKHDQZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2798   $ymm16 = VPUNPCKHDQZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2799   ; CHECK: $ymm16 = VPUNPCKHDQZ256rr           $ymm16, $ymm1
2800   $ymm16 = VPUNPCKHDQZ256rr                    $ymm16, $ymm1                                 
2801   ; CHECK: $ymm16 = VPUNPCKHQDQZ256rm          $ymm16, $rip, 1, $rax, 0, $noreg
2802   $ymm16 = VPUNPCKHQDQZ256rm                   $ymm16, $rip, 1, $rax, 0, $noreg
2803   ; CHECK: $ymm16 = VPUNPCKHQDQZ256rr          $ymm16, $ymm1
2804   $ymm16 = VPUNPCKHQDQZ256rr                   $ymm16, $ymm1                                 
2805   ; CHECK: $ymm16 = VPUNPCKHWDZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2806   $ymm16 = VPUNPCKHWDZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2807   ; CHECK: $ymm16 = VPUNPCKHWDZ256rr           $ymm16, $ymm1
2808   $ymm16 = VPUNPCKHWDZ256rr                    $ymm16, $ymm1                                 
2809   ; CHECK: $ymm16 = VPUNPCKLBWZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2810   $ymm16 = VPUNPCKLBWZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2811   ; CHECK: $ymm16 = VPUNPCKLBWZ256rr           $ymm16, $ymm1
2812   $ymm16 = VPUNPCKLBWZ256rr                    $ymm16, $ymm1                                 
2813   ; CHECK: $ymm16 = VPUNPCKLDQZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2814   $ymm16 = VPUNPCKLDQZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2815   ; CHECK: $ymm16 = VPUNPCKLDQZ256rr           $ymm16, $ymm1 
2816   $ymm16 = VPUNPCKLDQZ256rr                    $ymm16, $ymm1                                 
2817   ; CHECK: $ymm16 = VPUNPCKLQDQZ256rm          $ymm16, $rip, 1, $rax, 0, $noreg
2818   $ymm16 = VPUNPCKLQDQZ256rm                   $ymm16, $rip, 1, $rax, 0, $noreg
2819   ; CHECK: $ymm16 = VPUNPCKLQDQZ256rr          $ymm16, $ymm1 
2820   $ymm16 = VPUNPCKLQDQZ256rr                   $ymm16, $ymm1                                 
2821   ; CHECK: $ymm16 = VPUNPCKLWDZ256rm           $ymm16, $rip, 1, $rax, 0, $noreg
2822   $ymm16 = VPUNPCKLWDZ256rm                    $ymm16, $rip, 1, $rax, 0, $noreg
2823   ; CHECK: $ymm16 = VPUNPCKLWDZ256rr           $ymm16, $ymm1   
2824   $ymm16 = VPUNPCKLWDZ256rr                    $ymm16, $ymm1                                                
2825   ; CHECK: $ymm16 = VFMADD132PDZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2826   $ymm16 = VFMADD132PDZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2827   ; CHECK: $ymm16 = VFMADD132PDZ256r           $ymm16, $ymm1, $ymm2
2828   $ymm16 = VFMADD132PDZ256r                    $ymm16, $ymm1, $ymm2                          
2829   ; CHECK: $ymm16 = VFMADD132PSZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2830   $ymm16 = VFMADD132PSZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2831   ; CHECK: $ymm16 = VFMADD132PSZ256r           $ymm16, $ymm1, $ymm2
2832   $ymm16 = VFMADD132PSZ256r                    $ymm16, $ymm1, $ymm2                          
2833   ; CHECK: $ymm16 = VFMADD213PDZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2834   $ymm16 = VFMADD213PDZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2835   ; CHECK: $ymm16 = VFMADD213PDZ256r           $ymm16, $ymm1, $ymm2
2836   $ymm16 = VFMADD213PDZ256r                    $ymm16, $ymm1, $ymm2                          
2837   ; CHECK: $ymm16 = VFMADD213PSZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2838   $ymm16 = VFMADD213PSZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2839   ; CHECK: $ymm16 = VFMADD213PSZ256r           $ymm16, $ymm1, $ymm2
2840   $ymm16 = VFMADD213PSZ256r                    $ymm16, $ymm1, $ymm2                          
2841   ; CHECK: $ymm16 = VFMADD231PDZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2842   $ymm16 = VFMADD231PDZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2843   ; CHECK: $ymm16 = VFMADD231PDZ256r           $ymm16, $ymm1, $ymm2
2844   $ymm16 = VFMADD231PDZ256r                    $ymm16, $ymm1, $ymm2                          
2845   ; CHECK: $ymm16 = VFMADD231PSZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2846   $ymm16 = VFMADD231PSZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2847   ; CHECK: $ymm16 = VFMADD231PSZ256r           $ymm16, $ymm1, $ymm2
2848   $ymm16 = VFMADD231PSZ256r                    $ymm16, $ymm1, $ymm2                          
2849   ; CHECK: $ymm16 = VFMADDSUB132PDZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2850   $ymm16 = VFMADDSUB132PDZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2851   ; CHECK: $ymm16 = VFMADDSUB132PDZ256r        $ymm16, $ymm1, $ymm2
2852   $ymm16 = VFMADDSUB132PDZ256r                 $ymm16, $ymm1, $ymm2                          
2853   ; CHECK: $ymm16 = VFMADDSUB132PSZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2854   $ymm16 = VFMADDSUB132PSZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2855   ; CHECK: $ymm16 = VFMADDSUB132PSZ256r        $ymm16, $ymm1, $ymm2
2856   $ymm16 = VFMADDSUB132PSZ256r                 $ymm16, $ymm1, $ymm2                          
2857   ; CHECK: $ymm16 = VFMADDSUB213PDZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2858   $ymm16 = VFMADDSUB213PDZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2859   ; CHECK: $ymm16 = VFMADDSUB213PDZ256r        $ymm16, $ymm1, $ymm2
2860   $ymm16 = VFMADDSUB213PDZ256r                 $ymm16, $ymm1, $ymm2                          
2861   ; CHECK: $ymm16 = VFMADDSUB213PSZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2862   $ymm16 = VFMADDSUB213PSZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2863   ; CHECK: $ymm16 = VFMADDSUB213PSZ256r        $ymm16, $ymm1, $ymm2
2864   $ymm16 = VFMADDSUB213PSZ256r                 $ymm16, $ymm1, $ymm2                          
2865   ; CHECK: $ymm16 = VFMADDSUB231PDZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2866   $ymm16 = VFMADDSUB231PDZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2867   ; CHECK: $ymm16 = VFMADDSUB231PDZ256r        $ymm16, $ymm1, $ymm2
2868   $ymm16 = VFMADDSUB231PDZ256r                 $ymm16, $ymm1, $ymm2                          
2869   ; CHECK: $ymm16 = VFMADDSUB231PSZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2870   $ymm16 = VFMADDSUB231PSZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2871   ; CHECK: $ymm16 = VFMADDSUB231PSZ256r        $ymm16, $ymm1, $ymm2
2872   $ymm16 = VFMADDSUB231PSZ256r                 $ymm16, $ymm1, $ymm2                          
2873   ; CHECK: $ymm16 = VFMSUB132PDZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2874   $ymm16 = VFMSUB132PDZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2875   ; CHECK: $ymm16 = VFMSUB132PDZ256r           $ymm16, $ymm1, $ymm2
2876   $ymm16 = VFMSUB132PDZ256r                    $ymm16, $ymm1, $ymm2                          
2877   ; CHECK: $ymm16 = VFMSUB132PSZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2878   $ymm16 = VFMSUB132PSZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2879   ; CHECK: $ymm16 = VFMSUB132PSZ256r           $ymm16, $ymm1, $ymm2
2880   $ymm16 = VFMSUB132PSZ256r                    $ymm16, $ymm1, $ymm2                          
2881   ; CHECK: $ymm16 = VFMSUB213PDZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2882   $ymm16 = VFMSUB213PDZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2883   ; CHECK: $ymm16 = VFMSUB213PDZ256r           $ymm16, $ymm1, $ymm2
2884   $ymm16 = VFMSUB213PDZ256r                    $ymm16, $ymm1, $ymm2                          
2885   ; CHECK: $ymm16 = VFMSUB213PSZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2886   $ymm16 = VFMSUB213PSZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2887   ; CHECK: $ymm16 = VFMSUB213PSZ256r           $ymm16, $ymm1, $ymm2
2888   $ymm16 = VFMSUB213PSZ256r                    $ymm16, $ymm1, $ymm2                          
2889   ; CHECK: $ymm16 = VFMSUB231PDZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2890   $ymm16 = VFMSUB231PDZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2891   ; CHECK: $ymm16 = VFMSUB231PDZ256r           $ymm16, $ymm1, $ymm2
2892   $ymm16 = VFMSUB231PDZ256r                    $ymm16, $ymm1, $ymm2                          
2893   ; CHECK: $ymm16 = VFMSUB231PSZ256m           $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2894   $ymm16 = VFMSUB231PSZ256m                    $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2895   ; CHECK: $ymm16 = VFMSUB231PSZ256r           $ymm16, $ymm1, $ymm2
2896   $ymm16 = VFMSUB231PSZ256r                    $ymm16, $ymm1, $ymm2                          
2897   ; CHECK: $ymm16 = VFMSUBADD132PDZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2898   $ymm16 = VFMSUBADD132PDZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2899   ; CHECK: $ymm16 = VFMSUBADD132PDZ256r        $ymm16, $ymm1, $ymm2
2900   $ymm16 = VFMSUBADD132PDZ256r                 $ymm16, $ymm1, $ymm2                          
2901   ; CHECK: $ymm16 = VFMSUBADD132PSZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2902   $ymm16 = VFMSUBADD132PSZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2903   ; CHECK: $ymm16 = VFMSUBADD132PSZ256r        $ymm16, $ymm1, $ymm2
2904   $ymm16 = VFMSUBADD132PSZ256r                 $ymm16, $ymm1, $ymm2                          
2905   ; CHECK: $ymm16 = VFMSUBADD213PDZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2906   $ymm16 = VFMSUBADD213PDZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2907   ; CHECK: $ymm16 = VFMSUBADD213PDZ256r        $ymm16, $ymm1, $ymm2
2908   $ymm16 = VFMSUBADD213PDZ256r                 $ymm16, $ymm1, $ymm2                          
2909   ; CHECK: $ymm16 = VFMSUBADD213PSZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2910   $ymm16 = VFMSUBADD213PSZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2911   ; CHECK: $ymm16 = VFMSUBADD213PSZ256r        $ymm16, $ymm1, $ymm2
2912   $ymm16 = VFMSUBADD213PSZ256r                 $ymm16, $ymm1, $ymm2                          
2913   ; CHECK: $ymm16 = VFMSUBADD231PDZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2914   $ymm16 = VFMSUBADD231PDZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2915   ; CHECK: $ymm16 = VFMSUBADD231PDZ256r        $ymm16, $ymm1, $ymm2
2916   $ymm16 = VFMSUBADD231PDZ256r                 $ymm16, $ymm1, $ymm2                          
2917   ; CHECK: $ymm16 = VFMSUBADD231PSZ256m        $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2918   $ymm16 = VFMSUBADD231PSZ256m                 $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2919   ; CHECK: $ymm16 = VFMSUBADD231PSZ256r        $ymm16, $ymm1, $ymm2
2920   $ymm16 = VFMSUBADD231PSZ256r                 $ymm16, $ymm1, $ymm2                          
2921   ; CHECK: $ymm16 = VFNMADD132PDZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2922   $ymm16 = VFNMADD132PDZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2923   ; CHECK: $ymm16 = VFNMADD132PDZ256r          $ymm16, $ymm1, $ymm2
2924   $ymm16 = VFNMADD132PDZ256r                   $ymm16, $ymm1, $ymm2                          
2925   ; CHECK: $ymm16 = VFNMADD132PSZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2926   $ymm16 = VFNMADD132PSZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2927   ; CHECK: $ymm16 = VFNMADD132PSZ256r          $ymm16, $ymm1, $ymm2
2928   $ymm16 = VFNMADD132PSZ256r                   $ymm16, $ymm1, $ymm2                          
2929   ; CHECK: $ymm16 = VFNMADD213PDZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2930   $ymm16 = VFNMADD213PDZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2931   ; CHECK: $ymm16 = VFNMADD213PDZ256r          $ymm16, $ymm1, $ymm2
2932   $ymm16 = VFNMADD213PDZ256r                   $ymm16, $ymm1, $ymm2                          
2933   ; CHECK: $ymm16 = VFNMADD213PSZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2934   $ymm16 = VFNMADD213PSZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2935   ; CHECK: $ymm16 = VFNMADD213PSZ256r          $ymm16, $ymm1, $ymm2
2936   $ymm16 = VFNMADD213PSZ256r                   $ymm16, $ymm1, $ymm2                          
2937   ; CHECK: $ymm16 = VFNMADD231PDZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2938   $ymm16 = VFNMADD231PDZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2939   ; CHECK: $ymm16 = VFNMADD231PDZ256r          $ymm16, $ymm1, $ymm2
2940   $ymm16 = VFNMADD231PDZ256r                   $ymm16, $ymm1, $ymm2                          
2941   ; CHECK: $ymm16 = VFNMADD231PSZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2942   $ymm16 = VFNMADD231PSZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2943   ; CHECK: $ymm16 = VFNMADD231PSZ256r          $ymm16, $ymm1, $ymm2
2944   $ymm16 = VFNMADD231PSZ256r                   $ymm16, $ymm1, $ymm2                          
2945   ; CHECK: $ymm16 = VFNMSUB132PDZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2946   $ymm16 = VFNMSUB132PDZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2947   ; CHECK: $ymm16 = VFNMSUB132PDZ256r          $ymm16, $ymm1, $ymm2
2948   $ymm16 = VFNMSUB132PDZ256r                   $ymm16, $ymm1, $ymm2                          
2949   ; CHECK: $ymm16 = VFNMSUB132PSZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2950   $ymm16 = VFNMSUB132PSZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2951   ; CHECK: $ymm16 = VFNMSUB132PSZ256r          $ymm16, $ymm1, $ymm2
2952   $ymm16 = VFNMSUB132PSZ256r                   $ymm16, $ymm1, $ymm2                          
2953   ; CHECK: $ymm16 = VFNMSUB213PDZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2954   $ymm16 = VFNMSUB213PDZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2955   ; CHECK: $ymm16 = VFNMSUB213PDZ256r          $ymm16, $ymm1, $ymm2
2956   $ymm16 = VFNMSUB213PDZ256r                   $ymm16, $ymm1, $ymm2                          
2957   ; CHECK: $ymm16 = VFNMSUB213PSZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2958   $ymm16 = VFNMSUB213PSZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2959   ; CHECK: $ymm16 = VFNMSUB213PSZ256r          $ymm16, $ymm1, $ymm2
2960   $ymm16 = VFNMSUB213PSZ256r                   $ymm16, $ymm1, $ymm2                          
2961   ; CHECK: $ymm16 = VFNMSUB231PDZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2962   $ymm16 = VFNMSUB231PDZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2963   ; CHECK: $ymm16 = VFNMSUB231PDZ256r          $ymm16, $ymm1, $ymm2
2964   $ymm16 = VFNMSUB231PDZ256r                   $ymm16, $ymm1, $ymm2                          
2965   ; CHECK: $ymm16 = VFNMSUB231PSZ256m          $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg
2966   $ymm16 = VFNMSUB231PSZ256m                   $ymm16, $ymm16, $rsi, 1, $noreg, 0, $noreg              
2967   ; CHECK: $ymm16 = VFNMSUB231PSZ256r          $ymm16, $ymm1, $ymm2  
2968   $ymm16 = VFNMSUB231PSZ256r                   $ymm16, $ymm1, $ymm2                                              
2969   ; CHECK: $ymm16 = VPSRADZ256ri               $ymm16, 7
2970   $ymm16 = VPSRADZ256ri                        $ymm16, 7                                     
2971   ; CHECK: $ymm16 = VPSRADZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2972   $ymm16 = VPSRADZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2973   ; CHECK: $ymm16 = VPSRADZ256rr               $ymm16, $xmm1
2974   $ymm16 = VPSRADZ256rr                        $ymm16, $xmm1                                 
2975   ; CHECK: $ymm16 = VPSRAVDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
2976   $ymm16 = VPSRAVDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
2977   ; CHECK: $ymm16 = VPSRAVDZ256rr              $ymm16, $ymm1
2978   $ymm16 = VPSRAVDZ256rr                       $ymm16, $ymm1                                 
2979   ; CHECK: $ymm16 = VPSRAWZ256ri               $ymm16, 7
2980   $ymm16 = VPSRAWZ256ri                        $ymm16, 7                                     
2981   ; CHECK: $ymm16 = VPSRAWZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2982   $ymm16 = VPSRAWZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2983   ; CHECK: $ymm16 = VPSRAWZ256rr               $ymm16, $xmm1
2984   $ymm16 = VPSRAWZ256rr                        $ymm16, $xmm1                                 
2985   ; CHECK: $ymm16 = VPSRLDQZ256rr              $ymm16, 7
2986   $ymm16 = VPSRLDQZ256rr                       $ymm16, 7
2987   ; CHECK: $ymm16 = VPSRLDZ256ri               $ymm16, 7
2988   $ymm16 = VPSRLDZ256ri                        $ymm16, 7                                     
2989   ; CHECK: $ymm16 = VPSRLDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2990   $ymm16 = VPSRLDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2991   ; CHECK: $ymm16 = VPSRLDZ256rr               $ymm16, $xmm1
2992   $ymm16 = VPSRLDZ256rr                        $ymm16, $xmm1                                 
2993   ; CHECK: $ymm16 = VPSRLQZ256ri               $ymm16, 7
2994   $ymm16 = VPSRLQZ256ri                        $ymm16, 7                                     
2995   ; CHECK: $ymm16 = VPSRLQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
2996   $ymm16 = VPSRLQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
2997   ; CHECK: $ymm16 = VPSRLQZ256rr               $ymm16, $xmm1
2998   $ymm16 = VPSRLQZ256rr                        $ymm16, $xmm1                                 
2999   ; CHECK: $ymm16 = VPSRLVDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
3000   $ymm16 = VPSRLVDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
3001   ; CHECK: $ymm16 = VPSRLVDZ256rr              $ymm16, $ymm1
3002   $ymm16 = VPSRLVDZ256rr                       $ymm16, $ymm1                                 
3003   ; CHECK: $ymm16 = VPSRLVQZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
3004   $ymm16 = VPSRLVQZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
3005   ; CHECK: $ymm16 = VPSRLVQZ256rr              $ymm16, $ymm1
3006   $ymm16 = VPSRLVQZ256rr                       $ymm16, $ymm1                                 
3007   ; CHECK: $ymm16 = VPSRLWZ256ri               $ymm16, 7
3008   $ymm16 = VPSRLWZ256ri                        $ymm16, 7                                     
3009   ; CHECK: $ymm16 = VPSRLWZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
3010   $ymm16 = VPSRLWZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
3011   ; CHECK: $ymm16 = VPSRLWZ256rr               $ymm16, $xmm1  
3012   $ymm16 = VPSRLWZ256rr                        $ymm16, $xmm1                                               
3013   ; CHECK: $ymm16 = VPMOVSXBDZ256rm            $rip, 1, $rax, 0, $noreg
3014   $ymm16 = VPMOVSXBDZ256rm                     $rip, 1, $rax, 0, $noreg
3015   ; CHECK: $ymm16 = VPMOVSXBDZ256rr            $xmm0
3016   $ymm16 = VPMOVSXBDZ256rr                     $xmm0                                         
3017   ; CHECK: $ymm16 = VPMOVSXBQZ256rm            $rip, 1, $rax, 0, $noreg
3018   $ymm16 = VPMOVSXBQZ256rm                     $rip, 1, $rax, 0, $noreg
3019   ; CHECK: $ymm16 = VPMOVSXBQZ256rr            $xmm0
3020   $ymm16 = VPMOVSXBQZ256rr                     $xmm0                                         
3021   ; CHECK: $ymm16 = VPMOVSXBWZ256rm            $rip, 1, $rax, 0, $noreg
3022   $ymm16 = VPMOVSXBWZ256rm                     $rip, 1, $rax, 0, $noreg
3023   ; CHECK: $ymm16 = VPMOVSXBWZ256rr            $xmm0
3024   $ymm16 = VPMOVSXBWZ256rr                     $xmm0                                         
3025   ; CHECK: $ymm16 = VPMOVSXDQZ256rm            $rip, 1, $rax, 0, $noreg
3026   $ymm16 = VPMOVSXDQZ256rm                     $rip, 1, $rax, 0, $noreg
3027   ; CHECK: $ymm16 = VPMOVSXDQZ256rr            $xmm0
3028   $ymm16 = VPMOVSXDQZ256rr                     $xmm0                                         
3029   ; CHECK: $ymm16 = VPMOVSXWDZ256rm            $rip, 1, $rax, 0, $noreg
3030   $ymm16 = VPMOVSXWDZ256rm                     $rip, 1, $rax, 0, $noreg
3031   ; CHECK: $ymm16 = VPMOVSXWDZ256rr            $xmm0
3032   $ymm16 = VPMOVSXWDZ256rr                     $xmm0                                         
3033   ; CHECK: $ymm16 = VPMOVSXWQZ256rm            $rip, 1, $rax, 0, $noreg
3034   $ymm16 = VPMOVSXWQZ256rm                     $rip, 1, $rax, 0, $noreg
3035   ; CHECK: $ymm16 = VPMOVSXWQZ256rr            $xmm0
3036   $ymm16 = VPMOVSXWQZ256rr                     $xmm0                                         
3037   ; CHECK: $ymm16 = VPMOVZXBDZ256rm            $rip, 1, $rax, 0, $noreg
3038   $ymm16 = VPMOVZXBDZ256rm                     $rip, 1, $rax, 0, $noreg
3039   ; CHECK: $ymm16 = VPMOVZXBDZ256rr            $xmm0
3040   $ymm16 = VPMOVZXBDZ256rr                     $xmm0                                         
3041   ; CHECK: $ymm16 = VPMOVZXBQZ256rm            $rip, 1, $rax, 0, $noreg
3042   $ymm16 = VPMOVZXBQZ256rm                     $rip, 1, $rax, 0, $noreg
3043   ; CHECK: $ymm16 = VPMOVZXBQZ256rr            $xmm0
3044   $ymm16 = VPMOVZXBQZ256rr                     $xmm0                                         
3045   ; CHECK: $ymm16 = VPMOVZXBWZ256rm            $rip, 1, $rax, 0, $noreg
3046   $ymm16 = VPMOVZXBWZ256rm                     $rip, 1, $rax, 0, $noreg
3047   ; CHECK: $ymm16 = VPMOVZXBWZ256rr            $xmm0
3048   $ymm16 = VPMOVZXBWZ256rr                     $xmm0                                         
3049   ; CHECK: $ymm16 = VPMOVZXDQZ256rm            $rip, 1, $rax, 0, $noreg
3050   $ymm16 = VPMOVZXDQZ256rm                     $rip, 1, $rax, 0, $noreg
3051   ; CHECK: $ymm16 = VPMOVZXDQZ256rr            $xmm0
3052   $ymm16 = VPMOVZXDQZ256rr                     $xmm0                                         
3053   ; CHECK: $ymm16 = VPMOVZXWDZ256rm            $rip, 1, $rax, 0, $noreg
3054   $ymm16 = VPMOVZXWDZ256rm                     $rip, 1, $rax, 0, $noreg
3055   ; CHECK: $ymm16 = VPMOVZXWDZ256rr            $xmm0
3056   $ymm16 = VPMOVZXWDZ256rr                     $xmm0                                         
3057   ; CHECK: $ymm16 = VPMOVZXWQZ256rm            $rip, 1, $rax, 0, $noreg
3058   $ymm16 = VPMOVZXWQZ256rm                     $rip, 1, $rax, 0, $noreg
3059   ; CHECK: $ymm16 = VPMOVZXWQZ256rr            $xmm0    
3060   $ymm16 = VPMOVZXWQZ256rr                     $xmm0                                                 
3061   ; CHECK: $ymm16 = VBROADCASTF32X2Z256m       $rip, 1, $rax, 0, $noreg
3062   $ymm16 = VBROADCASTF32X2Z256m                $rip, 1, $rax, 0, $noreg
3063   ; CHECK: $ymm16 = VBROADCASTF32X2Z256r       $xmm16
3064   $ymm16 = VBROADCASTF32X2Z256r                $xmm16
3065   ; CHECK: $ymm16 = VBROADCASTF32X4Z256rm      $rip, 1, $rax, 0, $noreg
3066   $ymm16 = VBROADCASTF32X4Z256rm               $rip, 1, $rax, 0, $noreg
3067   ; CHECK: $ymm16 = VBROADCASTSDZ256m          $rip, 1, $rax, 0, $noreg
3068   $ymm16 = VBROADCASTSDZ256m                   $rip, 1, $rax, 0, $noreg
3069   ; CHECK: $ymm16 = VBROADCASTSDZ256r          $xmm0
3070   $ymm16 = VBROADCASTSDZ256r                   $xmm0                                         
3071   ; CHECK: $ymm16 = VBROADCASTSSZ256m          $rip, 1, $rax, 0, $noreg
3072   $ymm16 = VBROADCASTSSZ256m                   $rip, 1, $rax, 0, $noreg
3073   ; CHECK: $ymm16 = VBROADCASTSSZ256r          $xmm0
3074   $ymm16 = VBROADCASTSSZ256r                   $xmm0                                         
3075   ; CHECK: $ymm16 = VPBROADCASTBZ256m          $rip, 1, $rax, 0, $noreg
3076   $ymm16 = VPBROADCASTBZ256m                   $rip, 1, $rax, 0, $noreg
3077   ; CHECK: $ymm16 = VPBROADCASTBZ256r          $xmm0
3078   $ymm16 = VPBROADCASTBZ256r                   $xmm0                                         
3079   ; CHECK: $ymm16 = VPBROADCASTDZ256m          $rip, 1, $rax, 0, $noreg
3080   $ymm16 = VPBROADCASTDZ256m                   $rip, 1, $rax, 0, $noreg
3081   ; CHECK: $ymm16 = VPBROADCASTDZ256r          $xmm0
3082   $ymm16 = VPBROADCASTDZ256r                   $xmm0                                         
3083   ; CHECK: $ymm16 = VPBROADCASTWZ256m          $rip, 1, $rax, 0, $noreg
3084   $ymm16 = VPBROADCASTWZ256m                   $rip, 1, $rax, 0, $noreg
3085   ; CHECK: $ymm16 = VPBROADCASTWZ256r          $xmm0
3086   $ymm16 = VPBROADCASTWZ256r                   $xmm0                                         
3087   ; CHECK: $ymm16 = VBROADCASTI32X4Z256rm      $rip, 1, $rax, 0, $noreg
3088   $ymm16 = VBROADCASTI32X4Z256rm               $rip, 1, $rax, 0, $noreg
3089   ; CHECK: $ymm16 = VBROADCASTI32X2Z256m       $rip, 1, $rax, 0, $noreg
3090   $ymm16 = VBROADCASTI32X2Z256m                $rip, 1, $rax, 0, $noreg
3091   ; CHECK: $ymm16 = VBROADCASTI32X2Z256r       $xmm16
3092   $ymm16 = VBROADCASTI32X2Z256r                $xmm16
3093   ; CHECK: $ymm16 = VPBROADCASTQZ256m          $rip, 1, $rax, 0, $noreg
3094   $ymm16 = VPBROADCASTQZ256m                   $rip, 1, $rax, 0, $noreg
3095   ; CHECK: $ymm16 = VPBROADCASTQZ256r          $xmm0  
3096   $ymm16 = VPBROADCASTQZ256r                   $xmm0                                               
3097   ; CHECK: $ymm16 = VPABSBZ256rm               $rip, 1, $rax, 0, $noreg
3098   $ymm16 = VPABSBZ256rm                        $rip, 1, $rax, 0, $noreg
3099   ; CHECK: $ymm16 = VPABSBZ256rr               $ymm16
3100   $ymm16 = VPABSBZ256rr                        $ymm16                                        
3101   ; CHECK: $ymm16 = VPABSDZ256rm               $rip, 1, $rax, 0, $noreg
3102   $ymm16 = VPABSDZ256rm                        $rip, 1, $rax, 0, $noreg
3103   ; CHECK: $ymm16 = VPABSDZ256rr               $ymm16
3104   $ymm16 = VPABSDZ256rr                        $ymm16                                        
3105   ; CHECK: $ymm16 = VPABSWZ256rm               $rip, 1, $rax, 0, $noreg
3106   $ymm16 = VPABSWZ256rm                        $rip, 1, $rax, 0, $noreg
3107   ; CHECK: $ymm16 = VPABSWZ256rr               $ymm16  
3108   $ymm16 = VPABSWZ256rr                        $ymm16                                               
3109   ; CHECK: $ymm16 = VPSADBWZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
3110   $ymm16 = VPSADBWZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
3111   ; CHECK: $ymm16 = VPSADBWZ256rr              $ymm16, $ymm1  
3112   $ymm16 = VPSADBWZ256rr                       $ymm16, $ymm1                                               
3113   ; CHECK: $ymm16 = VPERMDZ256rm               $ymm16, $rdi, 1, $noreg, 0, $noreg
3114   $ymm16 = VPERMDZ256rm                        $ymm16, $rdi, 1, $noreg, 0, $noreg                      
3115   ; CHECK: $ymm16 = VPERMDZ256rr               $ymm1, $ymm16
3116   $ymm16 = VPERMDZ256rr                        $ymm1, $ymm16                                 
3117   ; CHECK: $ymm16 = VPERMILPDZ256mi            $rdi, 1, $noreg, 0, $noreg, 7
3118   $ymm16 = VPERMILPDZ256mi                     $rdi, 1, $noreg, 0, $noreg, 7
3119   ; CHECK: $ymm16 = VPERMILPDZ256ri            $ymm16, 7
3120   $ymm16 = VPERMILPDZ256ri                     $ymm16, 7                                     
3121   ; CHECK: $ymm16 = VPERMILPDZ256rm            $ymm16, $rdi, 1, $noreg, 0, $noreg
3122   $ymm16 = VPERMILPDZ256rm                     $ymm16, $rdi, 1, $noreg, 0, $noreg                      
3123   ; CHECK: $ymm16 = VPERMILPDZ256rr            $ymm1, $ymm16
3124   $ymm16 = VPERMILPDZ256rr                     $ymm1, $ymm16                                 
3125   ; CHECK: $ymm16 = VPERMILPSZ256mi            $rdi, 1, $noreg, 0, $noreg, 7
3126   $ymm16 = VPERMILPSZ256mi                     $rdi, 1, $noreg, 0, $noreg, 7
3127   ; CHECK: $ymm16 = VPERMILPSZ256ri            $ymm16, 7
3128   $ymm16 = VPERMILPSZ256ri                     $ymm16, 7                                     
3129   ; CHECK: $ymm16 = VPERMILPSZ256rm            $ymm16, $rdi, 1, $noreg, 0, $noreg
3130   $ymm16 = VPERMILPSZ256rm                     $ymm16, $rdi, 1, $noreg, 0, $noreg                      
3131   ; CHECK: $ymm16 = VPERMILPSZ256rr            $ymm1, $ymm16
3132   $ymm16 = VPERMILPSZ256rr                     $ymm1, $ymm16                                 
3133   ; CHECK: $ymm16 = VPERMPDZ256mi              $rdi, 1, $noreg, 0, $noreg, 7
3134   $ymm16 = VPERMPDZ256mi                       $rdi, 1, $noreg, 0, $noreg, 7
3135   ; CHECK: $ymm16 = VPERMPDZ256ri              $ymm16, 7
3136   $ymm16 = VPERMPDZ256ri                       $ymm16, 7                                     
3137   ; CHECK: $ymm16 = VPERMPSZ256rm              $ymm16, $rdi, 1, $noreg, 0, $noreg
3138   $ymm16 = VPERMPSZ256rm                       $ymm16, $rdi, 1, $noreg, 0, $noreg                      
3139   ; CHECK: $ymm16 = VPERMPSZ256rr              $ymm1, $ymm16
3140   $ymm16 = VPERMPSZ256rr                       $ymm1, $ymm16                                 
3141   ; CHECK: $ymm16 = VPERMQZ256mi               $rdi, 1, $noreg, 0, $noreg, 7
3142   $ymm16 = VPERMQZ256mi                        $rdi, 1, $noreg, 0, $noreg, 7
3143   ; CHECK: $ymm16 = VPERMQZ256ri               $ymm16, 7
3144   $ymm16 = VPERMQZ256ri                        $ymm16, 7                                               
3145   ; CHECK: $ymm16 = VPSLLDQZ256rr              $ymm16, 14
3146   $ymm16 = VPSLLDQZ256rr                       $ymm16, 14
3147   ; CHECK: $ymm16 = VPSLLDZ256ri               $ymm16, 7
3148   $ymm16 = VPSLLDZ256ri                        $ymm16, 7                                     
3149   ; CHECK: $ymm16 = VPSLLDZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
3150   $ymm16 = VPSLLDZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
3151   ; CHECK: $ymm16 = VPSLLDZ256rr               $ymm16, $xmm16
3152   $ymm16 = VPSLLDZ256rr                        $ymm16, $xmm16
3153   ; CHECK: $ymm16 = VPSLLQZ256ri               $ymm16, 7
3154   $ymm16 = VPSLLQZ256ri                        $ymm16, 7                                     
3155   ; CHECK: $ymm16 = VPSLLQZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
3156   $ymm16 = VPSLLQZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
3157   ; CHECK: $ymm16 = VPSLLQZ256rr               $ymm16, $xmm16
3158   $ymm16 = VPSLLQZ256rr                        $ymm16, $xmm16
3159   ; CHECK: $ymm16 = VPSLLVDZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
3160   $ymm16 = VPSLLVDZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
3161   ; CHECK: $ymm16 = VPSLLVDZ256rr              $ymm16, $ymm16
3162   $ymm16 = VPSLLVDZ256rr                       $ymm16, $ymm16
3163   ; CHECK: $ymm16 = VPSLLVQZ256rm              $ymm16, $rip, 1, $rax, 0, $noreg
3164   $ymm16 = VPSLLVQZ256rm                       $ymm16, $rip, 1, $rax, 0, $noreg
3165   ; CHECK: $ymm16 = VPSLLVQZ256rr              $ymm16, $ymm16
3166   $ymm16 = VPSLLVQZ256rr                       $ymm16, $ymm16
3167   ; CHECK: $ymm16 = VPSLLWZ256ri               $ymm16, 7
3168   $ymm16 = VPSLLWZ256ri                        $ymm16, 7                                     
3169   ; CHECK: $ymm16 = VPSLLWZ256rm               $ymm16, $rip, 1, $rax, 0, $noreg
3170   $ymm16 = VPSLLWZ256rm                        $ymm16, $rip, 1, $rax, 0, $noreg
3171   ; CHECK: $ymm16 = VPSLLWZ256rr               $ymm16, $xmm16
3172   $ymm16 = VPSLLWZ256rr                        $ymm16, $xmm16
3173   ; CHECK: $ymm16 = VCVTDQ2PDZ256rm            $rdi, 1, $noreg, 0, $noreg
3174   $ymm16 = VCVTDQ2PDZ256rm                     $rdi, 1, $noreg, 0, $noreg
3175   ; CHECK: $ymm16 = VCVTDQ2PDZ256rr            $xmm0
3176   $ymm16 = VCVTDQ2PDZ256rr                     $xmm0                                         
3177   ; CHECK: $ymm16 = VCVTDQ2PSZ256rm            $rdi, 1, $noreg, 0, $noreg
3178   $ymm16 = VCVTDQ2PSZ256rm                     $rdi, 1, $noreg, 0, $noreg
3179   ; CHECK: $ymm16 = VCVTDQ2PSZ256rr            $ymm16
3180   $ymm16 = VCVTDQ2PSZ256rr                     $ymm16                                        
3181   ; CHECK: $xmm16 = VCVTPD2DQZ256rm            $rdi, 1, $noreg, 0, $noreg
3182   $xmm16 = VCVTPD2DQZ256rm                     $rdi, 1, $noreg, 0, $noreg
3183   ; CHECK: $xmm16 = VCVTPD2DQZ256rr            $ymm16
3184   $xmm16 = VCVTPD2DQZ256rr                     $ymm16                                        
3185   ; CHECK: $xmm16 = VCVTPD2PSZ256rm            $rdi, 1, $noreg, 0, $noreg
3186   $xmm16 = VCVTPD2PSZ256rm                     $rdi, 1, $noreg, 0, $noreg
3187   ; CHECK: $xmm16 = VCVTPD2PSZ256rr            $ymm16
3188   $xmm16 = VCVTPD2PSZ256rr                     $ymm16                                        
3189   ; CHECK: $ymm16 = VCVTPS2DQZ256rm            $rdi, 1, $noreg, 0, $noreg
3190   $ymm16 = VCVTPS2DQZ256rm                     $rdi, 1, $noreg, 0, $noreg
3191   ; CHECK: $ymm16 = VCVTPS2DQZ256rr            $ymm16  
3192   $ymm16 = VCVTPS2DQZ256rr                     $ymm16                                        
3193   ; CHECK: $ymm16 = VCVTPS2PDZ256rm            $rdi, 1, $noreg, 0, $noreg
3194   $ymm16 = VCVTPS2PDZ256rm                     $rdi, 1, $noreg, 0, $noreg
3195   ; CHECK: $ymm16 = VCVTPS2PDZ256rr            $xmm0
3196   $ymm16 = VCVTPS2PDZ256rr                     $xmm0                                               
3197   ; CHECK: VCVTPS2PHZ256mr                     $rdi, 1, $noreg, 0, $noreg, $ymm16, 0
3198   VCVTPS2PHZ256mr                              $rdi, 1, $noreg, 0, $noreg, $ymm16, 0
3199   ; CHECK: $xmm0 = VCVTPS2PHZ256rr             $ymm16, 0
3200   $xmm0 = VCVTPS2PHZ256rr                      $ymm16, 0
3201   ; CHECK: $ymm16 = VCVTPH2PSZ256rm            $rdi, 1, $noreg, 0, $noreg
3202   $ymm16 = VCVTPH2PSZ256rm                     $rdi, 1, $noreg, 0, $noreg
3203   ; CHECK: $ymm16 = VCVTPH2PSZ256rr            $xmm16
3204   $ymm16 = VCVTPH2PSZ256rr                     $xmm16
3205   ; CHECK: $xmm16 = VCVTTPD2DQZ256rm           $rdi, 1, $noreg, 0, $noreg
3206   $xmm16 = VCVTTPD2DQZ256rm                    $rdi, 1, $noreg, 0, $noreg
3207   ; CHECK: $xmm16 = VCVTTPD2DQZ256rr           $ymm16
3208   $xmm16 = VCVTTPD2DQZ256rr                    $ymm16                                        
3209   ; CHECK: $ymm16 = VCVTTPS2DQZ256rm           $rdi, 1, $noreg, 0, $noreg
3210   $ymm16 = VCVTTPS2DQZ256rm                    $rdi, 1, $noreg, 0, $noreg
3211   ; CHECK: $ymm16 = VCVTTPS2DQZ256rr           $ymm16  
3212   $ymm16 = VCVTTPS2DQZ256rr                    $ymm16                                               
3213   ; CHECK: $ymm16 = VSQRTPDZ256m               $rdi, 1, $noreg, 0, $noreg
3214   $ymm16 = VSQRTPDZ256m                        $rdi, 1, $noreg, 0, $noreg
3215   ; CHECK: $ymm16 = VSQRTPDZ256r               $ymm16
3216   $ymm16 = VSQRTPDZ256r                        $ymm16                                        
3217   ; CHECK: $ymm16 = VSQRTPSZ256m               $rdi, 1, $noreg, 0, $noreg
3218   $ymm16 = VSQRTPSZ256m                        $rdi, 1, $noreg, 0, $noreg
3219   ; CHECK: $ymm16 = VSQRTPSZ256r               $ymm16    
3220   $ymm16 = VSQRTPSZ256r                        $ymm16                                                 
3221   ; CHECK: $ymm16 = VPALIGNRZ256rmi            $ymm16, $rdi, 1, $noreg, 0, $noreg, 1
3222   $ymm16 = VPALIGNRZ256rmi                     $ymm16, $rdi, 1, $noreg, 0, $noreg, 1
3223   ; CHECK: $ymm16 = VPALIGNRZ256rri            $ymm16, $ymm1, 1
3224   $ymm16 = VPALIGNRZ256rri                     $ymm16, $ymm1, 1
3225   ; CHECK: $ymm16 = VMOVUPSZ256rm              $rdi, 1, $noreg, 0, $noreg       
3226   $ymm16 = VMOVUPSZ256rm                       $rdi, 1, $noreg, 0, $noreg                              
3227   ; CHECK: $ymm16 = VMOVUPSZ256rr              $ymm16
3228   $ymm16 = VMOVUPSZ256rr                       $ymm16                                        
3229   ; CHECK: $ymm16 = VMOVUPSZ256rr_REV          $ymm16   
3230   $ymm16 = VMOVUPSZ256rr_REV                   $ymm16                                                
3231   ; CHECK: $ymm16 = VPSHUFBZ256rm              $ymm16, $rdi, 1, $noreg, 0, $noreg
3232   $ymm16 = VPSHUFBZ256rm                       $ymm16, $rdi, 1, $noreg, 0, $noreg
3233   ; CHECK: $ymm16 = VPSHUFBZ256rr              $ymm16, $ymm1
3234   $ymm16 = VPSHUFBZ256rr                       $ymm16, $ymm1                                 
3235   ; CHECK: $ymm16 = VPSHUFDZ256mi              $rdi, 1, $noreg, 0, $noreg, -24
3236   $ymm16 = VPSHUFDZ256mi                       $rdi, 1, $noreg, 0, $noreg, -24
3237   ; CHECK: $ymm16 = VPSHUFDZ256ri              $ymm16, -24
3238   $ymm16 = VPSHUFDZ256ri                       $ymm16, -24                                   
3239   ; CHECK: $ymm16 = VPSHUFHWZ256mi             $rdi, 1, $noreg, 0, $noreg, -24
3240   $ymm16 = VPSHUFHWZ256mi                      $rdi, 1, $noreg, 0, $noreg, -24
3241   ; CHECK: $ymm16 = VPSHUFHWZ256ri             $ymm16, -24
3242   $ymm16 = VPSHUFHWZ256ri                      $ymm16, -24                                   
3243   ; CHECK: $ymm16 = VPSHUFLWZ256mi             $rdi, 1, $noreg, 0, $noreg, -24
3244   $ymm16 = VPSHUFLWZ256mi                      $rdi, 1, $noreg, 0, $noreg, -24
3245   ; CHECK: $ymm16 = VPSHUFLWZ256ri             $ymm16, -24
3246   $ymm16 = VPSHUFLWZ256ri                      $ymm16, -24                                   
3247   ; CHECK: $ymm16 = VSHUFPDZ256rmi             $ymm16, $rip, 1, $rax, 0, $noreg, -24
3248   $ymm16 = VSHUFPDZ256rmi                      $ymm16, $rip, 1, $rax, 0, $noreg, -24
3249   ; CHECK: $ymm16 = VSHUFPDZ256rri             $ymm16, $ymm1, -24
3250   $ymm16 = VSHUFPDZ256rri                      $ymm16, $ymm1, -24
3251   ; CHECK: $ymm16 = VSHUFPSZ256rmi             $ymm16, $rip, 1, $rax, 0, $noreg, -24
3252   $ymm16 = VSHUFPSZ256rmi                      $ymm16, $rip, 1, $rax, 0, $noreg, -24
3253   ; CHECK: $ymm16 = VSHUFPSZ256rri             $ymm16, $ymm1, -24
3254   $ymm16 = VSHUFPSZ256rri                      $ymm16, $ymm1, -24
3255   ; CHECK: $ymm16 = VRNDSCALEPDZ256rmi         $rip, 1, $rax, 0, $noreg, 15
3256   $ymm16 = VRNDSCALEPDZ256rmi                  $rip, 1, $rax, 0, $noreg, 15
3257   ; CHECK: $ymm16 = VRNDSCALEPDZ256rri         $ymm16, 15
3258   $ymm16 = VRNDSCALEPDZ256rri                  $ymm16, 15
3259   ; CHECK: $ymm16 = VRNDSCALEPSZ256rmi         $rip, 1, $rax, 0, $noreg, 15
3260   $ymm16 = VRNDSCALEPSZ256rmi                  $rip, 1, $rax, 0, $noreg, 15
3261   ; CHECK: $ymm16 = VRNDSCALEPSZ256rri         $ymm16, 15
3262   $ymm16 = VRNDSCALEPSZ256rri                  $ymm16, 15
3263   ; CHECK: $ymm0 = VRNDSCALEPDZ256rmi          $rip, 1, $rax, 0, $noreg, 31
3264   $ymm0 = VRNDSCALEPDZ256rmi                   $rip, 1, $rax, 0, $noreg, 31
3265   ; CHECK: $ymm0 = VRNDSCALEPDZ256rri          $ymm0, 31
3266   $ymm0 = VRNDSCALEPDZ256rri                   $ymm0, 31
3267   ; CHECK: $ymm0 = VRNDSCALEPSZ256rmi          $rip, 1, $rax, 0, $noreg, 31
3268   $ymm0 = VRNDSCALEPSZ256rmi                   $rip, 1, $rax, 0, $noreg, 31
3269   ; CHECK: $ymm0 = VRNDSCALEPSZ256rri          $ymm0, 31
3270   $ymm0 = VRNDSCALEPSZ256rri                   $ymm0, 31
3271   ; CHECK: $ymm16 = VSHUFF32X4Z256rmi          $ymm16, $rip, 1, $rax, 0, $noreg, 228
3272   $ymm16 = VSHUFF32X4Z256rmi                   $ymm16, $rip, 1, $rax, 0, $noreg, 228
3273   ; CHECK: $ymm16 = VSHUFF32X4Z256rri          $ymm16, $ymm1, 228
3274   $ymm16 = VSHUFF32X4Z256rri                   $ymm16, $ymm1, 228
3275   ; CHECK: $ymm16 = VSHUFF64X2Z256rmi          $ymm16, $rip, 1, $rax, 0, $noreg, 228
3276   $ymm16 = VSHUFF64X2Z256rmi                   $ymm16, $rip, 1, $rax, 0, $noreg, 228
3277   ; CHECK: $ymm16 = VSHUFF64X2Z256rri          $ymm16, $ymm1, 228
3278   $ymm16 = VSHUFF64X2Z256rri                   $ymm16, $ymm1, 228
3279   ; CHECK: $ymm16 = VSHUFI32X4Z256rmi          $ymm16, $rip, 1, $rax, 0, $noreg, 228
3280   $ymm16 = VSHUFI32X4Z256rmi                   $ymm16, $rip, 1, $rax, 0, $noreg, 228
3281   ; CHECK: $ymm16 = VSHUFI32X4Z256rri          $ymm16, $ymm1, 228
3282   $ymm16 = VSHUFI32X4Z256rri                   $ymm16, $ymm1, 228
3283   ; CHECK: $ymm16 = VSHUFI64X2Z256rmi          $ymm16, $rip, 1, $rax, 0, $noreg, 228
3284   $ymm16 = VSHUFI64X2Z256rmi                   $ymm16, $rip, 1, $rax, 0, $noreg, 228
3285   ; CHECK: $ymm16 = VSHUFI64X2Z256rri          $ymm16, $ymm1, 228
3286   $ymm16 = VSHUFI64X2Z256rri                   $ymm16, $ymm1, 228
3288    RET 0, $zmm0, $zmm1 
3289 ...                                            
3290 ---                                            
3291   # CHECK-LABEL: name: evex_z128_to_evex_test
3292   # CHECK: bb.0:
3294 name: evex_z128_to_evex_test
3295 body: |
3296   bb.0:
3297   ; CHECK: VMOVAPDZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3298   VMOVAPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3299   ; CHECK: $xmm16 = VMOVAPDZ128rm              $rip, 1, $rax, 0, $noreg
3300   $xmm16 = VMOVAPDZ128rm                       $rip, 1, $rax, 0, $noreg
3301   ; CHECK: $xmm16 = VMOVAPDZ128rr              $xmm16
3302   $xmm16 = VMOVAPDZ128rr                       $xmm16                                                    
3303   ; CHECK: VMOVAPSZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3304   VMOVAPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3305   ; CHECK: $xmm16 = VMOVAPSZ128rm              $rip, 1, $rax, 0, $noreg
3306   $xmm16 = VMOVAPSZ128rm                       $rip, 1, $rax, 0, $noreg
3307   ; CHECK: $xmm16 = VMOVAPSZ128rr              $xmm16  
3308   $xmm16 = VMOVAPSZ128rr                       $xmm16                                                    
3309   ; CHECK: VMOVDQA32Z128mr                     $rdi, 1, $noreg, 0, $noreg, $xmm16
3310   VMOVDQA32Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3311   ; CHECK: $xmm16 = VMOVDQA32Z128rm            $rip, 1, $rax, 0, $noreg
3312   $xmm16 = VMOVDQA32Z128rm                     $rip, 1, $rax, 0, $noreg
3313   ; CHECK: $xmm16 = VMOVDQA32Z128rr            $xmm16
3314   $xmm16 = VMOVDQA32Z128rr                     $xmm16                                                    
3315   ; CHECK: VMOVDQA64Z128mr                     $rdi, 1, $noreg, 0, $noreg, $xmm16
3316   VMOVDQA64Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3317   ; CHECK: $xmm16 = VMOVDQA64Z128rm            $rip, 1, $rax, 0, $noreg
3318   $xmm16 = VMOVDQA64Z128rm                     $rip, 1, $rax, 0, $noreg
3319   ; CHECK: $xmm16 = VMOVDQA64Z128rr            $xmm16
3320   $xmm16 = VMOVDQA64Z128rr                     $xmm16                                                    
3321   ; CHECK: VMOVDQU16Z128mr                     $rdi, 1, $noreg, 0, $noreg, $xmm16
3322   VMOVDQU16Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3323   ; CHECK: $xmm16 = VMOVDQU16Z128rm            $rip, 1, $rax, 0, $noreg
3324   $xmm16 = VMOVDQU16Z128rm                     $rip, 1, $rax, 0, $noreg
3325   ; CHECK: $xmm16 = VMOVDQU16Z128rr            $xmm16
3326   $xmm16 = VMOVDQU16Z128rr                     $xmm16                                                    
3327   ; CHECK: VMOVDQU32Z128mr                     $rdi, 1, $noreg, 0, $noreg, $xmm16
3328   VMOVDQU32Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3329   ; CHECK: $xmm16 = VMOVDQU32Z128rm            $rip, 1, $rax, 0, $noreg
3330   $xmm16 = VMOVDQU32Z128rm                     $rip, 1, $rax, 0, $noreg
3331   ; CHECK: $xmm16 = VMOVDQU32Z128rr            $xmm16
3332   $xmm16 = VMOVDQU32Z128rr                     $xmm16                                                    
3333   ; CHECK: VMOVDQU64Z128mr                     $rdi, 1, $noreg, 0, $noreg, $xmm16
3334   VMOVDQU64Z128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3335   ; CHECK: $xmm16 = VMOVDQU64Z128rm            $rip, 1, $rax, 0, $noreg
3336   $xmm16 = VMOVDQU64Z128rm                     $rip, 1, $rax, 0, $noreg
3337   ; CHECK: $xmm16 = VMOVDQU64Z128rr            $xmm16
3338   $xmm16 = VMOVDQU64Z128rr                     $xmm16                                                    
3339   ; CHECK: VMOVDQU8Z128mr                      $rdi, 1, $noreg, 0, $noreg, $xmm16
3340   VMOVDQU8Z128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3341   ; CHECK: $xmm16 = VMOVDQU8Z128rm             $rip, 1, $rax, 0, $noreg
3342   $xmm16 = VMOVDQU8Z128rm                      $rip, 1, $rax, 0, $noreg
3343   ; CHECK: $xmm16 = VMOVDQU8Z128rr             $xmm16
3344   $xmm16 = VMOVDQU8Z128rr                      $xmm16                                                    
3345   ; CHECK: $xmm16 = VMOVDQU8Z128rr_REV         $xmm16
3346   $xmm16 = VMOVDQU8Z128rr_REV                  $xmm16                                                    
3347   ; CHECK: $xmm16 = VMOVNTDQAZ128rm            $rip, 1, $rax, 0, $noreg
3348   $xmm16 = VMOVNTDQAZ128rm                     $rip, 1, $rax, 0, $noreg
3349   ; CHECK: VMOVUPDZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3350   VMOVUPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3351   ; CHECK: $xmm16 = VMOVUPDZ128rm              $rip, 1, $rax, 0, $noreg
3352   $xmm16 = VMOVUPDZ128rm                       $rip, 1, $rax, 0, $noreg
3353   ; CHECK: $xmm16 = VMOVUPDZ128rr              $xmm16
3354   $xmm16 = VMOVUPDZ128rr                       $xmm16                                                    
3355   ; CHECK: $xmm16 = VMOVUPDZ128rr_REV          $xmm16
3356   $xmm16 = VMOVUPDZ128rr_REV                   $xmm16                                                    
3357   ; CHECK: VMOVUPSZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3358   VMOVUPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3359   ; CHECK: $xmm16 = VMOVUPSZ128rm              $rip, 1, $rax, 0, $noreg
3360   $xmm16 = VMOVUPSZ128rm                       $rip, 1, $rax, 0, $noreg
3361   ; CHECK: $xmm16 = VMOVUPSZ128rr              $xmm16
3362   $xmm16 = VMOVUPSZ128rr                       $xmm16                                                    
3363   ; CHECK: $xmm16 = VMOVUPSZ128rr_REV          $xmm16
3364   $xmm16 = VMOVUPSZ128rr_REV                   $xmm16                                                    
3365   ; CHECK: VMOVNTDQZ128mr                      $rdi, 1, $noreg, 0, $noreg, $xmm16
3366   VMOVNTDQZ128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3367   ; CHECK: VMOVNTPDZ128mr                      $rdi, 1, $noreg, 0, $noreg, $xmm16
3368   VMOVNTPDZ128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3369   ; CHECK: VMOVNTPSZ128mr                      $rdi, 1, $noreg, 0, $noreg, $xmm16
3370   VMOVNTPSZ128mr                               $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3371   ; CHECK: $xmm16 = VMOVAPDZ128rr_REV          $xmm16
3372   $xmm16 = VMOVAPDZ128rr_REV                   $xmm16                                                    
3373   ; CHECK: $xmm16 = VMOVAPSZ128rr_REV          $xmm16
3374   $xmm16 = VMOVAPSZ128rr_REV                   $xmm16                                                    
3375   ; CHECK: $xmm16 = VMOVDQA32Z128rr_REV        $xmm16
3376   $xmm16 = VMOVDQA32Z128rr_REV                 $xmm16                                                    
3377   ; CHECK: $xmm16 = VMOVDQA64Z128rr_REV        $xmm16
3378   $xmm16 = VMOVDQA64Z128rr_REV                 $xmm16                                                    
3379   ; CHECK: $xmm16 = VMOVDQU16Z128rr_REV        $xmm16
3380   $xmm16 = VMOVDQU16Z128rr_REV                 $xmm16                                                    
3381   ; CHECK: $xmm16 = VMOVDQU32Z128rr_REV        $xmm16
3382   $xmm16 = VMOVDQU32Z128rr_REV                 $xmm16                                                    
3383   ; CHECK: $xmm16 = VMOVDQU64Z128rr_REV        $xmm16
3384   $xmm16 = VMOVDQU64Z128rr_REV                 $xmm16                                                    
3385   ; CHECK: $xmm16 = VPMOVSXBDZ128rm            $rip, 1, $rax, 0, $noreg
3386   $xmm16 = VPMOVSXBDZ128rm                     $rip, 1, $rax, 0, $noreg
3387   ; CHECK: $xmm16 = VPMOVSXBDZ128rr            $xmm16
3388   $xmm16 = VPMOVSXBDZ128rr                     $xmm16                                                    
3389   ; CHECK: $xmm16 = VPMOVSXBQZ128rm            $rip, 1, $rax, 0, $noreg
3390   $xmm16 = VPMOVSXBQZ128rm                     $rip, 1, $rax, 0, $noreg
3391   ; CHECK: $xmm16 = VPMOVSXBQZ128rr            $xmm16
3392   $xmm16 = VPMOVSXBQZ128rr                     $xmm16                                                    
3393   ; CHECK: $xmm16 = VPMOVSXBWZ128rm            $rip, 1, $rax, 0, $noreg
3394   $xmm16 = VPMOVSXBWZ128rm                     $rip, 1, $rax, 0, $noreg
3395   ; CHECK: $xmm16 = VPMOVSXBWZ128rr            $xmm16
3396   $xmm16 = VPMOVSXBWZ128rr                     $xmm16                                                    
3397   ; CHECK: $xmm16 = VPMOVSXDQZ128rm            $rip, 1, $rax, 0, $noreg
3398   $xmm16 = VPMOVSXDQZ128rm                     $rip, 1, $rax, 0, $noreg
3399   ; CHECK: $xmm16 = VPMOVSXDQZ128rr            $xmm16
3400   $xmm16 = VPMOVSXDQZ128rr                     $xmm16                                                    
3401   ; CHECK: $xmm16 = VPMOVSXWDZ128rm            $rip, 1, $rax, 0, $noreg
3402   $xmm16 = VPMOVSXWDZ128rm                     $rip, 1, $rax, 0, $noreg
3403   ; CHECK: $xmm16 = VPMOVSXWDZ128rr            $xmm16
3404   $xmm16 = VPMOVSXWDZ128rr                     $xmm16                                                    
3405   ; CHECK: $xmm16 = VPMOVSXWQZ128rm            $rip, 1, $rax, 0, $noreg
3406   $xmm16 = VPMOVSXWQZ128rm                     $rip, 1, $rax, 0, $noreg
3407   ; CHECK: $xmm16 = VPMOVSXWQZ128rr            $xmm16
3408   $xmm16 = VPMOVSXWQZ128rr                     $xmm16                                                    
3409   ; CHECK: $xmm16 = VPMOVZXBDZ128rm            $rip, 1, $rax, 0, $noreg
3410   $xmm16 = VPMOVZXBDZ128rm                     $rip, 1, $rax, 0, $noreg
3411   ; CHECK: $xmm16 = VPMOVZXBDZ128rr            $xmm16
3412   $xmm16 = VPMOVZXBDZ128rr                     $xmm16                                                    
3413   ; CHECK: $xmm16 = VPMOVZXBQZ128rm            $rip, 1, $rax, 0, $noreg
3414   $xmm16 = VPMOVZXBQZ128rm                     $rip, 1, $rax, 0, $noreg
3415   ; CHECK: $xmm16 = VPMOVZXBQZ128rr            $xmm16
3416   $xmm16 = VPMOVZXBQZ128rr                     $xmm16                                                    
3417   ; CHECK: $xmm16 = VPMOVZXBWZ128rm            $rip, 1, $rax, 0, $noreg
3418   $xmm16 = VPMOVZXBWZ128rm                     $rip, 1, $rax, 0, $noreg
3419   ; CHECK: $xmm16 = VPMOVZXBWZ128rr            $xmm16
3420   $xmm16 = VPMOVZXBWZ128rr                     $xmm16                                                    
3421   ; CHECK: $xmm16 = VPMOVZXDQZ128rm            $rip, 1, $rax, 0, $noreg
3422   $xmm16 = VPMOVZXDQZ128rm                     $rip, 1, $rax, 0, $noreg
3423   ; CHECK: $xmm16 = VPMOVZXDQZ128rr            $xmm16
3424   $xmm16 = VPMOVZXDQZ128rr                     $xmm16                                                    
3425   ; CHECK: $xmm16 = VPMOVZXWDZ128rm            $rip, 1, $rax, 0, $noreg
3426   $xmm16 = VPMOVZXWDZ128rm                     $rip, 1, $rax, 0, $noreg
3427   ; CHECK: $xmm16 = VPMOVZXWDZ128rr            $xmm16
3428   $xmm16 = VPMOVZXWDZ128rr                     $xmm16                                                    
3429   ; CHECK: $xmm16 = VPMOVZXWQZ128rm            $rip, 1, $rax, 0, $noreg
3430   $xmm16 = VPMOVZXWQZ128rm                     $rip, 1, $rax, 0, $noreg
3431   ; CHECK: $xmm16 = VPMOVZXWQZ128rr            $xmm16  
3432   $xmm16 = VPMOVZXWQZ128rr                     $xmm16                                                    
3433   ; CHECK: VMOVHPDZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3434   VMOVHPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3435   ; CHECK: $xmm16 = VMOVHPDZ128rm              $xmm16,  $rdi, 1, $noreg, 0, $noreg
3436   $xmm16 = VMOVHPDZ128rm                       $xmm16,  $rdi, 1, $noreg, 0, $noreg                                 
3437   ; CHECK: VMOVHPSZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3438   VMOVHPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3439   ; CHECK: $xmm16 = VMOVHPSZ128rm              $xmm16,  $rdi, 1, $noreg, 0, $noreg
3440   $xmm16 = VMOVHPSZ128rm                       $xmm16,  $rdi, 1, $noreg, 0, $noreg                                 
3441   ; CHECK: VMOVLPDZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3442   VMOVLPDZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3443   ; CHECK: $xmm16 = VMOVLPDZ128rm              $xmm16,  $rdi, 1, $noreg, 0, $noreg
3444   $xmm16 = VMOVLPDZ128rm                       $xmm16,  $rdi, 1, $noreg, 0, $noreg                                 
3445   ; CHECK: VMOVLPSZ128mr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
3446   VMOVLPSZ128mr                                $rdi, 1, $noreg, 0, $noreg, $xmm16                                  
3447   ; CHECK: $xmm16 = VMOVLPSZ128rm              $xmm16,  $rdi, 1, $noreg, 0, $noreg  
3448   $xmm16 = VMOVLPSZ128rm                       $xmm16,  $rdi, 1, $noreg, 0, $noreg                                               
3449   ; CHECK: $xmm16 = VMAXCPDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3450   $xmm16 = VMAXCPDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3451   ; CHECK: $xmm16 = VMAXCPDZ128rr              $xmm16, $xmm1  
3452   $xmm16 = VMAXCPDZ128rr                       $xmm16, $xmm1                                             
3453   ; CHECK: $xmm16 = VMAXCPSZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3454   $xmm16 = VMAXCPSZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3455   ; CHECK: $xmm16 = VMAXCPSZ128rr              $xmm16, $xmm1
3456   $xmm16 = VMAXCPSZ128rr                       $xmm16, $xmm1                                             
3457   ; CHECK: $xmm16 = VMAXPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3458   $xmm16 = VMAXPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3459   ; CHECK: $xmm16 = VMAXPDZ128rr               $xmm16, $xmm1
3460   $xmm16 = VMAXPDZ128rr                        $xmm16, $xmm1                                             
3461   ; CHECK: $xmm16 = VMAXPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3462   $xmm16 = VMAXPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3463   ; CHECK: $xmm16 = VMAXPSZ128rr               $xmm16, $xmm1
3464   $xmm16 = VMAXPSZ128rr                        $xmm16, $xmm1                                             
3465   ; CHECK: $xmm16 = VMINCPDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3466   $xmm16 = VMINCPDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3467   ; CHECK: $xmm16 = VMINCPDZ128rr              $xmm16, $xmm1  
3468   $xmm16 = VMINCPDZ128rr                       $xmm16, $xmm1                                             
3469   ; CHECK: $xmm16 = VMINCPSZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3470   $xmm16 = VMINCPSZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3471   ; CHECK: $xmm16 = VMINCPSZ128rr              $xmm16, $xmm1
3472   $xmm16 = VMINCPSZ128rr                       $xmm16, $xmm1                                             
3473   ; CHECK: $xmm16 = VMINPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3474   $xmm16 = VMINPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3475   ; CHECK: $xmm16 = VMINPDZ128rr               $xmm16, $xmm1
3476   $xmm16 = VMINPDZ128rr                        $xmm16, $xmm1                                             
3477   ; CHECK: $xmm16 = VMINPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3478   $xmm16 = VMINPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3479   ; CHECK: $xmm16 = VMINPSZ128rr               $xmm16, $xmm1
3480   $xmm16 = VMINPSZ128rr                        $xmm16, $xmm1                                             
3481   ; CHECK: $xmm16 = VMULPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3482   $xmm16 = VMULPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3483   ; CHECK: $xmm16 = VMULPDZ128rr               $xmm16, $xmm1
3484   $xmm16 = VMULPDZ128rr                        $xmm16, $xmm1                                             
3485   ; CHECK: $xmm16 = VMULPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3486   $xmm16 = VMULPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3487   ; CHECK: $xmm16 = VMULPSZ128rr               $xmm16, $xmm1
3488   $xmm16 = VMULPSZ128rr                        $xmm16, $xmm1                                             
3489   ; CHECK: $xmm16 = VORPDZ128rm                $xmm16, $rip, 1, $rax, 0, $noreg
3490   $xmm16 = VORPDZ128rm                         $xmm16, $rip, 1, $rax, 0, $noreg
3491   ; CHECK: $xmm16 = VORPDZ128rr                $xmm16, $xmm1
3492   $xmm16 = VORPDZ128rr                         $xmm16, $xmm1                                             
3493   ; CHECK: $xmm16 = VORPSZ128rm                $xmm16, $rip, 1, $rax, 0, $noreg
3494   $xmm16 = VORPSZ128rm                         $xmm16, $rip, 1, $rax, 0, $noreg
3495   ; CHECK: $xmm16 = VORPSZ128rr                $xmm16, $xmm1
3496   $xmm16 = VORPSZ128rr                         $xmm16, $xmm1                                             
3497   ; CHECK: $xmm16 = VPADDBZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3498   $xmm16 = VPADDBZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3499   ; CHECK: $xmm16 = VPADDBZ128rr               $xmm16, $xmm1
3500   $xmm16 = VPADDBZ128rr                        $xmm16, $xmm1                                             
3501   ; CHECK: $xmm16 = VPADDDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3502   $xmm16 = VPADDDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3503   ; CHECK: $xmm16 = VPADDDZ128rr               $xmm16, $xmm1
3504   $xmm16 = VPADDDZ128rr                        $xmm16, $xmm1                                             
3505   ; CHECK: $xmm16 = VPADDQZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3506   $xmm16 = VPADDQZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3507   ; CHECK: $xmm16 = VPADDQZ128rr               $xmm16, $xmm1
3508   $xmm16 = VPADDQZ128rr                        $xmm16, $xmm1                                             
3509   ; CHECK: $xmm16 = VPADDSBZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3510   $xmm16 = VPADDSBZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3511   ; CHECK: $xmm16 = VPADDSBZ128rr              $xmm16, $xmm1
3512   $xmm16 = VPADDSBZ128rr                       $xmm16, $xmm1                                             
3513   ; CHECK: $xmm16 = VPADDSWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3514   $xmm16 = VPADDSWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3515   ; CHECK: $xmm16 = VPADDSWZ128rr              $xmm16, $xmm1
3516   $xmm16 = VPADDSWZ128rr                       $xmm16, $xmm1                                             
3517   ; CHECK: $xmm16 = VPADDUSBZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3518   $xmm16 = VPADDUSBZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3519   ; CHECK: $xmm16 = VPADDUSBZ128rr             $xmm16, $xmm1
3520   $xmm16 = VPADDUSBZ128rr                      $xmm16, $xmm1                                             
3521   ; CHECK: $xmm16 = VPADDUSWZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3522   $xmm16 = VPADDUSWZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3523   ; CHECK: $xmm16 = VPADDUSWZ128rr             $xmm16, $xmm1
3524   $xmm16 = VPADDUSWZ128rr                      $xmm16, $xmm1                                             
3525   ; CHECK: $xmm16 = VPADDWZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3526   $xmm16 = VPADDWZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3527   ; CHECK: $xmm16 = VPADDWZ128rr               $xmm16, $xmm1
3528   $xmm16 = VPADDWZ128rr                        $xmm16, $xmm1                                             
3529   ; CHECK: $xmm16 = VPANDDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3530   $xmm16 = VPANDDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3531   ; CHECK: $xmm16 = VPANDDZ128rr               $xmm16, $xmm1
3532   $xmm16 = VPANDDZ128rr                        $xmm16, $xmm1                                             
3533   ; CHECK: $xmm16 = VPANDQZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3534   $xmm16 = VPANDQZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3535   ; CHECK: $xmm16 = VPANDQZ128rr               $xmm16, $xmm1  
3536   $xmm16 = VPANDQZ128rr                        $xmm16, $xmm1                                             
3537   ; CHECK: $xmm16 = VPANDNDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3538   $xmm16 = VPANDNDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3539   ; CHECK: $xmm16 = VPANDNDZ128rr              $xmm16, $xmm1
3540   $xmm16 = VPANDNDZ128rr                       $xmm16, $xmm1                                             
3541   ; CHECK: $xmm16 = VPANDNQZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3542   $xmm16 = VPANDNQZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3543   ; CHECK: $xmm16 = VPANDNQZ128rr              $xmm16, $xmm1  
3544   $xmm16 = VPANDNQZ128rr                       $xmm16, $xmm1                                             
3545   ; CHECK: $xmm16 = VPAVGBZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3546   $xmm16 = VPAVGBZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3547   ; CHECK: $xmm16 = VPAVGBZ128rr               $xmm16, $xmm1  
3548   $xmm16 = VPAVGBZ128rr                        $xmm16, $xmm1                                             
3549   ; CHECK: $xmm16 = VPAVGWZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3550   $xmm16 = VPAVGWZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3551   ; CHECK: $xmm16 = VPAVGWZ128rr               $xmm16, $xmm1
3552   $xmm16 = VPAVGWZ128rr                        $xmm16, $xmm1                                             
3553   ; CHECK: $xmm16 = VPMAXSBZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3554   $xmm16 = VPMAXSBZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3555   ; CHECK: $xmm16 = VPMAXSBZ128rr              $xmm16, $xmm1
3556   $xmm16 = VPMAXSBZ128rr                       $xmm16, $xmm1                                             
3557   ; CHECK: $xmm16 = VPMAXSDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3558   $xmm16 = VPMAXSDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3559   ; CHECK: $xmm16 = VPMAXSDZ128rr              $xmm16, $xmm1
3560   $xmm16 = VPMAXSDZ128rr                       $xmm16, $xmm1                                             
3561   ; CHECK: $xmm16 = VPMAXSWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3562   $xmm16 = VPMAXSWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3563   ; CHECK: $xmm16 = VPMAXSWZ128rr              $xmm16, $xmm1  
3564   $xmm16 = VPMAXSWZ128rr                       $xmm16, $xmm1                                             
3565   ; CHECK: $xmm16 = VPMAXUBZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3566   $xmm16 = VPMAXUBZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3567   ; CHECK: $xmm16 = VPMAXUBZ128rr              $xmm16, $xmm1
3568   $xmm16 = VPMAXUBZ128rr                       $xmm16, $xmm1                                             
3569   ; CHECK: $xmm16 = VPMAXUDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3570   $xmm16 = VPMAXUDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3571   ; CHECK: $xmm16 = VPMAXUDZ128rr              $xmm16, $xmm1
3572   $xmm16 = VPMAXUDZ128rr                       $xmm16, $xmm1                                             
3573   ; CHECK: $xmm16 = VPMAXUWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3574   $xmm16 = VPMAXUWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3575   ; CHECK: $xmm16 = VPMAXUWZ128rr              $xmm16, $xmm1
3576   $xmm16 = VPMAXUWZ128rr                       $xmm16, $xmm1                                             
3577   ; CHECK: $xmm16 = VPMINSBZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3578   $xmm16 = VPMINSBZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3579   ; CHECK: $xmm16 = VPMINSBZ128rr              $xmm16, $xmm1
3580   $xmm16 = VPMINSBZ128rr                       $xmm16, $xmm1                                             
3581   ; CHECK: $xmm16 = VPMINSDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3582   $xmm16 = VPMINSDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3583   ; CHECK: $xmm16 = VPMINSDZ128rr              $xmm16, $xmm1
3584   $xmm16 = VPMINSDZ128rr                       $xmm16, $xmm1                                             
3585   ; CHECK: $xmm16 = VPMINSWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3586   $xmm16 = VPMINSWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3587   ; CHECK: $xmm16 = VPMINSWZ128rr              $xmm16, $xmm1
3588   $xmm16 = VPMINSWZ128rr                       $xmm16, $xmm1                                             
3589   ; CHECK: $xmm16 = VPMINUBZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3590   $xmm16 = VPMINUBZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3591   ; CHECK: $xmm16 = VPMINUBZ128rr              $xmm16, $xmm1
3592   $xmm16 = VPMINUBZ128rr                       $xmm16, $xmm1                                             
3593   ; CHECK: $xmm16 = VPMINUDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3594   $xmm16 = VPMINUDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3595   ; CHECK: $xmm16 = VPMINUDZ128rr              $xmm16, $xmm1
3596   $xmm16 = VPMINUDZ128rr                       $xmm16, $xmm1                                             
3597   ; CHECK: $xmm16 = VPMINUWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3598   $xmm16 = VPMINUWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3599   ; CHECK: $xmm16 = VPMINUWZ128rr              $xmm16, $xmm1
3600   $xmm16 = VPMINUWZ128rr                       $xmm16, $xmm1                                             
3601   ; CHECK: $xmm16 = VPMULDQZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3602   $xmm16 = VPMULDQZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3603   ; CHECK: $xmm16 = VPMULDQZ128rr              $xmm16, $xmm1
3604   $xmm16 = VPMULDQZ128rr                       $xmm16, $xmm1                                             
3605   ; CHECK: $xmm16 = VPMULHRSWZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3606   $xmm16 = VPMULHRSWZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3607   ; CHECK: $xmm16 = VPMULHRSWZ128rr            $xmm16, $xmm1
3608   $xmm16 = VPMULHRSWZ128rr                     $xmm16, $xmm1                                             
3609   ; CHECK: $xmm16 = VPMULHUWZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3610   $xmm16 = VPMULHUWZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3611   ; CHECK: $xmm16 = VPMULHUWZ128rr             $xmm16, $xmm1
3612   $xmm16 = VPMULHUWZ128rr                      $xmm16, $xmm1                                             
3613   ; CHECK: $xmm16 = VPMULHWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3614   $xmm16 = VPMULHWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3615   ; CHECK: $xmm16 = VPMULHWZ128rr              $xmm16, $xmm1
3616   $xmm16 = VPMULHWZ128rr                       $xmm16, $xmm1                                             
3617   ; CHECK: $xmm16 = VPMULLDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3618   $xmm16 = VPMULLDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3619   ; CHECK: $xmm16 = VPMULLDZ128rr              $xmm16, $xmm1
3620   $xmm16 = VPMULLDZ128rr                       $xmm16, $xmm1                                             
3621   ; CHECK: $xmm16 = VPMULLWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3622   $xmm16 = VPMULLWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3623   ; CHECK: $xmm16 = VPMULLWZ128rr              $xmm16, $xmm1
3624   $xmm16 = VPMULLWZ128rr                       $xmm16, $xmm1                                             
3625   ; CHECK: $xmm16 = VPMULUDQZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3626   $xmm16 = VPMULUDQZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3627   ; CHECK: $xmm16 = VPMULUDQZ128rr             $xmm16, $xmm1
3628   $xmm16 = VPMULUDQZ128rr                      $xmm16, $xmm1                                             
3629   ; CHECK: $xmm16 = VPORDZ128rm                $xmm16, $rip, 1, $rax, 0, $noreg
3630   $xmm16 = VPORDZ128rm                         $xmm16, $rip, 1, $rax, 0, $noreg
3631   ; CHECK: $xmm16 = VPORDZ128rr                $xmm16, $xmm1
3632   $xmm16 = VPORDZ128rr                         $xmm16, $xmm1                                             
3633   ; CHECK: $xmm16 = VPORQZ128rm                $xmm16, $rip, 1, $rax, 0, $noreg
3634   $xmm16 = VPORQZ128rm                         $xmm16, $rip, 1, $rax, 0, $noreg
3635   ; CHECK: $xmm16 = VPORQZ128rr                $xmm16, $xmm1  
3636   $xmm16 = VPORQZ128rr                         $xmm16, $xmm1                                             
3637   ; CHECK: $xmm16 = VPSUBBZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3638   $xmm16 = VPSUBBZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3639   ; CHECK: $xmm16 = VPSUBBZ128rr               $xmm16, $xmm1
3640   $xmm16 = VPSUBBZ128rr                        $xmm16, $xmm1                                             
3641   ; CHECK: $xmm16 = VPSUBDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3642   $xmm16 = VPSUBDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3643   ; CHECK: $xmm16 = VPSUBDZ128rr               $xmm16, $xmm1
3644   $xmm16 = VPSUBDZ128rr                        $xmm16, $xmm1                                             
3645   ; CHECK: $xmm16 = VPSUBQZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3646   $xmm16 = VPSUBQZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3647   ; CHECK: $xmm16 = VPSUBQZ128rr               $xmm16, $xmm1
3648   $xmm16 = VPSUBQZ128rr                        $xmm16, $xmm1                                             
3649   ; CHECK: $xmm16 = VPSUBSBZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3650   $xmm16 = VPSUBSBZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3651   ; CHECK: $xmm16 = VPSUBSBZ128rr              $xmm16, $xmm1  
3652   $xmm16 = VPSUBSBZ128rr                       $xmm16, $xmm1                                             
3653   ; CHECK: $xmm16 = VPSUBSWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3654   $xmm16 = VPSUBSWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3655   ; CHECK: $xmm16 = VPSUBSWZ128rr              $xmm16, $xmm1
3656   $xmm16 = VPSUBSWZ128rr                       $xmm16, $xmm1                                             
3657   ; CHECK: $xmm16 = VPSUBUSBZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3658   $xmm16 = VPSUBUSBZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3659   ; CHECK: $xmm16 = VPSUBUSBZ128rr             $xmm16, $xmm1  
3660   $xmm16 = VPSUBUSBZ128rr                      $xmm16, $xmm1                                             
3661   ; CHECK: $xmm16 = VPSUBUSWZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3662   $xmm16 = VPSUBUSWZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3663   ; CHECK: $xmm16 = VPSUBUSWZ128rr             $xmm16, $xmm1
3664   $xmm16 = VPSUBUSWZ128rr                      $xmm16, $xmm1                                             
3665   ; CHECK: $xmm16 = VPSUBWZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3666   $xmm16 = VPSUBWZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3667   ; CHECK: $xmm16 = VPSUBWZ128rr               $xmm16, $xmm1                            
3668   $xmm16 = VPSUBWZ128rr                        $xmm16, $xmm1                                             
3669   ; CHECK: $xmm16 = VADDPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3670   $xmm16 = VADDPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3671   ; CHECK: $xmm16 = VADDPDZ128rr               $xmm16, $xmm1  
3672   $xmm16 = VADDPDZ128rr                        $xmm16, $xmm1                                             
3673   ; CHECK: $xmm16 = VADDPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3674   $xmm16 = VADDPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3675   ; CHECK: $xmm16 = VADDPSZ128rr               $xmm16, $xmm1
3676   $xmm16 = VADDPSZ128rr                        $xmm16, $xmm1                                             
3677   ; CHECK: $xmm16 = VANDNPDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3678   $xmm16 = VANDNPDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3679   ; CHECK: $xmm16 = VANDNPDZ128rr              $xmm16, $xmm1
3680   $xmm16 = VANDNPDZ128rr                       $xmm16, $xmm1                                             
3681   ; CHECK: $xmm16 = VANDNPSZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3682   $xmm16 = VANDNPSZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3683   ; CHECK: $xmm16 = VANDNPSZ128rr              $xmm16, $xmm1
3684   $xmm16 = VANDNPSZ128rr                       $xmm16, $xmm1                                             
3685   ; CHECK: $xmm16 = VANDPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3686   $xmm16 = VANDPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3687   ; CHECK: $xmm16 = VANDPDZ128rr               $xmm16, $xmm1  
3688   $xmm16 = VANDPDZ128rr                        $xmm16, $xmm1                                             
3689   ; CHECK: $xmm16 = VANDPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3690   $xmm16 = VANDPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3691   ; CHECK: $xmm16 = VANDPSZ128rr               $xmm16, $xmm1
3692   $xmm16 = VANDPSZ128rr                        $xmm16, $xmm1                                             
3693   ; CHECK: $xmm16 = VDIVPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3694   $xmm16 = VDIVPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3695   ; CHECK: $xmm16 = VDIVPDZ128rr               $xmm16, $xmm1
3696   $xmm16 = VDIVPDZ128rr                        $xmm16, $xmm1                                             
3697   ; CHECK: $xmm16 = VDIVPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3698   $xmm16 = VDIVPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3699   ; CHECK: $xmm16 = VDIVPSZ128rr               $xmm16, $xmm1
3700   $xmm16 = VDIVPSZ128rr                        $xmm16, $xmm1                                             
3701   ; CHECK: $xmm16 = VPXORDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3702   $xmm16 = VPXORDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3703   ; CHECK: $xmm16 = VPXORDZ128rr               $xmm16, $xmm1
3704   $xmm16 = VPXORDZ128rr                        $xmm16, $xmm1                                             
3705   ; CHECK: $xmm16 = VPXORQZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3706   $xmm16 = VPXORQZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3707   ; CHECK: $xmm16 = VPXORQZ128rr               $xmm16, $xmm1
3708   $xmm16 = VPXORQZ128rr                        $xmm16, $xmm1                                             
3709   ; CHECK: $xmm16 = VSUBPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3710   $xmm16 = VSUBPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3711   ; CHECK: $xmm16 = VSUBPDZ128rr               $xmm16, $xmm1
3712   $xmm16 = VSUBPDZ128rr                        $xmm16, $xmm1                                             
3713   ; CHECK: $xmm16 = VSUBPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3714   $xmm16 = VSUBPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3715   ; CHECK: $xmm16 = VSUBPSZ128rr               $xmm16, $xmm1                  
3716   $xmm16 = VSUBPSZ128rr                        $xmm16, $xmm1                                             
3717   ; CHECK: $xmm16 = VXORPDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3718   $xmm16 = VXORPDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3719   ; CHECK: $xmm16 = VXORPDZ128rr               $xmm16, $xmm1
3720   $xmm16 = VXORPDZ128rr                        $xmm16, $xmm1                                             
3721   ; CHECK: $xmm16 = VXORPSZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3722   $xmm16 = VXORPSZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3723   ; CHECK: $xmm16 = VXORPSZ128rr               $xmm16, $xmm1
3724   $xmm16 = VXORPSZ128rr                        $xmm16, $xmm1                                             
3725   ; CHECK: $xmm16 = VPMADDUBSWZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3726   $xmm16 = VPMADDUBSWZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3727   ; CHECK: $xmm16 = VPMADDUBSWZ128rr           $xmm16, $xmm1
3728   $xmm16 = VPMADDUBSWZ128rr                    $xmm16, $xmm1                                             
3729   ; CHECK: $xmm16 = VPMADDWDZ128rm             $xmm16, $rip, 1, $rax, 0, $noreg
3730   $xmm16 = VPMADDWDZ128rm                      $xmm16, $rip, 1, $rax, 0, $noreg
3731   ; CHECK: $xmm16 = VPMADDWDZ128rr             $xmm16, $xmm1                                               
3732   $xmm16 = VPMADDWDZ128rr                      $xmm16, $xmm1                                                 
3733   ; CHECK: $xmm16 = VPACKSSDWZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3734   $xmm16 = VPACKSSDWZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3735   ; CHECK: $xmm16 = VPACKSSDWZ128rr            $xmm16, $xmm1
3736   $xmm16 = VPACKSSDWZ128rr                     $xmm16, $xmm1                                             
3737   ; CHECK: $xmm16 = VPACKSSWBZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3738   $xmm16 = VPACKSSWBZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3739   ; CHECK: $xmm16 = VPACKSSWBZ128rr            $xmm16, $xmm1
3740   $xmm16 = VPACKSSWBZ128rr                     $xmm16, $xmm1                                             
3741   ; CHECK: $xmm16 = VPACKUSDWZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3742   $xmm16 = VPACKUSDWZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3743   ; CHECK: $xmm16 = VPACKUSDWZ128rr            $xmm16, $xmm1
3744   $xmm16 = VPACKUSDWZ128rr                     $xmm16, $xmm1                                             
3745   ; CHECK: $xmm16 = VPACKUSWBZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3746   $xmm16 = VPACKUSWBZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3747   ; CHECK: $xmm16 = VPACKUSWBZ128rr            $xmm16, $xmm1
3748   $xmm16 = VPACKUSWBZ128rr                     $xmm16, $xmm1                                             
3749   ; CHECK: $xmm16 = VPUNPCKHBWZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3750   $xmm16 = VPUNPCKHBWZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3751   ; CHECK: $xmm16 = VPUNPCKHBWZ128rr           $xmm16, $xmm1
3752   $xmm16 = VPUNPCKHBWZ128rr                    $xmm16, $xmm1                                             
3753   ; CHECK: $xmm16 = VPUNPCKHDQZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3754   $xmm16 = VPUNPCKHDQZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3755   ; CHECK: $xmm16 = VPUNPCKHDQZ128rr           $xmm16, $xmm1
3756   $xmm16 = VPUNPCKHDQZ128rr                    $xmm16, $xmm1                                             
3757   ; CHECK: $xmm16 = VPUNPCKHQDQZ128rm          $xmm16, $rip, 1, $rax, 0, $noreg
3758   $xmm16 = VPUNPCKHQDQZ128rm                   $xmm16, $rip, 1, $rax, 0, $noreg
3759   ; CHECK: $xmm16 = VPUNPCKHQDQZ128rr          $xmm16, $xmm1
3760   $xmm16 = VPUNPCKHQDQZ128rr                   $xmm16, $xmm1                                             
3761   ; CHECK: $xmm16 = VPUNPCKHWDZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3762   $xmm16 = VPUNPCKHWDZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3763   ; CHECK: $xmm16 = VPUNPCKHWDZ128rr           $xmm16, $xmm1
3764   $xmm16 = VPUNPCKHWDZ128rr                    $xmm16, $xmm1                                             
3765   ; CHECK: $xmm16 = VPUNPCKLBWZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3766   $xmm16 = VPUNPCKLBWZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3767   ; CHECK: $xmm16 = VPUNPCKLBWZ128rr           $xmm16, $xmm1
3768   $xmm16 = VPUNPCKLBWZ128rr                    $xmm16, $xmm1                                             
3769   ; CHECK: $xmm16 = VPUNPCKLDQZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3770   $xmm16 = VPUNPCKLDQZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3771   ; CHECK: $xmm16 = VPUNPCKLDQZ128rr           $xmm16, $xmm1
3772   $xmm16 = VPUNPCKLDQZ128rr                    $xmm16, $xmm1                                             
3773   ; CHECK: $xmm16 = VPUNPCKLQDQZ128rm          $xmm16, $rip, 1, $rax, 0, $noreg
3774   $xmm16 = VPUNPCKLQDQZ128rm                   $xmm16, $rip, 1, $rax, 0, $noreg
3775   ; CHECK: $xmm16 = VPUNPCKLQDQZ128rr          $xmm16, $xmm1
3776   $xmm16 = VPUNPCKLQDQZ128rr                   $xmm16, $xmm1                                             
3777   ; CHECK: $xmm16 = VPUNPCKLWDZ128rm           $xmm16, $rip, 1, $rax, 0, $noreg
3778   $xmm16 = VPUNPCKLWDZ128rm                    $xmm16, $rip, 1, $rax, 0, $noreg
3779   ; CHECK: $xmm16 = VPUNPCKLWDZ128rr           $xmm16, $xmm1
3780   $xmm16 = VPUNPCKLWDZ128rr                    $xmm16, $xmm1                                             
3781   ; CHECK: $xmm16 = VUNPCKHPDZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3782   $xmm16 = VUNPCKHPDZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3783   ; CHECK: $xmm16 = VUNPCKHPDZ128rr            $xmm16, $xmm1
3784   $xmm16 = VUNPCKHPDZ128rr                     $xmm16, $xmm1                                             
3785   ; CHECK: $xmm16 = VUNPCKHPSZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3786   $xmm16 = VUNPCKHPSZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3787   ; CHECK: $xmm16 = VUNPCKHPSZ128rr            $xmm16, $xmm1
3788   $xmm16 = VUNPCKHPSZ128rr                     $xmm16, $xmm1                                             
3789   ; CHECK: $xmm16 = VUNPCKLPDZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3790   $xmm16 = VUNPCKLPDZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3791   ; CHECK: $xmm16 = VUNPCKLPDZ128rr            $xmm16, $xmm1
3792   $xmm16 = VUNPCKLPDZ128rr                     $xmm16, $xmm1                                             
3793   ; CHECK: $xmm16 = VUNPCKLPSZ128rm            $xmm16, $rip, 1, $rax, 0, $noreg
3794   $xmm16 = VUNPCKLPSZ128rm                     $xmm16, $rip, 1, $rax, 0, $noreg
3795   ; CHECK: $xmm16 = VUNPCKLPSZ128rr            $xmm16, $xmm1                                               
3796   $xmm16 = VUNPCKLPSZ128rr                     $xmm16, $xmm1                                                             
3797   ; CHECK: $xmm16 = VFMADD132PDZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3798   $xmm16 = VFMADD132PDZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3799   ; CHECK: $xmm16 = VFMADD132PDZ128r           $xmm16, $xmm1, $xmm2
3800   $xmm16 = VFMADD132PDZ128r                    $xmm16, $xmm1, $xmm2                                      
3801   ; CHECK: $xmm16 = VFMADD132PSZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3802   $xmm16 = VFMADD132PSZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3803   ; CHECK: $xmm16 = VFMADD132PSZ128r           $xmm16, $xmm1, $xmm2
3804   $xmm16 = VFMADD132PSZ128r                    $xmm16, $xmm1, $xmm2                                      
3805   ; CHECK: $xmm16 = VFMADD213PDZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3806   $xmm16 = VFMADD213PDZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3807   ; CHECK: $xmm16 = VFMADD213PDZ128r           $xmm16, $xmm1, $xmm2
3808   $xmm16 = VFMADD213PDZ128r                    $xmm16, $xmm1, $xmm2                                      
3809   ; CHECK: $xmm16 = VFMADD213PSZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3810   $xmm16 = VFMADD213PSZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3811   ; CHECK: $xmm16 = VFMADD213PSZ128r           $xmm16, $xmm1, $xmm2
3812   $xmm16 = VFMADD213PSZ128r                    $xmm16, $xmm1, $xmm2                                      
3813   ; CHECK: $xmm16 = VFMADD231PDZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3814   $xmm16 = VFMADD231PDZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3815   ; CHECK: $xmm16 = VFMADD231PDZ128r           $xmm16, $xmm1, $xmm2
3816   $xmm16 = VFMADD231PDZ128r                    $xmm16, $xmm1, $xmm2                                      
3817   ; CHECK: $xmm16 = VFMADD231PSZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3818   $xmm16 = VFMADD231PSZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3819   ; CHECK: $xmm16 = VFMADD231PSZ128r           $xmm16, $xmm1, $xmm2
3820   $xmm16 = VFMADD231PSZ128r                    $xmm16, $xmm1, $xmm2                                      
3821   ; CHECK: $xmm16 = VFMADDSUB132PDZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3822   $xmm16 = VFMADDSUB132PDZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3823   ; CHECK: $xmm16 = VFMADDSUB132PDZ128r        $xmm16, $xmm1, $xmm2
3824   $xmm16 = VFMADDSUB132PDZ128r                 $xmm16, $xmm1, $xmm2                                      
3825   ; CHECK: $xmm16 = VFMADDSUB132PSZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3826   $xmm16 = VFMADDSUB132PSZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3827   ; CHECK: $xmm16 = VFMADDSUB132PSZ128r        $xmm16, $xmm1, $xmm2
3828   $xmm16 = VFMADDSUB132PSZ128r                 $xmm16, $xmm1, $xmm2                                      
3829   ; CHECK: $xmm16 = VFMADDSUB213PDZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3830   $xmm16 = VFMADDSUB213PDZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3831   ; CHECK: $xmm16 = VFMADDSUB213PDZ128r        $xmm16, $xmm1, $xmm2
3832   $xmm16 = VFMADDSUB213PDZ128r                 $xmm16, $xmm1, $xmm2                                      
3833   ; CHECK: $xmm16 = VFMADDSUB213PSZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3834   $xmm16 = VFMADDSUB213PSZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3835   ; CHECK: $xmm16 = VFMADDSUB213PSZ128r        $xmm16, $xmm1, $xmm2
3836   $xmm16 = VFMADDSUB213PSZ128r                 $xmm16, $xmm1, $xmm2                                      
3837   ; CHECK: $xmm16 = VFMADDSUB231PDZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3838   $xmm16 = VFMADDSUB231PDZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3839   ; CHECK: $xmm16 = VFMADDSUB231PDZ128r        $xmm16, $xmm1, $xmm2
3840   $xmm16 = VFMADDSUB231PDZ128r                 $xmm16, $xmm1, $xmm2                                      
3841   ; CHECK: $xmm16 = VFMADDSUB231PSZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3842   $xmm16 = VFMADDSUB231PSZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3843   ; CHECK: $xmm16 = VFMADDSUB231PSZ128r        $xmm16, $xmm1, $xmm2
3844   $xmm16 = VFMADDSUB231PSZ128r                 $xmm16, $xmm1, $xmm2                                      
3845   ; CHECK: $xmm16 = VFMSUB132PDZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3846   $xmm16 = VFMSUB132PDZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3847   ; CHECK: $xmm16 = VFMSUB132PDZ128r           $xmm16, $xmm1, $xmm2
3848   $xmm16 = VFMSUB132PDZ128r                    $xmm16, $xmm1, $xmm2                                      
3849   ; CHECK: $xmm16 = VFMSUB132PSZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3850   $xmm16 = VFMSUB132PSZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3851   ; CHECK: $xmm16 = VFMSUB132PSZ128r           $xmm16, $xmm1, $xmm2
3852   $xmm16 = VFMSUB132PSZ128r                    $xmm16, $xmm1, $xmm2                                      
3853   ; CHECK: $xmm16 = VFMSUB213PDZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3854   $xmm16 = VFMSUB213PDZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3855   ; CHECK: $xmm16 = VFMSUB213PDZ128r           $xmm16, $xmm1, $xmm2
3856   $xmm16 = VFMSUB213PDZ128r                    $xmm16, $xmm1, $xmm2                                      
3857   ; CHECK: $xmm16 = VFMSUB213PSZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3858   $xmm16 = VFMSUB213PSZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3859   ; CHECK: $xmm16 = VFMSUB213PSZ128r           $xmm16, $xmm1, $xmm2
3860   $xmm16 = VFMSUB213PSZ128r                    $xmm16, $xmm1, $xmm2                                      
3861   ; CHECK: $xmm16 = VFMSUB231PDZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3862   $xmm16 = VFMSUB231PDZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3863   ; CHECK: $xmm16 = VFMSUB231PDZ128r           $xmm16, $xmm1, $xmm2
3864   $xmm16 = VFMSUB231PDZ128r                    $xmm16, $xmm1, $xmm2                                      
3865   ; CHECK: $xmm16 = VFMSUB231PSZ128m           $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3866   $xmm16 = VFMSUB231PSZ128m                    $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3867   ; CHECK: $xmm16 = VFMSUB231PSZ128r           $xmm16, $xmm1, $xmm2
3868   $xmm16 = VFMSUB231PSZ128r                    $xmm16, $xmm1, $xmm2                                      
3869   ; CHECK: $xmm16 = VFMSUBADD132PDZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3870   $xmm16 = VFMSUBADD132PDZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3871   ; CHECK: $xmm16 = VFMSUBADD132PDZ128r        $xmm16, $xmm1, $xmm2
3872   $xmm16 = VFMSUBADD132PDZ128r                 $xmm16, $xmm1, $xmm2                                      
3873   ; CHECK: $xmm16 = VFMSUBADD132PSZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3874   $xmm16 = VFMSUBADD132PSZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3875   ; CHECK: $xmm16 = VFMSUBADD132PSZ128r        $xmm16, $xmm1, $xmm2
3876   $xmm16 = VFMSUBADD132PSZ128r                 $xmm16, $xmm1, $xmm2                                      
3877   ; CHECK: $xmm16 = VFMSUBADD213PDZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3878   $xmm16 = VFMSUBADD213PDZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3879   ; CHECK: $xmm16 = VFMSUBADD213PDZ128r        $xmm16, $xmm1, $xmm2
3880   $xmm16 = VFMSUBADD213PDZ128r                 $xmm16, $xmm1, $xmm2                                      
3881   ; CHECK: $xmm16 = VFMSUBADD213PSZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3882   $xmm16 = VFMSUBADD213PSZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3883   ; CHECK: $xmm16 = VFMSUBADD213PSZ128r        $xmm16, $xmm1, $xmm2
3884   $xmm16 = VFMSUBADD213PSZ128r                 $xmm16, $xmm1, $xmm2                                      
3885   ; CHECK: $xmm16 = VFMSUBADD231PDZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3886   $xmm16 = VFMSUBADD231PDZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3887   ; CHECK: $xmm16 = VFMSUBADD231PDZ128r        $xmm16, $xmm1, $xmm2
3888   $xmm16 = VFMSUBADD231PDZ128r                 $xmm16, $xmm1, $xmm2                                      
3889   ; CHECK: $xmm16 = VFMSUBADD231PSZ128m        $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3890   $xmm16 = VFMSUBADD231PSZ128m                 $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3891   ; CHECK: $xmm16 = VFMSUBADD231PSZ128r        $xmm16, $xmm1, $xmm2
3892   $xmm16 = VFMSUBADD231PSZ128r                 $xmm16, $xmm1, $xmm2                                      
3893   ; CHECK: $xmm16 = VFNMADD132PDZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3894   $xmm16 = VFNMADD132PDZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3895   ; CHECK: $xmm16 = VFNMADD132PDZ128r          $xmm16, $xmm1, $xmm2
3896   $xmm16 = VFNMADD132PDZ128r                   $xmm16, $xmm1, $xmm2                                      
3897   ; CHECK: $xmm16 = VFNMADD132PSZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3898   $xmm16 = VFNMADD132PSZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3899   ; CHECK: $xmm16 = VFNMADD132PSZ128r          $xmm16, $xmm1, $xmm2
3900   $xmm16 = VFNMADD132PSZ128r                   $xmm16, $xmm1, $xmm2                                      
3901   ; CHECK: $xmm16 = VFNMADD213PDZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3902   $xmm16 = VFNMADD213PDZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3903   ; CHECK: $xmm16 = VFNMADD213PDZ128r          $xmm16, $xmm1, $xmm2
3904   $xmm16 = VFNMADD213PDZ128r                   $xmm16, $xmm1, $xmm2                                      
3905   ; CHECK: $xmm16 = VFNMADD213PSZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3906   $xmm16 = VFNMADD213PSZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3907   ; CHECK: $xmm16 = VFNMADD213PSZ128r          $xmm16, $xmm1, $xmm2
3908   $xmm16 = VFNMADD213PSZ128r                   $xmm16, $xmm1, $xmm2                                      
3909   ; CHECK: $xmm16 = VFNMADD231PDZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3910   $xmm16 = VFNMADD231PDZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3911   ; CHECK: $xmm16 = VFNMADD231PDZ128r          $xmm16, $xmm1, $xmm2
3912   $xmm16 = VFNMADD231PDZ128r                   $xmm16, $xmm1, $xmm2                                      
3913   ; CHECK: $xmm16 = VFNMADD231PSZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3914   $xmm16 = VFNMADD231PSZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3915   ; CHECK: $xmm16 = VFNMADD231PSZ128r          $xmm16, $xmm1, $xmm2
3916   $xmm16 = VFNMADD231PSZ128r                   $xmm16, $xmm1, $xmm2                                      
3917   ; CHECK: $xmm16 = VFNMSUB132PDZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3918   $xmm16 = VFNMSUB132PDZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3919   ; CHECK: $xmm16 = VFNMSUB132PDZ128r          $xmm16, $xmm1, $xmm2
3920   $xmm16 = VFNMSUB132PDZ128r                   $xmm16, $xmm1, $xmm2                                      
3921   ; CHECK: $xmm16 = VFNMSUB132PSZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3922   $xmm16 = VFNMSUB132PSZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3923   ; CHECK: $xmm16 = VFNMSUB132PSZ128r          $xmm16, $xmm1, $xmm2
3924   $xmm16 = VFNMSUB132PSZ128r                   $xmm16, $xmm1, $xmm2                                      
3925   ; CHECK: $xmm16 = VFNMSUB213PDZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3926   $xmm16 = VFNMSUB213PDZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3927   ; CHECK: $xmm16 = VFNMSUB213PDZ128r          $xmm16, $xmm1, $xmm2
3928   $xmm16 = VFNMSUB213PDZ128r                   $xmm16, $xmm1, $xmm2                                      
3929   ; CHECK: $xmm16 = VFNMSUB213PSZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3930   $xmm16 = VFNMSUB213PSZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3931   ; CHECK: $xmm16 = VFNMSUB213PSZ128r          $xmm16, $xmm1, $xmm2
3932   $xmm16 = VFNMSUB213PSZ128r                   $xmm16, $xmm1, $xmm2                                      
3933   ; CHECK: $xmm16 = VFNMSUB231PDZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3934   $xmm16 = VFNMSUB231PDZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3935   ; CHECK: $xmm16 = VFNMSUB231PDZ128r          $xmm16, $xmm1, $xmm2
3936   $xmm16 = VFNMSUB231PDZ128r                   $xmm16, $xmm1, $xmm2                                      
3937   ; CHECK: $xmm16 = VFNMSUB231PSZ128m          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
3938   $xmm16 = VFNMSUB231PSZ128m                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                          
3939   ; CHECK: $xmm16 = VFNMSUB231PSZ128r          $xmm16, $xmm1, $xmm2 
3940   $xmm16 = VFNMSUB231PSZ128r                   $xmm16, $xmm1, $xmm2                                               
3941   ; CHECK: $xmm16 = VPSLLDZ128ri               $xmm16, 7  
3942   $xmm16 = VPSLLDZ128ri                        $xmm16, 7                                                 
3943   ; CHECK: $xmm16 = VPSLLDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3944   $xmm16 = VPSLLDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3945   ; CHECK: $xmm16 = VPSLLDZ128rr               $xmm16, $xmm16
3946   $xmm16 = VPSLLDZ128rr                        $xmm16, $xmm16
3947   ; CHECK: $xmm16 = VPSLLQZ128ri               $xmm16, 7
3948   $xmm16 = VPSLLQZ128ri                        $xmm16, 7                                                 
3949   ; CHECK: $xmm16 = VPSLLQZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3950   $xmm16 = VPSLLQZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3951   ; CHECK: $xmm16 = VPSLLQZ128rr               $xmm16, $xmm16
3952   $xmm16 = VPSLLQZ128rr                        $xmm16, $xmm16
3953   ; CHECK: $xmm16 = VPSLLVDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3954   $xmm16 = VPSLLVDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3955   ; CHECK: $xmm16 = VPSLLVDZ128rr              $xmm16, $xmm16
3956   $xmm16 = VPSLLVDZ128rr                       $xmm16, $xmm16
3957   ; CHECK: $xmm16 = VPSLLVQZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3958   $xmm16 = VPSLLVQZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3959   ; CHECK: $xmm16 = VPSLLVQZ128rr              $xmm16, $xmm16
3960   $xmm16 = VPSLLVQZ128rr                       $xmm16, $xmm16
3961   ; CHECK: $xmm16 = VPSLLWZ128ri               $xmm16, 7
3962   $xmm16 = VPSLLWZ128ri                        $xmm16, 7                                                 
3963   ; CHECK: $xmm16 = VPSLLWZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3964   $xmm16 = VPSLLWZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3965   ; CHECK: $xmm16 = VPSLLWZ128rr               $xmm16, $xmm16
3966   $xmm16 = VPSLLWZ128rr                        $xmm16, $xmm16
3967   ; CHECK: $xmm16 = VPSRADZ128ri               $xmm16, 7
3968   $xmm16 = VPSRADZ128ri                        $xmm16, 7                                                 
3969   ; CHECK: $xmm16 = VPSRADZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3970   $xmm16 = VPSRADZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3971   ; CHECK: $xmm16 = VPSRADZ128rr               $xmm16, $xmm16
3972   $xmm16 = VPSRADZ128rr                        $xmm16, $xmm16
3973   ; CHECK: $xmm16 = VPSRAVDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3974   $xmm16 = VPSRAVDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3975   ; CHECK: $xmm16 = VPSRAVDZ128rr              $xmm16, $xmm16
3976   $xmm16 = VPSRAVDZ128rr                       $xmm16, $xmm16
3977   ; CHECK: $xmm16 = VPSRAWZ128ri               $xmm16, 7 
3978   $xmm16 = VPSRAWZ128ri                        $xmm16, 7                                                 
3979   ; CHECK: $xmm16 = VPSRAWZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3980   $xmm16 = VPSRAWZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3981   ; CHECK: $xmm16 = VPSRAWZ128rr               $xmm16, $xmm16
3982   $xmm16 = VPSRAWZ128rr                        $xmm16, $xmm16
3983   ; CHECK: $xmm16 = VPSRLDQZ128rr              $xmm16, 14
3984   $xmm16 = VPSRLDQZ128rr                       $xmm16, 14                                                
3985   ; CHECK: $xmm16 = VPSRLDZ128ri               $xmm16, 7 
3986   $xmm16 = VPSRLDZ128ri                        $xmm16, 7                                                 
3987   ; CHECK: $xmm16 = VPSRLDZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3988   $xmm16 = VPSRLDZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3989   ; CHECK: $xmm16 = VPSRLDZ128rr               $xmm16, $xmm16
3990   $xmm16 = VPSRLDZ128rr                        $xmm16, $xmm16
3991   ; CHECK: $xmm16 = VPSRLQZ128ri               $xmm16, 7 
3992   $xmm16 = VPSRLQZ128ri                        $xmm16, 7                                                 
3993   ; CHECK: $xmm16 = VPSRLQZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
3994   $xmm16 = VPSRLQZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
3995   ; CHECK: $xmm16 = VPSRLQZ128rr               $xmm16, $xmm16
3996   $xmm16 = VPSRLQZ128rr                        $xmm16, $xmm16
3997   ; CHECK: $xmm16 = VPSRLVDZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
3998   $xmm16 = VPSRLVDZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
3999   ; CHECK: $xmm16 = VPSRLVDZ128rr              $xmm16, $xmm16
4000   $xmm16 = VPSRLVDZ128rr                       $xmm16, $xmm16
4001   ; CHECK: $xmm16 = VPSRLVQZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
4002   $xmm16 = VPSRLVQZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
4003   ; CHECK: $xmm16 = VPSRLVQZ128rr              $xmm16, $xmm16
4004   $xmm16 = VPSRLVQZ128rr                       $xmm16, $xmm16
4005   ; CHECK: $xmm16 = VPSRLWZ128ri               $xmm16, 7
4006   $xmm16 = VPSRLWZ128ri                        $xmm16, 7                                                 
4007   ; CHECK: $xmm16 = VPSRLWZ128rm               $xmm16, $rip, 1, $rax, 0, $noreg
4008   $xmm16 = VPSRLWZ128rm                        $xmm16, $rip, 1, $rax, 0, $noreg
4009   ; CHECK: $xmm16 = VPSRLWZ128rr               $xmm16, $xmm16
4010   $xmm16 = VPSRLWZ128rr                        $xmm16, $xmm16
4011   ; CHECK: $xmm16 = VPERMILPDZ128mi            $rdi, 1, $noreg, 0, $noreg, 9
4012   $xmm16 = VPERMILPDZ128mi                     $rdi, 1, $noreg, 0, $noreg, 9
4013   ; CHECK: $xmm16 = VPERMILPDZ128ri            $xmm16, 9
4014   $xmm16 = VPERMILPDZ128ri                     $xmm16, 9                                                 
4015   ; CHECK: $xmm16 = VPERMILPDZ128rm            $xmm16, $rdi, 1, $noreg, 0, $noreg
4016   $xmm16 = VPERMILPDZ128rm                     $xmm16, $rdi, 1, $noreg, 0, $noreg                                  
4017   ; CHECK: $xmm16 = VPERMILPDZ128rr            $xmm16, $xmm1
4018   $xmm16 = VPERMILPDZ128rr                     $xmm16, $xmm1                                             
4019   ; CHECK: $xmm16 = VPERMILPSZ128mi            $rdi, 1, $noreg, 0, $noreg, 9
4020   $xmm16 = VPERMILPSZ128mi                     $rdi, 1, $noreg, 0, $noreg, 9
4021   ; CHECK: $xmm16 = VPERMILPSZ128ri            $xmm16, 9
4022   $xmm16 = VPERMILPSZ128ri                     $xmm16, 9                                                 
4023   ; CHECK: $xmm16 = VPERMILPSZ128rm            $xmm16, $rdi, 1, $noreg, 0, $noreg
4024   $xmm16 = VPERMILPSZ128rm                     $xmm16, $rdi, 1, $noreg, 0, $noreg                                  
4025   ; CHECK: $xmm16 = VPERMILPSZ128rr            $xmm16, $xmm1
4026   $xmm16 = VPERMILPSZ128rr                     $xmm16, $xmm1                                               
4027   ; CHECK: $xmm16 = VCVTPH2PSZ128rm            $rdi, 1, $noreg, 0, $noreg
4028   $xmm16 = VCVTPH2PSZ128rm                     $rdi, 1, $noreg, 0, $noreg
4029   ; CHECK: $xmm16 = VCVTPH2PSZ128rr            $xmm16
4030   $xmm16 = VCVTPH2PSZ128rr                     $xmm16                                                    
4031   ; CHECK: $xmm16 = VCVTDQ2PDZ128rm            $rdi, 1, $noreg, 0, $noreg
4032   $xmm16 = VCVTDQ2PDZ128rm                     $rdi, 1, $noreg, 0, $noreg
4033   ; CHECK: $xmm16 = VCVTDQ2PDZ128rr            $xmm16     
4034   $xmm16 = VCVTDQ2PDZ128rr                     $xmm16                                                    
4035   ; CHECK: $xmm16 = VCVTDQ2PSZ128rm            $rdi, 1, $noreg, 0, $noreg
4036   $xmm16 = VCVTDQ2PSZ128rm                     $rdi, 1, $noreg, 0, $noreg
4037   ; CHECK: $xmm16 = VCVTDQ2PSZ128rr            $xmm16   
4038   $xmm16 = VCVTDQ2PSZ128rr                     $xmm16                                                    
4039   ; CHECK: $xmm16 = VCVTPD2DQZ128rm            $rdi, 1, $noreg, 0, $noreg
4040   $xmm16 = VCVTPD2DQZ128rm                     $rdi, 1, $noreg, 0, $noreg
4041   ; CHECK: $xmm16 = VCVTPD2DQZ128rr            $xmm16   
4042   $xmm16 = VCVTPD2DQZ128rr                     $xmm16                                                    
4043   ; CHECK: $xmm16 = VCVTPD2PSZ128rm            $rdi, 1, $noreg, 0, $noreg
4044   $xmm16 = VCVTPD2PSZ128rm                     $rdi, 1, $noreg, 0, $noreg
4045   ; CHECK: $xmm16 = VCVTPD2PSZ128rr            $xmm16   
4046   $xmm16 = VCVTPD2PSZ128rr                     $xmm16                                                    
4047   ; CHECK: $xmm16 = VCVTPS2DQZ128rm            $rdi, 1, $noreg, 0, $noreg
4048   $xmm16 = VCVTPS2DQZ128rm                     $rdi, 1, $noreg, 0, $noreg
4049   ; CHECK: $xmm16 = VCVTPS2DQZ128rr            $xmm16   
4050   $xmm16 = VCVTPS2DQZ128rr                     $xmm16                                                    
4051   ; CHECK: $xmm16 = VCVTPS2PDZ128rm            $rdi, 1, $noreg, 0, $noreg
4052   $xmm16 = VCVTPS2PDZ128rm                     $rdi, 1, $noreg, 0, $noreg
4053   ; CHECK: $xmm16 = VCVTPS2PDZ128rr            $xmm16
4054   $xmm16 = VCVTPS2PDZ128rr                     $xmm16                                                    
4055   ; CHECK: $xmm16 = VCVTTPD2DQZ128rm           $rdi, 1, $noreg, 0, $noreg
4056   $xmm16 = VCVTTPD2DQZ128rm                    $rdi, 1, $noreg, 0, $noreg
4057   ; CHECK: $xmm16 = VCVTTPD2DQZ128rr           $xmm16  
4058   $xmm16 = VCVTTPD2DQZ128rr                    $xmm16                                                    
4059   ; CHECK: $xmm16 = VCVTTPS2DQZ128rm           $rdi, 1, $noreg, 0, $noreg
4060   $xmm16 = VCVTTPS2DQZ128rm                    $rdi, 1, $noreg, 0, $noreg
4061   ; CHECK: $xmm16 = VCVTTPS2DQZ128rr           $xmm16
4062   $xmm16 = VCVTTPS2DQZ128rr                    $xmm16                                                    
4063   ; CHECK: $xmm16 = VSQRTPDZ128m               $rdi, 1, $noreg, 0, $noreg
4064   $xmm16 = VSQRTPDZ128m                        $rdi, 1, $noreg, 0, $noreg
4065   ; CHECK: $xmm16 = VSQRTPDZ128r               $xmm16
4066   $xmm16 = VSQRTPDZ128r                        $xmm16                                                    
4067   ; CHECK: $xmm16 = VSQRTPSZ128m               $rdi, 1, $noreg, 0, $noreg
4068   $xmm16 = VSQRTPSZ128m                        $rdi, 1, $noreg, 0, $noreg
4069   ; CHECK: $xmm16 = VSQRTPSZ128r               $xmm16  
4070   $xmm16 = VSQRTPSZ128r                        $xmm16                                                    
4071   ; CHECK: $xmm16 = VMOVDDUPZ128rm             $rdi, 1, $noreg, 0, $noreg     
4072   $xmm16 = VMOVDDUPZ128rm                      $rdi, 1, $noreg, 0, $noreg                                          
4073   ; CHECK: $xmm16 = VMOVDDUPZ128rr             $xmm16    
4074   $xmm16 = VMOVDDUPZ128rr                      $xmm16                                                    
4075   ; CHECK: $xmm16 = VMOVSHDUPZ128rm            $rdi, 1, $noreg, 0, $noreg    
4076   $xmm16 = VMOVSHDUPZ128rm                     $rdi, 1, $noreg, 0, $noreg                                          
4077   ; CHECK: $xmm16 = VMOVSHDUPZ128rr            $xmm16    
4078   $xmm16 = VMOVSHDUPZ128rr                     $xmm16                                                    
4079   ; CHECK: $xmm16 = VMOVSLDUPZ128rm            $rdi, 1, $noreg, 0, $noreg     
4080   $xmm16 = VMOVSLDUPZ128rm                     $rdi, 1, $noreg, 0, $noreg                                          
4081   ; CHECK: $xmm16 = VMOVSLDUPZ128rr            $xmm16  
4082   $xmm16 = VMOVSLDUPZ128rr                     $xmm16                                                    
4083   ; CHECK: $xmm16 = VPSHUFBZ128rm              $xmm16, $rdi, 1, $noreg, 0, $noreg
4084   $xmm16 = VPSHUFBZ128rm                       $xmm16, $rdi, 1, $noreg, 0, $noreg
4085   ; CHECK: $xmm16 = VPSHUFBZ128rr              $xmm16, $xmm1
4086   $xmm16 = VPSHUFBZ128rr                       $xmm16, $xmm1                                             
4087   ; CHECK: $xmm16 = VPSHUFDZ128mi              $rdi, 1, $noreg, 0, $noreg, -24
4088   $xmm16 = VPSHUFDZ128mi                       $rdi, 1, $noreg, 0, $noreg, -24
4089   ; CHECK: $xmm16 = VPSHUFDZ128ri              $xmm16, -24
4090   $xmm16 = VPSHUFDZ128ri                       $xmm16, -24                                               
4091   ; CHECK: $xmm16 = VPSHUFHWZ128mi             $rdi, 1, $noreg, 0, $noreg, -24
4092   $xmm16 = VPSHUFHWZ128mi                      $rdi, 1, $noreg, 0, $noreg, -24
4093   ; CHECK: $xmm16 = VPSHUFHWZ128ri             $xmm16, -24
4094   $xmm16 = VPSHUFHWZ128ri                      $xmm16, -24                                               
4095   ; CHECK: $xmm16 = VPSHUFLWZ128mi             $rdi, 1, $noreg, 0, $noreg, -24
4096   $xmm16 = VPSHUFLWZ128mi                      $rdi, 1, $noreg, 0, $noreg, -24
4097   ; CHECK: $xmm16 = VPSHUFLWZ128ri             $xmm16, -24
4098   $xmm16 = VPSHUFLWZ128ri                      $xmm16, -24                                               
4099   ; CHECK: $xmm16 = VPSLLDQZ128rr              $xmm16, 1
4100   $xmm16 = VPSLLDQZ128rr                       $xmm16, 1
4101   ; CHECK: $xmm16 = VSHUFPDZ128rmi             $xmm16, $rip, 1, $rax, 0, $noreg, -24
4102   $xmm16 = VSHUFPDZ128rmi                      $xmm16, $rip, 1, $rax, 0, $noreg, -24
4103   ; CHECK: $xmm16 = VSHUFPDZ128rri             $xmm16, $xmm1, -24
4104   $xmm16 = VSHUFPDZ128rri                      $xmm16, $xmm1, -24
4105   ; CHECK: $xmm16 = VSHUFPSZ128rmi             $xmm16, $rip, 1, $rax, 0, $noreg, -24
4106   $xmm16 = VSHUFPSZ128rmi                      $xmm16, $rip, 1, $rax, 0, $noreg, -24
4107   ; CHECK: $xmm16 = VSHUFPSZ128rri             $xmm16, $xmm1, -24
4108   $xmm16 = VSHUFPSZ128rri                      $xmm16, $xmm1, -24
4109   ; CHECK: $xmm16 = VPSADBWZ128rm              $xmm16, $rip, 1, $rax, 0, $noreg
4110   $xmm16 = VPSADBWZ128rm                       $xmm16, $rip, 1, $rax, 0, $noreg
4111   ; CHECK: $xmm16 = VPSADBWZ128rr              $xmm16, $xmm1  
4112   $xmm16 = VPSADBWZ128rr                       $xmm16, $xmm1                                               
4113   ; CHECK: $xmm16 = VBROADCASTSSZ128m          $rip, 1, $rax, 0, $noreg
4114   $xmm16 = VBROADCASTSSZ128m                   $rip, 1, $rax, 0, $noreg
4115   ; CHECK: $xmm16 = VBROADCASTSSZ128r          $xmm16
4116   $xmm16 = VBROADCASTSSZ128r                   $xmm16                                                    
4117   ; CHECK: $xmm16 = VPBROADCASTBZ128m          $rip, 1, $rax, 0, $noreg
4118   $xmm16 = VPBROADCASTBZ128m                   $rip, 1, $rax, 0, $noreg
4119   ; CHECK: $xmm16 = VPBROADCASTBZ128r          $xmm16
4120   $xmm16 = VPBROADCASTBZ128r                   $xmm16                                                    
4121   ; CHECK: $xmm16 = VPBROADCASTDZ128m          $rip, 1, $rax, 0, $noreg
4122   $xmm16 = VPBROADCASTDZ128m                   $rip, 1, $rax, 0, $noreg
4123   ; CHECK: $xmm16 = VPBROADCASTDZ128r          $xmm16
4124   $xmm16 = VPBROADCASTDZ128r                   $xmm16                                                    
4125   ; CHECK: $xmm16 = VPBROADCASTQZ128m          $rip, 1, $rax, 0, $noreg
4126   $xmm16 = VPBROADCASTQZ128m                   $rip, 1, $rax, 0, $noreg
4127   ; CHECK: $xmm16 = VPBROADCASTQZ128r          $xmm16
4128   $xmm16 = VPBROADCASTQZ128r                   $xmm16                                                    
4129   ; CHECK: $xmm16 = VPBROADCASTWZ128m          $rip, 1, $rax, 0, $noreg
4130   $xmm16 = VPBROADCASTWZ128m                   $rip, 1, $rax, 0, $noreg
4131   ; CHECK: $xmm16 = VPBROADCASTWZ128r          $xmm16
4132   $xmm16 = VPBROADCASTWZ128r                   $xmm16                                                                                            
4133   ; CHECK: $xmm16 = VBROADCASTI32X2Z128m       $rip, 1, $rax, 0, $noreg
4134   $xmm16 = VBROADCASTI32X2Z128m                $rip, 1, $rax, 0, $noreg
4135   ; CHECK: $xmm16 = VBROADCASTI32X2Z128r       $xmm0
4136   $xmm16 = VBROADCASTI32X2Z128r                $xmm0
4137   ; CHECK: $xmm16 = VCVTPS2PHZ128rr            $xmm16, 2
4138   $xmm16 = VCVTPS2PHZ128rr                     $xmm16, 2                                                 
4139   ; CHECK: VCVTPS2PHZ128mr                     $rdi, 1, $noreg, 0, $noreg, $xmm16, 2
4140   VCVTPS2PHZ128mr                              $rdi, 1, $noreg, 0, $noreg, $xmm16, 2
4141   ; CHECK: $xmm16 = VPABSBZ128rm               $rip, 1, $rax, 0, $noreg
4142   $xmm16 = VPABSBZ128rm                        $rip, 1, $rax, 0, $noreg
4143   ; CHECK: $xmm16 = VPABSBZ128rr               $xmm16
4144   $xmm16 = VPABSBZ128rr                        $xmm16                                                    
4145   ; CHECK: $xmm16 = VPABSDZ128rm               $rip, 1, $rax, 0, $noreg
4146   $xmm16 = VPABSDZ128rm                        $rip, 1, $rax, 0, $noreg
4147   ; CHECK: $xmm16 = VPABSDZ128rr               $xmm16
4148   $xmm16 = VPABSDZ128rr                        $xmm16                                                    
4149   ; CHECK: $xmm16 = VPABSWZ128rm               $rip, 1, $rax, 0, $noreg
4150   $xmm16 = VPABSWZ128rm                        $rip, 1, $rax, 0, $noreg
4151   ; CHECK: $xmm16 = VPABSWZ128rr               $xmm16
4152   $xmm16 = VPABSWZ128rr                        $xmm16                                                    
4153   ; CHECK: $xmm16 = VPALIGNRZ128rmi            $xmm16, $rdi, 1, $noreg, 0, $noreg, 15
4154   $xmm16 = VPALIGNRZ128rmi                     $xmm16, $rdi, 1, $noreg, 0, $noreg, 15
4155   ; CHECK: $xmm16 = VPALIGNRZ128rri            $xmm16, $xmm1, 15
4156   $xmm16 = VPALIGNRZ128rri                     $xmm16, $xmm1, 15
4157   ; CHECK: VEXTRACTPSZmr                       $rdi, 1, $noreg, 0, $noreg, $xmm16, 1
4158   VEXTRACTPSZmr                                $rdi, 1, $noreg, 0, $noreg, $xmm16, 1
4159   ; CHECK: $eax = VEXTRACTPSZrr                $xmm16, 1
4160   $eax = VEXTRACTPSZrr                         $xmm16, 1
4161   ; CHECK: $xmm16 = VINSERTPSZrm               $xmm16, $rdi, 1, $noreg, 0, $noreg, 1
4162   $xmm16 = VINSERTPSZrm                        $xmm16, $rdi, 1, $noreg, 0, $noreg, 1
4163   ; CHECK: $xmm16 = VINSERTPSZrr               $xmm16, $xmm16, 1
4164   $xmm16 = VINSERTPSZrr                        $xmm16, $xmm16, 1
4165   ; CHECK: $xmm16 = VRNDSCALEPDZ128rmi         $rip, 1, $rax, 0, $noreg, 15
4166   $xmm16 = VRNDSCALEPDZ128rmi                  $rip, 1, $rax, 0, $noreg, 15
4167   ; CHECK: $xmm16 = VRNDSCALEPDZ128rri         $xmm16, 15
4168   $xmm16 = VRNDSCALEPDZ128rri                  $xmm16, 15
4169   ; CHECK: $xmm16 = VRNDSCALEPSZ128rmi         $rip, 1, $rax, 0, $noreg, 15
4170   $xmm16 = VRNDSCALEPSZ128rmi                  $rip, 1, $rax, 0, $noreg, 15
4171   ; CHECK: $xmm16 = VRNDSCALEPSZ128rri         $xmm16, 15
4172   $xmm16 = VRNDSCALEPSZ128rri                  $xmm16, 15
4173   ; CHECK: $xmm0 = VRNDSCALEPDZ128rmi          $rip, 1, $rax, 0, $noreg, 31
4174   $xmm0 = VRNDSCALEPDZ128rmi                   $rip, 1, $rax, 0, $noreg, 31
4175   ; CHECK: $xmm0 = VRNDSCALEPDZ128rri          $xmm0, 31
4176   $xmm0 = VRNDSCALEPDZ128rri                   $xmm0, 31
4177   ; CHECK: $xmm0 = VRNDSCALEPSZ128rmi          $rip, 1, $rax, 0, $noreg, 31
4178   $xmm0 = VRNDSCALEPSZ128rmi                   $rip, 1, $rax, 0, $noreg, 31
4179   ; CHECK: $xmm0 = VRNDSCALEPSZ128rri          $xmm0, 31
4180   $xmm0 = VRNDSCALEPSZ128rri                   $xmm0, 31
4181     
4182       RET 0, $zmm0, $zmm1
4185   # CHECK-LABEL: name: evex_scalar_to_evex_test
4186   # CHECK: bb.0:                               
4188 name: evex_scalar_to_evex_test
4189 body: |
4190   bb.0:
4191   ; CHECK: $xmm16 = VADDSDZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4192   $xmm16 = VADDSDZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4193   ; CHECK: $xmm16 = VADDSDZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4194   $xmm16 = VADDSDZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4195   ; CHECK: $xmm16 = VADDSDZrr                  $xmm16, $xmm1  
4196   $xmm16 = VADDSDZrr                           $xmm16, $xmm1                                              
4197   ; CHECK: $xmm16 = VADDSDZrr_Int              $xmm16, $xmm1
4198   $xmm16 = VADDSDZrr_Int                       $xmm16, $xmm1                                              
4199   ; CHECK: $xmm16 = VADDSSZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4200   $xmm16 = VADDSSZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4201   ; CHECK: $xmm16 = VADDSSZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4202   $xmm16 = VADDSSZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4203   ; CHECK: $xmm16 = VADDSSZrr                  $xmm16, $xmm1
4204   $xmm16 = VADDSSZrr                           $xmm16, $xmm1                                              
4205   ; CHECK: $xmm16 = VADDSSZrr_Int              $xmm16, $xmm1
4206   $xmm16 = VADDSSZrr_Int                       $xmm16, $xmm1                                              
4207   ; CHECK: $xmm16 = VDIVSDZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4208   $xmm16 = VDIVSDZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4209   ; CHECK: $xmm16 = VDIVSDZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4210   $xmm16 = VDIVSDZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4211   ; CHECK: $xmm16 = VDIVSDZrr                  $xmm16, $xmm1  
4212   $xmm16 = VDIVSDZrr                           $xmm16, $xmm1                                              
4213   ; CHECK: $xmm16 = VDIVSDZrr_Int              $xmm16, $xmm1
4214   $xmm16 = VDIVSDZrr_Int                       $xmm16, $xmm1                                              
4215   ; CHECK: $xmm16 = VDIVSSZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4216   $xmm16 = VDIVSSZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4217   ; CHECK: $xmm16 = VDIVSSZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4218   $xmm16 = VDIVSSZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4219   ; CHECK: $xmm16 = VDIVSSZrr                  $xmm16, $xmm1
4220   $xmm16 = VDIVSSZrr                           $xmm16, $xmm1                                              
4221   ; CHECK: $xmm16 = VDIVSSZrr_Int              $xmm16, $xmm1
4222   $xmm16 = VDIVSSZrr_Int                       $xmm16, $xmm1                                              
4223   ; CHECK: $xmm16 = VMAXCSDZrm                 $xmm16, $rip, 1, $rax, 0, $noreg
4224   $xmm16 = VMAXCSDZrm                          $xmm16, $rip, 1, $rax, 0, $noreg
4225   ; CHECK: $xmm16 = VMAXCSDZrr                 $xmm16, $xmm1
4226   $xmm16 = VMAXCSDZrr                          $xmm16, $xmm1                                              
4227   ; CHECK: $xmm16 = VMAXCSSZrm                 $xmm16, $rip, 1, $rax, 0, $noreg
4228   $xmm16 = VMAXCSSZrm                          $xmm16, $rip, 1, $rax, 0, $noreg
4229   ; CHECK: $xmm16 = VMAXCSSZrr                 $xmm16, $xmm1
4230   $xmm16 = VMAXCSSZrr                          $xmm16, $xmm1                                              
4231   ; CHECK: $xmm16 = VMAXSDZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4232   $xmm16 = VMAXSDZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4233   ; CHECK: $xmm16 = VMAXSDZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4234   $xmm16 = VMAXSDZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4235   ; CHECK: $xmm16 = VMAXSDZrr                  $xmm16, $xmm1
4236   $xmm16 = VMAXSDZrr                           $xmm16, $xmm1                                              
4237   ; CHECK: $xmm16 = VMAXSDZrr_Int              $xmm16, $xmm1
4238   $xmm16 = VMAXSDZrr_Int                       $xmm16, $xmm1                                              
4239   ; CHECK: $xmm16 = VMAXSSZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4240   $xmm16 = VMAXSSZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4241   ; CHECK: $xmm16 = VMAXSSZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4242   $xmm16 = VMAXSSZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4243   ; CHECK: $xmm16 = VMAXSSZrr                  $xmm16, $xmm1
4244   $xmm16 = VMAXSSZrr                           $xmm16, $xmm1                                              
4245   ; CHECK: $xmm16 = VMAXSSZrr_Int              $xmm16, $xmm1
4246   $xmm16 = VMAXSSZrr_Int                       $xmm16, $xmm1                                              
4247   ; CHECK: $xmm16 = VMINCSDZrm                 $xmm16, $rip, 1, $rax, 0, $noreg
4248   $xmm16 = VMINCSDZrm                          $xmm16, $rip, 1, $rax, 0, $noreg
4249   ; CHECK: $xmm16 = VMINCSDZrr                 $xmm16, $xmm1
4250   $xmm16 = VMINCSDZrr                          $xmm16, $xmm1                                              
4251   ; CHECK: $xmm16 = VMINCSSZrm                 $xmm16, $rip, 1, $rax, 0, $noreg
4252   $xmm16 = VMINCSSZrm                          $xmm16, $rip, 1, $rax, 0, $noreg
4253   ; CHECK: $xmm16 = VMINCSSZrr                 $xmm16, $xmm1
4254   $xmm16 = VMINCSSZrr                          $xmm16, $xmm1                                              
4255   ; CHECK: $xmm16 = VMINSDZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4256   $xmm16 = VMINSDZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4257   ; CHECK: $xmm16 = VMINSDZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4258   $xmm16 = VMINSDZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4259   ; CHECK: $xmm16 = VMINSDZrr                  $xmm16, $xmm1
4260   $xmm16 = VMINSDZrr                           $xmm16, $xmm1                                              
4261   ; CHECK: $xmm16 = VMINSDZrr_Int              $xmm16, $xmm1
4262   $xmm16 = VMINSDZrr_Int                       $xmm16, $xmm1                                              
4263   ; CHECK: $xmm16 = VMINSSZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4264   $xmm16 = VMINSSZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4265   ; CHECK: $xmm16 = VMINSSZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4266   $xmm16 = VMINSSZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4267   ; CHECK: $xmm16 = VMINSSZrr                  $xmm16, $xmm1
4268   $xmm16 = VMINSSZrr                           $xmm16, $xmm1                                              
4269   ; CHECK: $xmm16 = VMINSSZrr_Int              $xmm16, $xmm1
4270   $xmm16 = VMINSSZrr_Int                       $xmm16, $xmm1                                              
4271   ; CHECK: $xmm16 = VMULSDZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4272   $xmm16 = VMULSDZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4273   ; CHECK: $xmm16 = VMULSDZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4274   $xmm16 = VMULSDZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4275   ; CHECK: $xmm16 = VMULSDZrr                  $xmm16, $xmm1
4276   $xmm16 = VMULSDZrr                           $xmm16, $xmm1                                              
4277   ; CHECK: $xmm16 = VMULSDZrr_Int              $xmm16, $xmm1
4278   $xmm16 = VMULSDZrr_Int                       $xmm16, $xmm1                                              
4279   ; CHECK: $xmm16 = VMULSSZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4280   $xmm16 = VMULSSZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4281   ; CHECK: $xmm16 = VMULSSZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4282   $xmm16 = VMULSSZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4283   ; CHECK: $xmm16 = VMULSSZrr                  $xmm16, $xmm1  
4284   $xmm16 = VMULSSZrr                           $xmm16, $xmm1                                              
4285   ; CHECK: $xmm16 = VMULSSZrr_Int              $xmm16, $xmm1
4286   $xmm16 = VMULSSZrr_Int                       $xmm16, $xmm1                                              
4287   ; CHECK: $xmm16 = VSUBSDZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4288   $xmm16 = VSUBSDZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4289   ; CHECK: $xmm16 = VSUBSDZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4290   $xmm16 = VSUBSDZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4291   ; CHECK: $xmm16 = VSUBSDZrr                  $xmm16, $xmm1  
4292   $xmm16 = VSUBSDZrr                           $xmm16, $xmm1                                              
4293   ; CHECK: $xmm16 = VSUBSDZrr_Int              $xmm16, $xmm1
4294   $xmm16 = VSUBSDZrr_Int                       $xmm16, $xmm1                                              
4295   ; CHECK: $xmm16 = VSUBSSZrm                  $xmm16, $rip, 1, $rax, 0, $noreg
4296   $xmm16 = VSUBSSZrm                           $xmm16, $rip, 1, $rax, 0, $noreg
4297   ; CHECK: $xmm16 = VSUBSSZrm_Int              $xmm16, $rip, 1, $rax, 0, $noreg
4298   $xmm16 = VSUBSSZrm_Int                       $xmm16, $rip, 1, $rax, 0, $noreg
4299   ; CHECK: $xmm16 = VSUBSSZrr                  $xmm16, $xmm1
4300   $xmm16 = VSUBSSZrr                           $xmm16, $xmm1                                              
4301   ; CHECK: $xmm16 = VSUBSSZrr_Int              $xmm16, $xmm1
4302   $xmm16 = VSUBSSZrr_Int                       $xmm16, $xmm1                                               
4303   ; CHECK: $xmm16 = VFMADD132SDZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4304   $xmm16 = VFMADD132SDZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4305   ; CHECK: $xmm16 = VFMADD132SDZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4306   $xmm16 = VFMADD132SDZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4307   ; CHECK: $xmm16 = VFMADD132SDZr              $xmm16, $xmm1, $xmm2
4308   $xmm16 = VFMADD132SDZr                       $xmm16, $xmm1, $xmm2                                       
4309   ; CHECK: $xmm16 = VFMADD132SDZr_Int          $xmm16, $xmm1, $xmm2
4310   $xmm16 = VFMADD132SDZr_Int                   $xmm16, $xmm1, $xmm2                                       
4311   ; CHECK: $xmm16 = VFMADD132SSZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4312   $xmm16 = VFMADD132SSZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4313   ; CHECK: $xmm16 = VFMADD132SSZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4314   $xmm16 = VFMADD132SSZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4315   ; CHECK: $xmm16 = VFMADD132SSZr              $xmm16, $xmm1, $xmm2
4316   $xmm16 = VFMADD132SSZr                       $xmm16, $xmm1, $xmm2                                       
4317   ; CHECK: $xmm16 = VFMADD132SSZr_Int          $xmm16, $xmm1, $xmm2
4318   $xmm16 = VFMADD132SSZr_Int                   $xmm16, $xmm1, $xmm2                                       
4319   ; CHECK: $xmm16 = VFMADD213SDZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4320   $xmm16 = VFMADD213SDZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4321   ; CHECK: $xmm16 = VFMADD213SDZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4322   $xmm16 = VFMADD213SDZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4323   ; CHECK: $xmm16 = VFMADD213SDZr              $xmm16, $xmm1, $xmm2
4324   $xmm16 = VFMADD213SDZr                       $xmm16, $xmm1, $xmm2                                       
4325   ; CHECK: $xmm16 = VFMADD213SDZr_Int          $xmm16, $xmm1, $xmm2
4326   $xmm16 = VFMADD213SDZr_Int                   $xmm16, $xmm1, $xmm2                                       
4327   ; CHECK: $xmm16 = VFMADD213SSZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4328   $xmm16 = VFMADD213SSZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4329   ; CHECK: $xmm16 = VFMADD213SSZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4330   $xmm16 = VFMADD213SSZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4331   ; CHECK: $xmm16 = VFMADD213SSZr              $xmm16, $xmm1, $xmm2
4332   $xmm16 = VFMADD213SSZr                       $xmm16, $xmm1, $xmm2                                       
4333   ; CHECK: $xmm16 = VFMADD213SSZr_Int          $xmm16, $xmm1, $xmm2
4334   $xmm16 = VFMADD213SSZr_Int                   $xmm16, $xmm1, $xmm2                                       
4335   ; CHECK: $xmm16 = VFMADD231SDZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4336   $xmm16 = VFMADD231SDZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4337   ; CHECK: $xmm16 = VFMADD231SDZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4338   $xmm16 = VFMADD231SDZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4339   ; CHECK: $xmm16 = VFMADD231SDZr              $xmm16, $xmm1, $xmm2
4340   $xmm16 = VFMADD231SDZr                       $xmm16, $xmm1, $xmm2                                       
4341   ; CHECK: $xmm16 = VFMADD231SDZr_Int          $xmm16, $xmm1, $xmm2
4342   $xmm16 = VFMADD231SDZr_Int                   $xmm16, $xmm1, $xmm2                                       
4343   ; CHECK: $xmm16 = VFMADD231SSZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4344   $xmm16 = VFMADD231SSZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4345   ; CHECK: $xmm16 = VFMADD231SSZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4346   $xmm16 = VFMADD231SSZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4347   ; CHECK: $xmm16 = VFMADD231SSZr              $xmm16, $xmm1, $xmm2
4348   $xmm16 = VFMADD231SSZr                       $xmm16, $xmm1, $xmm2                                       
4349   ; CHECK: $xmm16 = VFMADD231SSZr_Int          $xmm16, $xmm1, $xmm2
4350   $xmm16 = VFMADD231SSZr_Int                   $xmm16, $xmm1, $xmm2                                       
4351   ; CHECK: $xmm16 = VFMSUB132SDZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4352   $xmm16 = VFMSUB132SDZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4353   ; CHECK: $xmm16 = VFMSUB132SDZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4354   $xmm16 = VFMSUB132SDZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4355   ; CHECK: $xmm16 = VFMSUB132SDZr              $xmm16, $xmm1, $xmm2
4356   $xmm16 = VFMSUB132SDZr                       $xmm16, $xmm1, $xmm2                                       
4357   ; CHECK: $xmm16 = VFMSUB132SDZr_Int          $xmm16, $xmm1, $xmm2
4358   $xmm16 = VFMSUB132SDZr_Int                   $xmm16, $xmm1, $xmm2                                       
4359   ; CHECK: $xmm16 = VFMSUB132SSZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4360   $xmm16 = VFMSUB132SSZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4361   ; CHECK: $xmm16 = VFMSUB132SSZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4362   $xmm16 = VFMSUB132SSZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4363   ; CHECK: $xmm16 = VFMSUB132SSZr              $xmm16, $xmm1, $xmm2
4364   $xmm16 = VFMSUB132SSZr                       $xmm16, $xmm1, $xmm2                                       
4365   ; CHECK: $xmm16 = VFMSUB132SSZr_Int          $xmm16, $xmm1, $xmm2
4366   $xmm16 = VFMSUB132SSZr_Int                   $xmm16, $xmm1, $xmm2                                       
4367   ; CHECK: $xmm16 = VFMSUB213SDZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4368   $xmm16 = VFMSUB213SDZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4369   ; CHECK: $xmm16 = VFMSUB213SDZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4370   $xmm16 = VFMSUB213SDZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4371   ; CHECK: $xmm16 = VFMSUB213SDZr              $xmm16, $xmm1, $xmm2
4372   $xmm16 = VFMSUB213SDZr                       $xmm16, $xmm1, $xmm2                                       
4373   ; CHECK: $xmm16 = VFMSUB213SDZr_Int          $xmm16, $xmm1, $xmm2
4374   $xmm16 = VFMSUB213SDZr_Int                   $xmm16, $xmm1, $xmm2                                       
4375   ; CHECK: $xmm16 = VFMSUB213SSZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4376   $xmm16 = VFMSUB213SSZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4377   ; CHECK: $xmm16 = VFMSUB213SSZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4378   $xmm16 = VFMSUB213SSZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4379   ; CHECK: $xmm16 = VFMSUB213SSZr              $xmm16, $xmm1, $xmm2
4380   $xmm16 = VFMSUB213SSZr                       $xmm16, $xmm1, $xmm2                                       
4381   ; CHECK: $xmm16 = VFMSUB213SSZr_Int          $xmm16, $xmm1, $xmm2
4382   $xmm16 = VFMSUB213SSZr_Int                   $xmm16, $xmm1, $xmm2                                       
4383   ; CHECK: $xmm16 = VFMSUB231SDZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4384   $xmm16 = VFMSUB231SDZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4385   ; CHECK: $xmm16 = VFMSUB231SDZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4386   $xmm16 = VFMSUB231SDZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4387   ; CHECK: $xmm16 = VFMSUB231SDZr              $xmm16, $xmm1, $xmm2
4388   $xmm16 = VFMSUB231SDZr                       $xmm16, $xmm1, $xmm2                                       
4389   ; CHECK: $xmm16 = VFMSUB231SDZr_Int          $xmm16, $xmm1, $xmm2
4390   $xmm16 = VFMSUB231SDZr_Int                   $xmm16, $xmm1, $xmm2                                       
4391   ; CHECK: $xmm16 = VFMSUB231SSZm              $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4392   $xmm16 = VFMSUB231SSZm                       $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4393   ; CHECK: $xmm16 = VFMSUB231SSZm_Int          $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4394   $xmm16 = VFMSUB231SSZm_Int                   $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4395   ; CHECK: $xmm16 = VFMSUB231SSZr              $xmm16, $xmm1, $xmm2
4396   $xmm16 = VFMSUB231SSZr                       $xmm16, $xmm1, $xmm2                                       
4397   ; CHECK: $xmm16 = VFMSUB231SSZr_Int          $xmm16, $xmm1, $xmm2
4398   $xmm16 = VFMSUB231SSZr_Int                   $xmm16, $xmm1, $xmm2                                       
4399   ; CHECK: $xmm16 = VFNMADD132SDZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4400   $xmm16 = VFNMADD132SDZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4401   ; CHECK: $xmm16 = VFNMADD132SDZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4402   $xmm16 = VFNMADD132SDZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4403   ; CHECK: $xmm16 = VFNMADD132SDZr             $xmm16, $xmm1, $xmm2
4404   $xmm16 = VFNMADD132SDZr                      $xmm16, $xmm1, $xmm2                                       
4405   ; CHECK: $xmm16 = VFNMADD132SDZr_Int         $xmm16, $xmm1, $xmm2
4406   $xmm16 = VFNMADD132SDZr_Int                  $xmm16, $xmm1, $xmm2                                       
4407   ; CHECK: $xmm16 = VFNMADD132SSZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4408   $xmm16 = VFNMADD132SSZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4409   ; CHECK: $xmm16 = VFNMADD132SSZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4410   $xmm16 = VFNMADD132SSZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4411   ; CHECK: $xmm16 = VFNMADD132SSZr             $xmm16, $xmm1, $xmm2
4412   $xmm16 = VFNMADD132SSZr                      $xmm16, $xmm1, $xmm2                                       
4413   ; CHECK: $xmm16 = VFNMADD132SSZr_Int         $xmm16, $xmm1, $xmm2
4414   $xmm16 = VFNMADD132SSZr_Int                  $xmm16, $xmm1, $xmm2                                       
4415   ; CHECK: $xmm16 = VFNMADD213SDZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4416   $xmm16 = VFNMADD213SDZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4417   ; CHECK: $xmm16 = VFNMADD213SDZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4418   $xmm16 = VFNMADD213SDZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4419   ; CHECK: $xmm16 = VFNMADD213SDZr             $xmm16, $xmm1, $xmm2
4420   $xmm16 = VFNMADD213SDZr                      $xmm16, $xmm1, $xmm2                                       
4421   ; CHECK: $xmm16 = VFNMADD213SDZr_Int         $xmm16, $xmm1, $xmm2
4422   $xmm16 = VFNMADD213SDZr_Int                  $xmm16, $xmm1, $xmm2                                       
4423   ; CHECK: $xmm16 = VFNMADD213SSZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4424   $xmm16 = VFNMADD213SSZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4425   ; CHECK: $xmm16 = VFNMADD213SSZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4426   $xmm16 = VFNMADD213SSZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4427   ; CHECK: $xmm16 = VFNMADD213SSZr             $xmm16, $xmm1, $xmm2
4428   $xmm16 = VFNMADD213SSZr                      $xmm16, $xmm1, $xmm2                                       
4429   ; CHECK: $xmm16 = VFNMADD213SSZr_Int         $xmm16, $xmm1, $xmm2
4430   $xmm16 = VFNMADD213SSZr_Int                  $xmm16, $xmm1, $xmm2                                       
4431   ; CHECK: $xmm16 = VFNMADD231SDZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4432   $xmm16 = VFNMADD231SDZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4433   ; CHECK: $xmm16 = VFNMADD231SDZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4434   $xmm16 = VFNMADD231SDZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4435   ; CHECK: $xmm16 = VFNMADD231SDZr             $xmm16, $xmm1, $xmm2
4436   $xmm16 = VFNMADD231SDZr                      $xmm16, $xmm1, $xmm2                                       
4437   ; CHECK: $xmm16 = VFNMADD231SDZr_Int         $xmm16, $xmm1, $xmm2
4438   $xmm16 = VFNMADD231SDZr_Int                  $xmm16, $xmm1, $xmm2                                       
4439   ; CHECK: $xmm16 = VFNMADD231SSZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4440   $xmm16 = VFNMADD231SSZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4441   ; CHECK: $xmm16 = VFNMADD231SSZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4442   $xmm16 = VFNMADD231SSZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4443   ; CHECK: $xmm16 = VFNMADD231SSZr             $xmm16, $xmm1, $xmm2
4444   $xmm16 = VFNMADD231SSZr                      $xmm16, $xmm1, $xmm2                                       
4445   ; CHECK: $xmm16 = VFNMADD231SSZr_Int         $xmm16, $xmm1, $xmm2
4446   $xmm16 = VFNMADD231SSZr_Int                  $xmm16, $xmm1, $xmm2                                       
4447   ; CHECK: $xmm16 = VFNMSUB132SDZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4448   $xmm16 = VFNMSUB132SDZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4449   ; CHECK: $xmm16 = VFNMSUB132SDZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4450   $xmm16 = VFNMSUB132SDZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4451   ; CHECK: $xmm16 = VFNMSUB132SDZr             $xmm16, $xmm1, $xmm2
4452   $xmm16 = VFNMSUB132SDZr                      $xmm16, $xmm1, $xmm2                                       
4453   ; CHECK: $xmm16 = VFNMSUB132SDZr_Int         $xmm16, $xmm1, $xmm2
4454   $xmm16 = VFNMSUB132SDZr_Int                  $xmm16, $xmm1, $xmm2                                       
4455   ; CHECK: $xmm16 = VFNMSUB132SSZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4456   $xmm16 = VFNMSUB132SSZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4457   ; CHECK: $xmm16 = VFNMSUB132SSZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4458   $xmm16 = VFNMSUB132SSZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4459   ; CHECK: $xmm16 = VFNMSUB132SSZr             $xmm16, $xmm1, $xmm2
4460   $xmm16 = VFNMSUB132SSZr                      $xmm16, $xmm1, $xmm2                                       
4461   ; CHECK: $xmm16 = VFNMSUB132SSZr_Int         $xmm16, $xmm1, $xmm2
4462   $xmm16 = VFNMSUB132SSZr_Int                  $xmm16, $xmm1, $xmm2                                       
4463   ; CHECK: $xmm16 = VFNMSUB213SDZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4464   $xmm16 = VFNMSUB213SDZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4465   ; CHECK: $xmm16 = VFNMSUB213SDZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4466   $xmm16 = VFNMSUB213SDZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4467   ; CHECK: $xmm16 = VFNMSUB213SDZr             $xmm16, $xmm1, $xmm2
4468   $xmm16 = VFNMSUB213SDZr                      $xmm16, $xmm1, $xmm2                                       
4469   ; CHECK: $xmm16 = VFNMSUB213SDZr_Int         $xmm16, $xmm1, $xmm2
4470   $xmm16 = VFNMSUB213SDZr_Int                  $xmm16, $xmm1, $xmm2                                       
4471   ; CHECK: $xmm16 = VFNMSUB213SSZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4472   $xmm16 = VFNMSUB213SSZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4473   ; CHECK: $xmm16 = VFNMSUB213SSZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4474   $xmm16 = VFNMSUB213SSZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4475   ; CHECK: $xmm16 = VFNMSUB213SSZr             $xmm16, $xmm1, $xmm2
4476   $xmm16 = VFNMSUB213SSZr                      $xmm16, $xmm1, $xmm2                                       
4477   ; CHECK: $xmm16 = VFNMSUB213SSZr_Int         $xmm16, $xmm1, $xmm2
4478   $xmm16 = VFNMSUB213SSZr_Int                  $xmm16, $xmm1, $xmm2                                       
4479   ; CHECK: $xmm16 = VFNMSUB231SDZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4480   $xmm16 = VFNMSUB231SDZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4481   ; CHECK: $xmm16 = VFNMSUB231SDZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4482   $xmm16 = VFNMSUB231SDZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4483   ; CHECK: $xmm16 = VFNMSUB231SDZr             $xmm16, $xmm1, $xmm2
4484   $xmm16 = VFNMSUB231SDZr                      $xmm16, $xmm1, $xmm2                                       
4485   ; CHECK: $xmm16 = VFNMSUB231SDZr_Int         $xmm16, $xmm1, $xmm2
4486   $xmm16 = VFNMSUB231SDZr_Int                  $xmm16, $xmm1, $xmm2                                       
4487   ; CHECK: $xmm16 = VFNMSUB231SSZm             $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4488   $xmm16 = VFNMSUB231SSZm                      $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4489   ; CHECK: $xmm16 = VFNMSUB231SSZm_Int         $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg
4490   $xmm16 = VFNMSUB231SSZm_Int                  $xmm16, $xmm16, $rsi, 1, $noreg, 0, $noreg                           
4491   ; CHECK: $xmm16 = VFNMSUB231SSZr             $xmm16, $xmm1, $xmm2
4492   $xmm16 = VFNMSUB231SSZr                      $xmm16, $xmm1, $xmm2                                       
4493   ; CHECK: $xmm16 = VFNMSUB231SSZr_Int         $xmm16, $xmm1, $xmm2
4494   $xmm16 = VFNMSUB231SSZr_Int                  $xmm16, $xmm1, $xmm2                                               
4495   ; CHECK: VPEXTRBZmr                          $rdi, 1, $noreg, 0, $noreg, $xmm16, 3       
4496   VPEXTRBZmr                                   $rdi, 1, $noreg, 0, $noreg, $xmm16, 3                                
4497   ; CHECK: $eax = VPEXTRBZrr                   $xmm16, 1    
4498   $eax = VPEXTRBZrr                            $xmm16, 1                                                  
4499   ; CHECK: VPEXTRDZmr                          $rdi, 1, $noreg, 0, $noreg, $xmm16, 3      
4500   VPEXTRDZmr                                   $rdi, 1, $noreg, 0, $noreg, $xmm16, 3                                
4501   ; CHECK: $eax = VPEXTRDZrr                   $xmm16, 1     
4502   $eax = VPEXTRDZrr                            $xmm16, 1                                                  
4503   ; CHECK: VPEXTRQZmr                          $rdi, 1, $noreg, 0, $noreg, $xmm16, 3       
4504   VPEXTRQZmr                                   $rdi, 1, $noreg, 0, $noreg, $xmm16, 3                                
4505   ; CHECK: $rax = VPEXTRQZrr                   $xmm16, 1      
4506   $rax = VPEXTRQZrr                            $xmm16, 1                                                  
4507   ; CHECK: VPEXTRWZmr                          $rdi, 1, $noreg, 0, $noreg,  $xmm16, 3       
4508   VPEXTRWZmr                                   $rdi, 1, $noreg, 0, $noreg,  $xmm16, 3                               
4509   ; CHECK: $eax = VPEXTRWZrr                   $xmm16, 1      
4510   $eax = VPEXTRWZrr                            $xmm16, 1                                                     
4511   ; CHECK: $eax = VPEXTRWZrr_REV               $xmm16, 1      
4512   $eax = VPEXTRWZrr_REV                        $xmm16, 1                                                     
4513   ; CHECK: $xmm16 = VPINSRBZrm                 $xmm16, $rsi, 1, $noreg, 0, $noreg, 3      
4514   $xmm16 = VPINSRBZrm                          $xmm16, $rsi, 1, $noreg, 0, $noreg, 3                                
4515   ; CHECK: $xmm16 = VPINSRBZrr                 $xmm16, $edi, 5      
4516   $xmm16 = VPINSRBZrr                          $xmm16, $edi, 5                                            
4517   ; CHECK: $xmm16 = VPINSRDZrm                 $xmm16, $rsi, 1, $noreg, 0, $noreg, 3      
4518   $xmm16 = VPINSRDZrm                          $xmm16, $rsi, 1, $noreg, 0, $noreg, 3                                
4519   ; CHECK: $xmm16 = VPINSRDZrr                 $xmm16, $edi, 5            
4520   $xmm16 = VPINSRDZrr                          $xmm16, $edi, 5                                            
4521   ; CHECK: $xmm16 = VPINSRQZrm                 $xmm16, $rsi, 1, $noreg, 0, $noreg, 3      
4522   $xmm16 = VPINSRQZrm                          $xmm16, $rsi, 1, $noreg, 0, $noreg, 3                                
4523   ; CHECK: $xmm16 = VPINSRQZrr                 $xmm16, $rdi, 5            
4524   $xmm16 = VPINSRQZrr                          $xmm16, $rdi, 5                                            
4525   ; CHECK: $xmm16 = VPINSRWZrm                 $xmm16, $rsi, 1, $noreg, 0, $noreg, 3      
4526   $xmm16 = VPINSRWZrm                          $xmm16, $rsi, 1, $noreg, 0, $noreg, 3                                
4527   ; CHECK: $xmm16 = VPINSRWZrr                 $xmm16, $edi, 5
4528   $xmm16 = VPINSRWZrr                          $xmm16, $edi, 5                                               
4529   ; CHECK: $xmm16 = VSQRTSDZm                  $xmm16, $rdi, 1, $noreg, 0, $noreg
4530   $xmm16 = VSQRTSDZm                           $xmm16, $rdi, 1, $noreg, 0, $noreg
4531   ; CHECK: $xmm16 = VSQRTSDZm_Int              $xmm16, $rdi, 1, $noreg, 0, $noreg
4532   $xmm16 = VSQRTSDZm_Int                       $xmm16, $rdi, 1, $noreg, 0, $noreg
4533   ; CHECK: $xmm16 = VSQRTSDZr                  $xmm16, $xmm1 
4534   $xmm16 = VSQRTSDZr                           $xmm16, $xmm1                                                  
4535   ; CHECK: $xmm16 = VSQRTSDZr_Int              $xmm16, $xmm1
4536   $xmm16 = VSQRTSDZr_Int                       $xmm16, $xmm1                                                  
4537   ; CHECK: $xmm16 = VSQRTSSZm                  $xmm16, $rdi, 1, $noreg, 0, $noreg
4538   $xmm16 = VSQRTSSZm                           $xmm16, $rdi, 1, $noreg, 0, $noreg
4539   ; CHECK: $xmm16 = VSQRTSSZm_Int              $xmm16, $rdi, 1, $noreg, 0, $noreg
4540   $xmm16 = VSQRTSSZm_Int                       $xmm16, $rdi, 1, $noreg, 0, $noreg
4541   ; CHECK: $xmm16 = VSQRTSSZr                  $xmm16, $xmm1
4542   $xmm16 = VSQRTSSZr                           $xmm16, $xmm1                                                  
4543   ; CHECK: $xmm16 = VSQRTSSZr_Int              $xmm16, $xmm1
4544   $xmm16 = VSQRTSSZr_Int                       $xmm16, $xmm1                                                  
4545   ; CHECK: $rdi = VCVTSD2SI64rm_Int            $rdi, 1, $noreg, 0, $noreg
4546   $rdi = VCVTSD2SI64Zrm_Int                    $rdi, 1, $noreg, 0, $noreg
4547   ; CHECK: $rdi = VCVTSD2SI64Zrr_Int           $xmm16
4548   $rdi = VCVTSD2SI64Zrr_Int                    $xmm16                                                     
4549   ; CHECK: $edi = VCVTSD2SIrm_Int              $rdi, 1, $noreg, 0, $noreg
4550   $edi = VCVTSD2SIZrm_Int                      $rdi, 1, $noreg, 0, $noreg
4551   ; CHECK: $edi = VCVTSD2SIZrr_Int             $xmm16
4552   $edi = VCVTSD2SIZrr_Int                      $xmm16                                                     
4553   ; CHECK: $xmm16 = VCVTSD2SSZrm               $xmm16, $rdi, 1, $noreg, 0, $noreg
4554   $xmm16 = VCVTSD2SSZrm                        $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4555   ; CHECK: $xmm16 = VCVTSD2SSZrm_Int           $xmm16, $rdi, 1, $noreg, 0, $noreg
4556   $xmm16 = VCVTSD2SSZrm_Int                    $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4557   ; CHECK: $xmm16 = VCVTSD2SSZrr               $xmm16, $noreg
4558   $xmm16 = VCVTSD2SSZrr                        $xmm16, $noreg                                                  
4559   ; CHECK: $xmm16 = VCVTSD2SSZrr_Int           $xmm16, $noreg
4560   $xmm16 = VCVTSD2SSZrr_Int                    $xmm16, $noreg                                                  
4561   ; CHECK: $xmm16 = VCVTSI2SDZrm               $xmm16, $rdi, 1, $noreg, 0, $noreg
4562   $xmm16 = VCVTSI2SDZrm                        $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4563   ; CHECK: $xmm16 = VCVTSI2SDZrm_Int           $xmm16, $rdi, 1, $noreg, 0, $noreg
4564   $xmm16 = VCVTSI2SDZrm_Int                    $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4565   ; CHECK: $xmm16 = VCVTSI2SDZrr               $xmm16, $noreg
4566   $xmm16 = VCVTSI2SDZrr                        $xmm16, $noreg                                                  
4567   ; CHECK: $xmm16 = VCVTSI2SDZrr_Int           $xmm16, $noreg
4568   $xmm16 = VCVTSI2SDZrr_Int                    $xmm16, $noreg                                                  
4569   ; CHECK: $xmm16 = VCVTSI2SSZrm               $xmm16, $rdi, 1, $noreg, 0, $noreg
4570   $xmm16 = VCVTSI2SSZrm                        $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4571   ; CHECK: $xmm16 = VCVTSI2SSZrm_Int           $xmm16, $rdi, 1, $noreg, 0, $noreg
4572   $xmm16 = VCVTSI2SSZrm_Int                    $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4573   ; CHECK: $xmm16 = VCVTSI2SSZrr               $xmm16, $noreg
4574   $xmm16 = VCVTSI2SSZrr                        $xmm16, $noreg                                                  
4575   ; CHECK: $xmm16 = VCVTSI2SSZrr_Int           $xmm16, $noreg
4576   $xmm16 = VCVTSI2SSZrr_Int                    $xmm16, $noreg                                                  
4577   ; CHECK: $xmm16 = VCVTSI642SDZrm             $xmm16, $rdi, 1, $noreg, 0, $noreg
4578   $xmm16 = VCVTSI642SDZrm                      $xmm16, $rdi, 1, $noreg, 0, $noreg
4579   ; CHECK: $xmm16 = VCVTSI642SDZrm_Int         $xmm16, $rdi, 1, $noreg, 0, $noreg
4580   $xmm16 = VCVTSI642SDZrm_Int                  $xmm16, $rdi, 1, $noreg, 0, $noreg
4581   ; CHECK: $xmm16 = VCVTSI642SDZrr             $xmm16, $noreg
4582   $xmm16 = VCVTSI642SDZrr                      $xmm16, $noreg
4583   ; CHECK: $xmm16 = VCVTSI642SDZrr_Int         $xmm16, $noreg
4584   $xmm16 = VCVTSI642SDZrr_Int                  $xmm16, $noreg
4585   ; CHECK: $xmm16 = VCVTSI642SSZrm             $xmm16, $rdi, 1, $noreg, 0, $noreg 
4586   $xmm16 = VCVTSI642SSZrm                      $xmm16, $rdi, 1, $noreg, 0, $noreg
4587   ; CHECK: $xmm16 = VCVTSI642SSZrm_Int         $xmm16, $rdi, 1, $noreg, 0, $noreg
4588   $xmm16 = VCVTSI642SSZrm_Int                  $xmm16, $rdi, 1, $noreg, 0, $noreg
4589   ; CHECK: $xmm16 = VCVTSI642SSZrr             $xmm16, $noreg 
4590   $xmm16 = VCVTSI642SSZrr                      $xmm16, $noreg
4591   ; CHECK: $xmm16 = VCVTSI642SSZrr_Int         $xmm16, $noreg
4592   $xmm16 = VCVTSI642SSZrr_Int                  $xmm16, $noreg
4593   ; CHECK: $xmm16 = VCVTSS2SDZrm               $xmm16, $rdi, 1, $noreg, 0, $noreg
4594   $xmm16 = VCVTSS2SDZrm                        $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4595   ; CHECK: $xmm16 = VCVTSS2SDZrm_Int           $xmm16, $rdi, 1, $noreg, 0, $noreg
4596   $xmm16 = VCVTSS2SDZrm_Int                    $xmm16, $rdi, 1, $noreg, 0, $noreg                                   
4597   ; CHECK: $xmm16 = VCVTSS2SDZrr               $xmm16, $noreg
4598   $xmm16 = VCVTSS2SDZrr                        $xmm16, $noreg                                                  
4599   ; CHECK: $xmm16 = VCVTSS2SDZrr_Int           $xmm16, $noreg
4600   $xmm16 = VCVTSS2SDZrr_Int                    $xmm16, $noreg                                                  
4601   ; CHECK: $rdi = VCVTSS2SI64rm_Int            $rdi, 1, $noreg, 0, $noreg
4602   $rdi = VCVTSS2SI64Zrm_Int                    $rdi, 1, $noreg, 0, $noreg
4603   ; CHECK: $rdi = VCVTSS2SI64Zrr_Int           $xmm16
4604   $rdi = VCVTSS2SI64Zrr_Int                    $xmm16                                                     
4605   ; CHECK: $edi = VCVTSS2SIrm_Int              $rdi, 1, $noreg, 0, $noreg
4606   $edi = VCVTSS2SIZrm_Int                      $rdi, 1, $noreg, 0, $noreg
4607   ; CHECK: $edi = VCVTSS2SIZrr_Int             $xmm16
4608   $edi = VCVTSS2SIZrr_Int                      $xmm16                                                     
4609   ; CHECK: $rdi = VCVTTSD2SI64rm               $rdi, 1, $noreg, 0, $noreg
4610   $rdi = VCVTTSD2SI64Zrm                       $rdi, 1, $noreg, 0, $noreg
4611   ; CHECK: $rdi = VCVTTSD2SI64rm_Int           $rdi, 1, $noreg, 0, $noreg
4612   $rdi = VCVTTSD2SI64Zrm_Int                   $rdi, 1, $noreg, 0, $noreg
4613   ; CHECK: $rdi = VCVTTSD2SI64Zrr              $xmm16
4614   $rdi = VCVTTSD2SI64Zrr                       $xmm16                                                     
4615   ; CHECK: $rdi = VCVTTSD2SI64Zrr_Int          $xmm16
4616   $rdi = VCVTTSD2SI64Zrr_Int                   $xmm16                                                     
4617   ; CHECK: $edi = VCVTTSD2SIrm                 $rdi, 1, $noreg, 0, $noreg
4618   $edi = VCVTTSD2SIZrm                         $rdi, 1, $noreg, 0, $noreg
4619   ; CHECK: $edi = VCVTTSD2SIrm_Int             $rdi, 1, $noreg, 0, $noreg
4620   $edi = VCVTTSD2SIZrm_Int                     $rdi, 1, $noreg, 0, $noreg
4621   ; CHECK: $edi = VCVTTSD2SIZrr                $xmm16
4622   $edi = VCVTTSD2SIZrr                         $xmm16                                                     
4623   ; CHECK: $edi = VCVTTSD2SIZrr_Int            $xmm16
4624   $edi = VCVTTSD2SIZrr_Int                     $xmm16                                                     
4625   ; CHECK: $rdi = VCVTTSS2SI64rm               $rdi, 1, $noreg, 0, $noreg
4626   $rdi = VCVTTSS2SI64Zrm                       $rdi, 1, $noreg, 0, $noreg
4627   ; CHECK: $rdi = VCVTTSS2SI64rm_Int           $rdi, 1, $noreg, 0, $noreg
4628   $rdi = VCVTTSS2SI64Zrm_Int                   $rdi, 1, $noreg, 0, $noreg
4629   ; CHECK: $rdi = VCVTTSS2SI64Zrr              $xmm16
4630   $rdi = VCVTTSS2SI64Zrr                       $xmm16                                                     
4631   ; CHECK: $rdi = VCVTTSS2SI64Zrr_Int          $xmm16
4632   $rdi = VCVTTSS2SI64Zrr_Int                   $xmm16                                                     
4633   ; CHECK: $edi = VCVTTSS2SIrm                 $rdi, 1, $noreg, 0, $noreg
4634   $edi = VCVTTSS2SIZrm                         $rdi, 1, $noreg, 0, $noreg
4635   ; CHECK: $edi = VCVTTSS2SIrm_Int             $rdi, 1, $noreg, 0, $noreg
4636   $edi = VCVTTSS2SIZrm_Int                     $rdi, 1, $noreg, 0, $noreg
4637   ; CHECK: $edi = VCVTTSS2SIZrr                $xmm16
4638   $edi = VCVTTSS2SIZrr                         $xmm16                                                     
4639   ; CHECK: $edi = VCVTTSS2SIZrr_Int            $xmm16  
4640   $edi = VCVTTSS2SIZrr_Int                     $xmm16                                                     
4641   ; CHECK: $xmm16 = VMOV64toSDZrr              $rdi    
4642   $xmm16 = VMOV64toSDZrr                       $rdi                                                       
4643   ; CHECK: $xmm16 = VMOVDI2SSZrr               $eax
4644   $xmm16 = VMOVDI2SSZrr                        $eax                                                       
4645   ; CHECK: VMOVSDZmr                           $rdi, 1, $noreg, 0, $noreg, $xmm16
4646   VMOVSDZmr                                    $rdi, 1, $noreg, 0, $noreg, $xmm16
4647   ; CHECK: $xmm16 = VMOVSDZrm                  $rip, 1, $rax, 0, $noreg
4648   $xmm16 = VMOVSDZrm                           $rip, 1, $rax, 0, $noreg
4649   ; CHECK: $xmm16 = VMOVSDZrm_alt              $rip, 1, $rax, 0, $noreg
4650   $xmm16 = VMOVSDZrm_alt                       $rip, 1, $rax, 0, $noreg
4651   ; CHECK: $xmm16 = VMOVSDZrr                  $xmm16, $xmm1
4652   $xmm16 = VMOVSDZrr                           $xmm16, $xmm1                                                  
4653   ; CHECK: $xmm16 = VMOVSDZrr_REV              $xmm16, $xmm1
4654   $xmm16 = VMOVSDZrr_REV                       $xmm16, $xmm1                                                
4655   ; CHECK: $rax = VMOVSDto64Zrr                $xmm16
4656   $rax = VMOVSDto64Zrr                         $xmm16
4657   ; CHECK: VMOVSSZmr                           $rdi, 1, $noreg, 0, $noreg, $xmm16
4658   VMOVSSZmr                                    $rdi, 1, $noreg, 0, $noreg, $xmm16
4659   ; CHECK: $xmm16 = VMOVSSZrm                  $rip, 1, $rax, 0, $noreg
4660   $xmm16 = VMOVSSZrm                           $rip, 1, $rax, 0, $noreg
4661   ; CHECK: $xmm16 = VMOVSSZrm_alt              $rip, 1, $rax, 0, $noreg
4662   $xmm16 = VMOVSSZrm_alt                       $rip, 1, $rax, 0, $noreg
4663   ; CHECK: $xmm16 = VMOVSSZrr                  $xmm16, $xmm1
4664   $xmm16 = VMOVSSZrr                           $xmm16, $xmm1                                                  
4665   ; CHECK: $xmm16 = VMOVSSZrr_REV              $xmm16, $xmm1
4666   $xmm16 = VMOVSSZrr_REV                       $xmm16, $xmm1                                                  
4667   ; CHECK: $eax = VMOVSS2DIZrr                 $xmm16
4668   $eax = VMOVSS2DIZrr                          $xmm16
4669   ; CHECK: $xmm16 = VMOV64toPQIZrr             $rdi
4670   $xmm16 = VMOV64toPQIZrr                      $rdi                                                       
4671   ; CHECK: $xmm16 = VMOV64toPQIZrm             $rdi, 1, $noreg, 0, $noreg
4672   $xmm16 = VMOV64toPQIZrm                      $rdi, 1, $noreg, 0, $noreg
4673   ; CHECK: $xmm16 = VMOV64toSDZrr              $rdi 
4674   $xmm16 = VMOV64toSDZrr                       $rdi                                                       
4675   ; CHECK: $xmm16 = VMOVDI2PDIZrm              $rip, 1, $rax, 0, $noreg
4676   $xmm16 = VMOVDI2PDIZrm                       $rip, 1, $rax, 0, $noreg
4677   ; CHECK: $xmm16 = VMOVDI2PDIZrr              $edi
4678   $xmm16 = VMOVDI2PDIZrr                       $edi                                                       
4679   ; CHECK: $xmm16 = VMOVLHPSZrr                $xmm16, $xmm1
4680   $xmm16 = VMOVLHPSZrr                         $xmm16, $xmm1
4681   ; CHECK: $xmm16 = VMOVHLPSZrr                $xmm16, $xmm1
4682   $xmm16 = VMOVHLPSZrr                         $xmm16, $xmm1
4683   ; CHECK: VMOVPDI2DIZmr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
4684   VMOVPDI2DIZmr                                $rdi, 1, $noreg, 0, $noreg, $xmm16
4685   ; CHECK: $edi = VMOVPDI2DIZrr                $xmm16
4686   $edi = VMOVPDI2DIZrr                         $xmm16                                                     
4687   ; CHECK: $xmm16 = VMOVPQI2QIZrr              $xmm16
4688   $xmm16 = VMOVPQI2QIZrr                       $xmm16
4689   ; CHECK: VMOVPQI2QIZmr                       $rdi, 1, $noreg, 0, $noreg, $xmm16
4690   VMOVPQI2QIZmr                                $rdi, 1, $noreg, 0, $noreg, $xmm16
4691   ; CHECK: $rdi = VMOVPQIto64Zrr               $xmm16
4692   $rdi = VMOVPQIto64Zrr                        $xmm16                                                     
4693   ; CHECK: VMOVPQIto64Zmr                      $rdi, 1, $noreg, 0, $noreg, $xmm16
4694   VMOVPQIto64Zmr                               $rdi, 1, $noreg, 0, $noreg, $xmm16
4695   ; CHECK: $xmm16 = VMOVQI2PQIZrm              $rip, 1, $rax, 0, $noreg
4696   $xmm16 = VMOVQI2PQIZrm                       $rip, 1, $rax, 0, $noreg
4697   ; CHECK: $xmm16 = VMOVZPQILo2PQIZrr          $xmm16
4698   $xmm16 = VMOVZPQILo2PQIZrr                   $xmm16                                                     
4699   ; CHECK: VCOMISDZrm_Int                      $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4700   VCOMISDZrm_Int                               $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4701   ; CHECK: VCOMISDZrr_Int                      $xmm16, $xmm1, implicit-def $eflags  
4702   VCOMISDZrr_Int                               $xmm16, $xmm1, implicit-def $eflags                        
4703   ; CHECK: VCOMISSZrm_Int                      $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4704   VCOMISSZrm_Int                               $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4705   ; CHECK: VCOMISSZrr_Int                      $xmm16, $xmm1, implicit-def $eflags 
4706   VCOMISSZrr_Int                               $xmm16, $xmm1, implicit-def $eflags                        
4707   ; CHECK: VUCOMISDZrm_Int                     $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4708   VUCOMISDZrm_Int                              $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4709   ; CHECK: VUCOMISDZrr_Int                     $xmm16, $xmm1, implicit-def $eflags
4710   VUCOMISDZrr_Int                              $xmm16, $xmm1, implicit-def $eflags                        
4711   ; CHECK: VUCOMISSZrm_Int                     $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4712   VUCOMISSZrm_Int                              $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4713   ; CHECK: VUCOMISSZrr_Int                     $xmm16, $xmm1, implicit-def $eflags 
4714   VUCOMISSZrr_Int                              $xmm16, $xmm1, implicit-def $eflags                        
4715   ; CHECK: VCOMISDZrm                          $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4716   VCOMISDZrm                                   $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4717   ; CHECK: VCOMISDZrr                          $xmm16, $xmm1, implicit-def $eflags 
4718   VCOMISDZrr                                   $xmm16, $xmm1, implicit-def $eflags                        
4719   ; CHECK: VCOMISSZrm                          $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4720   VCOMISSZrm                                   $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4721   ; CHECK: VCOMISSZrr                          $xmm16, $xmm1, implicit-def $eflags 
4722   VCOMISSZrr                                   $xmm16, $xmm1, implicit-def $eflags                        
4723   ; CHECK: VUCOMISDZrm                         $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4724   VUCOMISDZrm                                  $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4725   ; CHECK: VUCOMISDZrr                         $xmm16, $xmm1, implicit-def $eflags 
4726   VUCOMISDZrr                                  $xmm16, $xmm1, implicit-def $eflags                        
4727   ; CHECK: VUCOMISSZrm                         $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4728   VUCOMISSZrm                                  $xmm16, $rdi, 1, $noreg, 0, $noreg, implicit-def $eflags
4729   ; CHECK: VUCOMISSZrr                         $xmm16, $xmm1, implicit-def $eflags 
4730   VUCOMISSZrr                                  $xmm16, $xmm1, implicit-def $eflags 
4731   ; CHECK: $xmm16 = VRNDSCALESDZm              $xmm16, $rip, 1, $rax, 0, $noreg, 15
4732   $xmm16 = VRNDSCALESDZm                       $xmm16, $rip, 1, $rax, 0, $noreg, 15
4733   ; CHECK: $xmm16 = VRNDSCALESDZr              $xmm16, $xmm1, 15
4734   $xmm16 = VRNDSCALESDZr                       $xmm16, $xmm1, 15
4735   ; CHECK: $xmm16 = VRNDSCALESSZm              $xmm16, $rip, 1, $rax, 0, $noreg, 15
4736   $xmm16 = VRNDSCALESSZm                       $xmm16, $rip, 1, $rax, 0, $noreg, 15
4737   ; CHECK: $xmm16 = VRNDSCALESSZr              $xmm16, $xmm1, 15
4738   $xmm16 = VRNDSCALESSZr                       $xmm16, $xmm1, 15
4739   ; CHECK: $xmm16 = VRNDSCALESDZm_Int          $xmm16, $rip, 1, $rax, 0, $noreg, 15
4740   $xmm16 = VRNDSCALESDZm_Int                   $xmm16, $rip, 1, $rax, 0, $noreg, 15
4741   ; CHECK: $xmm16 = VRNDSCALESDZr_Int          $xmm16, $xmm1, 15
4742   $xmm16 = VRNDSCALESDZr_Int                   $xmm16, $xmm1, 15
4743   ; CHECK: $xmm16 = VRNDSCALESSZm_Int          $xmm16, $rip, 1, $rax, 0, $noreg, 15
4744   $xmm16 = VRNDSCALESSZm_Int                   $xmm16, $rip, 1, $rax, 0, $noreg, 15
4745   ; CHECK: $xmm16 = VRNDSCALESSZr_Int          $xmm16, $xmm1, 15
4746   $xmm16 = VRNDSCALESSZr_Int                   $xmm16, $xmm1, 15
4747   ; CHECK: $xmm0 = VRNDSCALESDZm               $xmm0, $rip, 1, $rax, 0, $noreg, 31
4748   $xmm0 = VRNDSCALESDZm                        $xmm0, $rip, 1, $rax, 0, $noreg, 31
4749   ; CHECK: $xmm0 = VRNDSCALESDZr               $xmm0, $xmm1, 31
4750   $xmm0 = VRNDSCALESDZr                        $xmm0, $xmm1, 31
4751   ; CHECK: $xmm0 = VRNDSCALESSZm               $xmm0, $rip, 1, $rax, 0, $noreg, 31
4752   $xmm0 = VRNDSCALESSZm                        $xmm0, $rip, 1, $rax, 0, $noreg, 31
4753   ; CHECK: $xmm0 = VRNDSCALESSZr               $xmm0, $xmm1, 31
4754   $xmm0 = VRNDSCALESSZr                        $xmm0, $xmm1, 31
4755   ; CHECK: $xmm0 = VRNDSCALESDZm_Int           $xmm0, $rip, 1, $rax, 0, $noreg, 31
4756   $xmm0 = VRNDSCALESDZm_Int                    $xmm0, $rip, 1, $rax, 0, $noreg, 31
4757   ; CHECK: $xmm0 = VRNDSCALESDZr_Int           $xmm0, $xmm1, 31
4758   $xmm0 = VRNDSCALESDZr_Int                    $xmm0, $xmm1, 31
4759   ; CHECK: $xmm0 = VRNDSCALESSZm_Int           $xmm0, $rip, 1, $rax, 0, $noreg, 31
4760   $xmm0 = VRNDSCALESSZm_Int                    $xmm0, $rip, 1, $rax, 0, $noreg, 31
4761   ; CHECK: $xmm0 = VRNDSCALESSZr_Int           $xmm0, $xmm1, 31
4762   $xmm0 = VRNDSCALESSZr_Int                    $xmm0, $xmm1, 31
4763   
4764       RET 0, $zmm0, $zmm1