Home | History | Annotate | Download | only in AArch64
      1 ; RUN: llc -mtriple arm64_be < %s -aarch64-load-store-opt=false -o - | FileCheck %s
      2 ; RUN: llc -mtriple arm64_be < %s -fast-isel=true -aarch64-load-store-opt=false -o - | FileCheck %s
      3 
      4 ; CHECK-LABEL: test_i64_f64:
      5 define i64 @test_i64_f64(double %p) {
      6 ; CHECK-NOT: rev
      7     %1 = fadd double %p, %p
      8     %2 = bitcast double %1 to i64
      9     %3 = add i64 %2, %2
     10     ret i64 %3
     11 }
     12 
     13 ; CHECK-LABEL: test_i64_v1i64:
     14 define i64 @test_i64_v1i64(<1 x i64> %p) {
     15 ; CHECK-NOT: rev
     16     %1 = add <1 x i64> %p, %p
     17     %2 = bitcast <1 x i64> %1 to i64
     18     %3 = add i64 %2, %2
     19     ret i64 %3
     20 }
     21 
     22 ; CHECK-LABEL: test_i64_v2f32:
     23 define i64 @test_i64_v2f32(<2 x float> %p) {
     24 ; CHECK: rev64 v{{[0-9]+}}.2s
     25     %1 = fadd <2 x float> %p, %p
     26     %2 = bitcast <2 x float> %1 to i64
     27     %3 = add i64 %2, %2
     28     ret i64 %3
     29 }
     30 
     31 ; CHECK-LABEL: test_i64_v2i32:
     32 define i64 @test_i64_v2i32(<2 x i32> %p) {
     33 ; CHECK: rev64 v{{[0-9]+}}.2s
     34     %1 = add <2 x i32> %p, %p
     35     %2 = bitcast <2 x i32> %1 to i64
     36     %3 = add i64 %2, %2
     37     ret i64 %3
     38 }
     39 
     40 ; CHECK-LABEL: test_i64_v4i16:
     41 define i64 @test_i64_v4i16(<4 x i16> %p) {
     42 ; CHECK: rev64 v{{[0-9]+}}.4h
     43     %1 = add <4 x i16> %p, %p
     44     %2 = bitcast <4 x i16> %1 to i64
     45     %3 = add i64 %2, %2
     46     ret i64 %3
     47 }
     48 
     49 ; CHECK-LABEL: test_i64_v8i8:
     50 define i64 @test_i64_v8i8(<8 x i8> %p) {
     51 ; CHECK: rev64 v{{[0-9]+}}.8b
     52     %1 = add <8 x i8> %p, %p
     53     %2 = bitcast <8 x i8> %1 to i64
     54     %3 = add i64 %2, %2
     55     ret i64 %3
     56 }
     57 
     58 ; CHECK-LABEL: test_f64_i64:
     59 define double @test_f64_i64(i64 %p) {
     60 ; CHECK-NOT: rev
     61     %1 = add i64 %p, %p
     62     %2 = bitcast i64 %1 to double
     63     %3 = fadd double %2, %2
     64     ret double %3
     65 }
     66 
     67 ; CHECK-LABEL: test_f64_v1i64:
     68 define double @test_f64_v1i64(<1 x i64> %p) {
     69 ; CHECK-NOT: rev
     70     %1 = add <1 x i64> %p, %p
     71     %2 = bitcast <1 x i64> %1 to double
     72     %3 = fadd double %2, %2
     73     ret double %3
     74 }
     75 
     76 ; CHECK-LABEL: test_f64_v2f32:
     77 define double @test_f64_v2f32(<2 x float> %p) {
     78 ; CHECK: rev64 v{{[0-9]+}}.2s
     79     %1 = fadd <2 x float> %p, %p
     80     %2 = bitcast <2 x float> %1 to double
     81     %3 = fadd double %2, %2
     82     ret double %3
     83 }
     84 
     85 ; CHECK-LABEL: test_f64_v2i32:
     86 define double @test_f64_v2i32(<2 x i32> %p) {
     87 ; CHECK: rev64 v{{[0-9]+}}.2s
     88     %1 = add <2 x i32> %p, %p
     89     %2 = bitcast <2 x i32> %1 to double
     90     %3 = fadd double %2, %2
     91     ret double %3
     92 }
     93 
     94 ; CHECK-LABEL: test_f64_v4i16:
     95 define double @test_f64_v4i16(<4 x i16> %p) {
     96 ; CHECK: rev64 v{{[0-9]+}}.4h
     97     %1 = add <4 x i16> %p, %p
     98     %2 = bitcast <4 x i16> %1 to double
     99     %3 = fadd double %2, %2
    100     ret double %3
    101 }
    102 
    103 ; CHECK-LABEL: test_f64_v8i8:
    104 define double @test_f64_v8i8(<8 x i8> %p) {
    105 ; CHECK: rev64 v{{[0-9]+}}.8b
    106     %1 = add <8 x i8> %p, %p
    107     %2 = bitcast <8 x i8> %1 to double
    108     %3 = fadd double %2, %2
    109     ret double %3
    110 }
    111 
    112 ; CHECK-LABEL: test_v1i64_i64:
    113 define <1 x i64> @test_v1i64_i64(i64 %p) {
    114 ; CHECK-NOT: rev
    115     %1 = add i64 %p, %p
    116     %2 = bitcast i64 %1 to <1 x i64>
    117     %3 = add <1 x i64> %2, %2
    118     ret <1 x i64> %3
    119 }
    120 
    121 ; CHECK-LABEL: test_v1i64_f64:
    122 define <1 x i64> @test_v1i64_f64(double %p) {
    123 ; CHECK-NOT: rev
    124     %1 = fadd double %p, %p
    125     %2 = bitcast double %1 to <1 x i64>
    126     %3 = add <1 x i64> %2, %2
    127     ret <1 x i64> %3
    128 }
    129 
    130 ; CHECK-LABEL: test_v1i64_v2f32:
    131 define <1 x i64> @test_v1i64_v2f32(<2 x float> %p) {
    132 ; CHECK: rev64 v{{[0-9]+}}.2s
    133     %1 = fadd <2 x float> %p, %p
    134     %2 = bitcast <2 x float> %1 to <1 x i64>
    135     %3 = add <1 x i64> %2, %2
    136     ret <1 x i64> %3
    137 }
    138 
    139 ; CHECK-LABEL: test_v1i64_v2i32:
    140 define <1 x i64> @test_v1i64_v2i32(<2 x i32> %p) {
    141 ; CHECK: rev64 v{{[0-9]+}}.2s
    142     %1 = add <2 x i32> %p, %p
    143     %2 = bitcast <2 x i32> %1 to <1 x i64>
    144     %3 = add <1 x i64> %2, %2
    145     ret <1 x i64> %3
    146 }
    147 
    148 ; CHECK-LABEL: test_v1i64_v4i16:
    149 define <1 x i64> @test_v1i64_v4i16(<4 x i16> %p) {
    150 ; CHECK: rev64 v{{[0-9]+}}.4h
    151     %1 = add <4 x i16> %p, %p
    152     %2 = bitcast <4 x i16> %1 to <1 x i64>
    153     %3 = add <1 x i64> %2, %2
    154     ret <1 x i64> %3
    155 }
    156 
    157 ; CHECK-LABEL: test_v1i64_v8i8:
    158 define <1 x i64> @test_v1i64_v8i8(<8 x i8> %p) {
    159 ; CHECK: rev64 v{{[0-9]+}}.8b
    160     %1 = add <8 x i8> %p, %p
    161     %2 = bitcast <8 x i8> %1 to <1 x i64>
    162     %3 = add <1 x i64> %2, %2
    163     ret <1 x i64> %3
    164 }
    165 
    166 ; CHECK-LABEL: test_v2f32_i64:
    167 define <2 x float> @test_v2f32_i64(i64 %p) {
    168 ; CHECK: rev64 v{{[0-9]+}}.2s
    169     %1 = add i64 %p, %p
    170     %2 = bitcast i64 %1 to <2 x float>
    171     %3 = fadd <2 x float> %2, %2
    172     ret <2 x float> %3
    173 }
    174 
    175 ; CHECK-LABEL: test_v2f32_f64:
    176 define <2 x float> @test_v2f32_f64(double %p) {
    177 ; CHECK: rev64 v{{[0-9]+}}.2s
    178     %1 = fadd double %p, %p
    179     %2 = bitcast double %1 to <2 x float>
    180     %3 = fadd <2 x float> %2, %2
    181     ret <2 x float> %3
    182 }
    183 
    184 ; CHECK-LABEL: test_v2f32_v1i64:
    185 define <2 x float> @test_v2f32_v1i64(<1 x i64> %p) {
    186 ; CHECK: rev64 v{{[0-9]+}}.2s
    187     %1 = add <1 x i64> %p, %p
    188     %2 = bitcast <1 x i64> %1 to <2 x float>
    189     %3 = fadd <2 x float> %2, %2
    190     ret <2 x float> %3
    191 }
    192 
    193 ; CHECK-LABEL: test_v2f32_v2i32:
    194 define <2 x float> @test_v2f32_v2i32(<2 x i32> %p) {
    195 ; CHECK: rev64 v{{[0-9]+}}.2s
    196 ; CHECK: rev64 v{{[0-9]+}}.2s
    197     %1 = add <2 x i32> %p, %p
    198     %2 = bitcast <2 x i32> %1 to <2 x float>
    199     %3 = fadd <2 x float> %2, %2
    200     ret <2 x float> %3
    201 }
    202 
    203 ; CHECK-LABEL: test_v2f32_v4i16:
    204 define <2 x float> @test_v2f32_v4i16(<4 x i16> %p) {
    205 ; CHECK: rev64 v{{[0-9]+}}.4h
    206 ; CHECK: rev64 v{{[0-9]+}}.2s
    207     %1 = add <4 x i16> %p, %p
    208     %2 = bitcast <4 x i16> %1 to <2 x float>
    209     %3 = fadd <2 x float> %2, %2
    210     ret <2 x float> %3
    211 }
    212 
    213 ; CHECK-LABEL: test_v2f32_v8i8:
    214 define <2 x float> @test_v2f32_v8i8(<8 x i8> %p) {
    215 ; CHECK: rev64 v{{[0-9]+}}.8b
    216 ; CHECK: rev64 v{{[0-9]+}}.2s
    217     %1 = add <8 x i8> %p, %p
    218     %2 = bitcast <8 x i8> %1 to <2 x float>
    219     %3 = fadd <2 x float> %2, %2
    220     ret <2 x float> %3
    221 }
    222 
    223 ; CHECK-LABEL: test_v2i32_i64:
    224 define <2 x i32> @test_v2i32_i64(i64 %p) {
    225 ; CHECK: rev64 v{{[0-9]+}}.2s
    226     %1 = add i64 %p, %p
    227     %2 = bitcast i64 %1 to <2 x i32>
    228     %3 = add <2 x i32> %2, %2
    229     ret <2 x i32> %3
    230 }
    231 
    232 ; CHECK-LABEL: test_v2i32_f64:
    233 define <2 x i32> @test_v2i32_f64(double %p) {
    234 ; CHECK: rev64 v{{[0-9]+}}.2s
    235     %1 = fadd double %p, %p
    236     %2 = bitcast double %1 to <2 x i32>
    237     %3 = add <2 x i32> %2, %2
    238     ret <2 x i32> %3
    239 }
    240 
    241 ; CHECK-LABEL: test_v2i32_v1i64:
    242 define <2 x i32> @test_v2i32_v1i64(<1 x i64> %p) {
    243 ; CHECK: rev64 v{{[0-9]+}}.2s
    244     %1 = add <1 x i64> %p, %p
    245     %2 = bitcast <1 x i64> %1 to <2 x i32>
    246     %3 = add <2 x i32> %2, %2
    247     ret <2 x i32> %3
    248 }
    249 
    250 ; CHECK-LABEL: test_v2i32_v2f32:
    251 define <2 x i32> @test_v2i32_v2f32(<2 x float> %p) {
    252 ; CHECK: rev64 v{{[0-9]+}}.2s
    253 ; CHECK: rev64 v{{[0-9]+}}.2s
    254     %1 = fadd <2 x float> %p, %p
    255     %2 = bitcast <2 x float> %1 to <2 x i32>
    256     %3 = add <2 x i32> %2, %2
    257     ret <2 x i32> %3
    258 }
    259 
    260 ; CHECK-LABEL: test_v2i32_v4i16:
    261 define <2 x i32> @test_v2i32_v4i16(<4 x i16> %p) {
    262 ; CHECK: rev64 v{{[0-9]+}}.4h
    263 ; CHECK: rev64 v{{[0-9]+}}.2s
    264     %1 = add <4 x i16> %p, %p
    265     %2 = bitcast <4 x i16> %1 to <2 x i32>
    266     %3 = add <2 x i32> %2, %2
    267     ret <2 x i32> %3
    268 }
    269 
    270 ; CHECK-LABEL: test_v2i32_v8i8:
    271 define <2 x i32> @test_v2i32_v8i8(<8 x i8> %p) {
    272 ; CHECK: rev64 v{{[0-9]+}}.8b
    273 ; CHECK: rev64 v{{[0-9]+}}.2s
    274     %1 = add <8 x i8> %p, %p
    275     %2 = bitcast <8 x i8> %1 to <2 x i32>
    276     %3 = add <2 x i32> %2, %2
    277     ret <2 x i32> %3
    278 }
    279 
    280 ; CHECK-LABEL: test_v4i16_i64:
    281 define <4 x i16> @test_v4i16_i64(i64 %p) {
    282 ; CHECK: rev64 v{{[0-9]+}}.4h
    283     %1 = add i64 %p, %p
    284     %2 = bitcast i64 %1 to <4 x i16>
    285     %3 = add <4 x i16> %2, %2
    286     ret <4 x i16> %3
    287 }
    288 
    289 ; CHECK-LABEL: test_v4i16_f64:
    290 define <4 x i16> @test_v4i16_f64(double %p) {
    291 ; CHECK: rev64 v{{[0-9]+}}.4h
    292     %1 = fadd double %p, %p
    293     %2 = bitcast double %1 to <4 x i16>
    294     %3 = add <4 x i16> %2, %2
    295     ret <4 x i16> %3
    296 }
    297 
    298 ; CHECK-LABEL: test_v4i16_v1i64:
    299 define <4 x i16> @test_v4i16_v1i64(<1 x i64> %p) {
    300 ; CHECK: rev64 v{{[0-9]+}}.4h
    301     %1 = add <1 x i64> %p, %p
    302     %2 = bitcast <1 x i64> %1 to <4 x i16>
    303     %3 = add <4 x i16> %2, %2
    304     ret <4 x i16> %3
    305 }
    306 
    307 ; CHECK-LABEL: test_v4i16_v2f32:
    308 define <4 x i16> @test_v4i16_v2f32(<2 x float> %p) {
    309 ; CHECK: rev64 v{{[0-9]+}}.2s
    310 ; CHECK: rev64 v{{[0-9]+}}.4h
    311     %1 = fadd <2 x float> %p, %p
    312     %2 = bitcast <2 x float> %1 to <4 x i16>
    313     %3 = add <4 x i16> %2, %2
    314     ret <4 x i16> %3
    315 }
    316 
    317 ; CHECK-LABEL: test_v4i16_v2i32:
    318 define <4 x i16> @test_v4i16_v2i32(<2 x i32> %p) {
    319 ; CHECK: rev64 v{{[0-9]+}}.2s
    320 ; CHECK: rev64 v{{[0-9]+}}.4h
    321     %1 = add <2 x i32> %p, %p
    322     %2 = bitcast <2 x i32> %1 to <4 x i16>
    323     %3 = add <4 x i16> %2, %2
    324     ret <4 x i16> %3
    325 }
    326 
    327 ; CHECK-LABEL: test_v4i16_v8i8:
    328 define <4 x i16> @test_v4i16_v8i8(<8 x i8> %p) {
    329 ; CHECK: rev64 v{{[0-9]+}}.8b
    330 ; CHECK: rev64 v{{[0-9]+}}.4h
    331     %1 = add <8 x i8> %p, %p
    332     %2 = bitcast <8 x i8> %1 to <4 x i16>
    333     %3 = add <4 x i16> %2, %2
    334     ret <4 x i16> %3
    335 }
    336 
    337 ; CHECK-LABEL: test_v8i8_i64:
    338 define <8 x i8> @test_v8i8_i64(i64 %p) {
    339 ; CHECK: rev64 v{{[0-9]+}}.8b
    340     %1 = add i64 %p, %p
    341     %2 = bitcast i64 %1 to <8 x i8>
    342     %3 = add <8 x i8> %2, %2
    343     ret <8 x i8> %3
    344 }
    345 
    346 ; CHECK-LABEL: test_v8i8_f64:
    347 define <8 x i8> @test_v8i8_f64(double %p) {
    348 ; CHECK: rev64 v{{[0-9]+}}.8b
    349     %1 = fadd double %p, %p
    350     %2 = bitcast double %1 to <8 x i8>
    351     %3 = add <8 x i8> %2, %2
    352     ret <8 x i8> %3
    353 }
    354 
    355 ; CHECK-LABEL: test_v8i8_v1i64:
    356 define <8 x i8> @test_v8i8_v1i64(<1 x i64> %p) {
    357 ; CHECK: rev64 v{{[0-9]+}}.8b
    358     %1 = add <1 x i64> %p, %p
    359     %2 = bitcast <1 x i64> %1 to <8 x i8>
    360     %3 = add <8 x i8> %2, %2
    361     ret <8 x i8> %3
    362 }
    363 
    364 ; CHECK-LABEL: test_v8i8_v2f32:
    365 define <8 x i8> @test_v8i8_v2f32(<2 x float> %p) {
    366 ; CHECK: rev64 v{{[0-9]+}}.2s
    367 ; CHECK: rev64 v{{[0-9]+}}.8b
    368     %1 = fadd <2 x float> %p, %p
    369     %2 = bitcast <2 x float> %1 to <8 x i8>
    370     %3 = add <8 x i8> %2, %2
    371     ret <8 x i8> %3
    372 }
    373 
    374 ; CHECK-LABEL: test_v8i8_v2i32:
    375 define <8 x i8> @test_v8i8_v2i32(<2 x i32> %p) {
    376 ; CHECK: rev64 v{{[0-9]+}}.2s
    377 ; CHECK: rev64 v{{[0-9]+}}.8b
    378     %1 = add <2 x i32> %p, %p
    379     %2 = bitcast <2 x i32> %1 to <8 x i8>
    380     %3 = add <8 x i8> %2, %2
    381     ret <8 x i8> %3
    382 }
    383 
    384 ; CHECK-LABEL: test_v8i8_v4i16:
    385 define <8 x i8> @test_v8i8_v4i16(<4 x i16> %p) {
    386 ; CHECK: rev64 v{{[0-9]+}}.4h
    387 ; CHECK: rev64 v{{[0-9]+}}.8b
    388     %1 = add <4 x i16> %p, %p
    389     %2 = bitcast <4 x i16> %1 to <8 x i8>
    390     %3 = add <8 x i8> %2, %2
    391     ret <8 x i8> %3
    392 }
    393 
    394 ; CHECK-LABEL: test_f128_v2f64:
    395 define fp128 @test_f128_v2f64(<2 x double> %p) {
    396 ; CHECK: ext
    397     %1 = fadd <2 x double> %p, %p
    398     %2 = bitcast <2 x double> %1 to fp128
    399     %3 = fadd fp128 %2, %2
    400     ret fp128 %3
    401 }
    402 
    403 ; CHECK-LABEL: test_f128_v2i64:
    404 define fp128 @test_f128_v2i64(<2 x i64> %p) {
    405 ; CHECK: ext
    406     %1 = add <2 x i64> %p, %p
    407     %2 = bitcast <2 x i64> %1 to fp128
    408     %3 = fadd fp128 %2, %2
    409     ret fp128 %3
    410 }
    411 
    412 ; CHECK-LABEL: test_f128_v4f32:
    413 define fp128 @test_f128_v4f32(<4 x float> %p) {
    414 ; CHECK: rev64 v{{[0-9]+}}.4s
    415 ; CHECK: ext
    416     %1 = fadd <4 x float> %p, %p
    417     %2 = bitcast <4 x float> %1 to fp128
    418     %3 = fadd fp128 %2, %2
    419     ret fp128 %3
    420 }
    421 
    422 ; CHECK-LABEL: test_f128_v4i32:
    423 define fp128 @test_f128_v4i32(<4 x i32> %p) {
    424 ; CHECK: rev64 v{{[0-9]+}}.4s
    425 ; CHECK: ext
    426     %1 = add <4 x i32> %p, %p
    427     %2 = bitcast <4 x i32> %1 to fp128
    428     %3 = fadd fp128 %2, %2
    429     ret fp128 %3
    430 }
    431 
    432 ; CHECK-LABEL: test_f128_v8i16:
    433 define fp128 @test_f128_v8i16(<8 x i16> %p) {
    434 ; CHECK: rev64 v{{[0-9]+}}.8h
    435 ; CHECK: ext
    436     %1 = add <8 x i16> %p, %p
    437     %2 = bitcast <8 x i16> %1 to fp128
    438     %3 = fadd fp128 %2, %2
    439     ret fp128 %3
    440 }
    441 
    442 ; CHECK-LABEL: test_f128_v16i8:
    443 define fp128 @test_f128_v16i8(<16 x i8> %p) {
    444 ; CHECK: rev64 v{{[0-9]+}}.16b
    445 ; CHECK: ext
    446     %1 = add <16 x i8> %p, %p
    447     %2 = bitcast <16 x i8> %1 to fp128
    448     %3 = fadd fp128 %2, %2
    449     ret fp128 %3
    450 }
    451 
    452 ; CHECK-LABEL: test_v2f64_f128:
    453 define <2 x double> @test_v2f64_f128(fp128 %p) {
    454 ; CHECK: ext
    455     %1 = fadd fp128 %p, %p
    456     %2 = bitcast fp128 %1 to <2 x double>
    457     %3 = fadd <2 x double> %2, %2
    458     ret <2 x double> %3
    459 }
    460 
    461 ; CHECK-LABEL: test_v2f64_v2i64:
    462 define <2 x double> @test_v2f64_v2i64(<2 x i64> %p) {
    463 ; CHECK: ext
    464 ; CHECK: ext
    465     %1 = add <2 x i64> %p, %p
    466     %2 = bitcast <2 x i64> %1 to <2 x double>
    467     %3 = fadd <2 x double> %2, %2
    468     ret <2 x double> %3
    469 }
    470 
    471 ; CHECK-LABEL: test_v2f64_v4f32:
    472 define <2 x double> @test_v2f64_v4f32(<4 x float> %p) {
    473 ; CHECK: rev64 v{{[0-9]+}}.4s
    474 ; CHECK: ext
    475 ; CHECK: ext
    476     %1 = fadd <4 x float> %p, %p
    477     %2 = bitcast <4 x float> %1 to <2 x double>
    478     %3 = fadd <2 x double> %2, %2
    479     ret <2 x double> %3
    480 }
    481 
    482 ; CHECK-LABEL: test_v2f64_v4i32:
    483 define <2 x double> @test_v2f64_v4i32(<4 x i32> %p) {
    484 ; CHECK: rev64 v{{[0-9]+}}.4s
    485 ; CHECK: ext
    486 ; CHECK: ext
    487     %1 = add <4 x i32> %p, %p
    488     %2 = bitcast <4 x i32> %1 to <2 x double>
    489     %3 = fadd <2 x double> %2, %2
    490     ret <2 x double> %3
    491 }
    492 
    493 ; CHECK-LABEL: test_v2f64_v8i16:
    494 define <2 x double> @test_v2f64_v8i16(<8 x i16> %p) {
    495 ; CHECK: rev64 v{{[0-9]+}}.8h
    496 ; CHECK: ext
    497 ; CHECK: ext
    498     %1 = add <8 x i16> %p, %p
    499     %2 = bitcast <8 x i16> %1 to <2 x double>
    500     %3 = fadd <2 x double> %2, %2
    501     ret <2 x double> %3
    502 }
    503 
    504 ; CHECK-LABEL: test_v2f64_v16i8:
    505 define <2 x double> @test_v2f64_v16i8(<16 x i8> %p) {
    506 ; CHECK: rev64 v{{[0-9]+}}.16b
    507 ; CHECK: ext
    508 ; CHECK: ext
    509     %1 = add <16 x i8> %p, %p
    510     %2 = bitcast <16 x i8> %1 to <2 x double>
    511     %3 = fadd <2 x double> %2, %2
    512     ret <2 x double> %3
    513 }
    514 
    515 ; CHECK-LABEL: test_v2i64_f128:
    516 define <2 x i64> @test_v2i64_f128(fp128 %p) {
    517 ; CHECK: ext
    518     %1 = fadd fp128 %p, %p
    519     %2 = bitcast fp128 %1 to <2 x i64>
    520     %3 = add <2 x i64> %2, %2
    521     ret <2 x i64> %3
    522 }
    523 
    524 ; CHECK-LABEL: test_v2i64_v2f64:
    525 define <2 x i64> @test_v2i64_v2f64(<2 x double> %p) {
    526 ; CHECK: ext
    527 ; CHECK: ext
    528     %1 = fadd <2 x double> %p, %p
    529     %2 = bitcast <2 x double> %1 to <2 x i64>
    530     %3 = add <2 x i64> %2, %2
    531     ret <2 x i64> %3
    532 }
    533 
    534 ; CHECK-LABEL: test_v2i64_v4f32:
    535 define <2 x i64> @test_v2i64_v4f32(<4 x float> %p) {
    536 ; CHECK: rev64 v{{[0-9]+}}.4s
    537 ; CHECK: ext
    538 ; CHECK: ext
    539     %1 = fadd <4 x float> %p, %p
    540     %2 = bitcast <4 x float> %1 to <2 x i64>
    541     %3 = add <2 x i64> %2, %2
    542     ret <2 x i64> %3
    543 }
    544 
    545 ; CHECK-LABEL: test_v2i64_v4i32:
    546 define <2 x i64> @test_v2i64_v4i32(<4 x i32> %p) {
    547 ; CHECK: rev64 v{{[0-9]+}}.4s
    548 ; CHECK: ext
    549 ; CHECK: ext
    550     %1 = add <4 x i32> %p, %p
    551     %2 = bitcast <4 x i32> %1 to <2 x i64>
    552     %3 = add <2 x i64> %2, %2
    553     ret <2 x i64> %3
    554 }
    555 
    556 ; CHECK-LABEL: test_v2i64_v8i16:
    557 define <2 x i64> @test_v2i64_v8i16(<8 x i16> %p) {
    558 ; CHECK: rev64 v{{[0-9]+}}.8h
    559 ; CHECK: ext
    560 ; CHECK: ext
    561     %1 = add <8 x i16> %p, %p
    562     %2 = bitcast <8 x i16> %1 to <2 x i64>
    563     %3 = add <2 x i64> %2, %2
    564     ret <2 x i64> %3
    565 }
    566 
    567 ; CHECK-LABEL: test_v2i64_v16i8:
    568 define <2 x i64> @test_v2i64_v16i8(<16 x i8> %p) {
    569 ; CHECK: rev64 v{{[0-9]+}}.16b
    570 ; CHECK: ext
    571 ; CHECK: ext
    572     %1 = add <16 x i8> %p, %p
    573     %2 = bitcast <16 x i8> %1 to <2 x i64>
    574     %3 = add <2 x i64> %2, %2
    575     ret <2 x i64> %3
    576 }
    577 
    578 ; CHECK-LABEL: test_v4f32_f128:
    579 define <4 x float> @test_v4f32_f128(fp128 %p) {
    580 ; CHECK: rev64 v{{[0-9]+}}.4s
    581 ; CHECK: ext
    582     %1 = fadd fp128 %p, %p
    583     %2 = bitcast fp128 %1 to <4 x float>
    584     %3 = fadd <4 x float> %2, %2
    585     ret <4 x float> %3
    586 }
    587 
    588 ; CHECK-LABEL: test_v4f32_v2f64:
    589 define <4 x float> @test_v4f32_v2f64(<2 x double> %p) {
    590 ; CHECK: ext
    591 ; CHECK: rev64 v{{[0-9]+}}.4s
    592 ; CHECK: ext
    593     %1 = fadd <2 x double> %p, %p
    594     %2 = bitcast <2 x double> %1 to <4 x float>
    595     %3 = fadd <4 x float> %2, %2
    596     ret <4 x float> %3
    597 }
    598 
    599 ; CHECK-LABEL: test_v4f32_v2i64:
    600 define <4 x float> @test_v4f32_v2i64(<2 x i64> %p) {
    601 ; CHECK: ext
    602 ; CHECK: rev64 v{{[0-9]+}}.4s
    603 ; CHECK: ext
    604     %1 = add <2 x i64> %p, %p
    605     %2 = bitcast <2 x i64> %1 to <4 x float>
    606     %3 = fadd <4 x float> %2, %2
    607     ret <4 x float> %3
    608 }
    609 
    610 ; CHECK-LABEL: test_v4f32_v4i32:
    611 define <4 x float> @test_v4f32_v4i32(<4 x i32> %p) {
    612 ; CHECK: rev64 v{{[0-9]+}}.4s
    613 ; CHECK: ext
    614 ; CHECK: rev64 v{{[0-9]+}}.4s
    615 ; CHECK: ext
    616     %1 = add <4 x i32> %p, %p
    617     %2 = bitcast <4 x i32> %1 to <4 x float>
    618     %3 = fadd <4 x float> %2, %2
    619     ret <4 x float> %3
    620 }
    621 
    622 ; CHECK-LABEL: test_v4f32_v8i16:
    623 define <4 x float> @test_v4f32_v8i16(<8 x i16> %p) {
    624 ; CHECK: rev64 v{{[0-9]+}}.8h
    625 ; CHECK: ext
    626 ; CHECK: rev64 v{{[0-9]+}}.4s
    627 ; CHECK: ext
    628     %1 = add <8 x i16> %p, %p
    629     %2 = bitcast <8 x i16> %1 to <4 x float>
    630     %3 = fadd <4 x float> %2, %2
    631     ret <4 x float> %3
    632 }
    633 
    634 ; CHECK-LABEL: test_v4f32_v16i8:
    635 define <4 x float> @test_v4f32_v16i8(<16 x i8> %p) {
    636 ; CHECK: rev64 v{{[0-9]+}}.16b
    637 ; CHECK: ext
    638 ; CHECK: rev64 v{{[0-9]+}}.4s
    639 ; CHECK: ext
    640     %1 = add <16 x i8> %p, %p
    641     %2 = bitcast <16 x i8> %1 to <4 x float>
    642     %3 = fadd <4 x float> %2, %2
    643     ret <4 x float> %3
    644 }
    645 
    646 ; CHECK-LABEL: test_v4i32_f128:
    647 define <4 x i32> @test_v4i32_f128(fp128 %p) {
    648 ; CHECK: rev64 v{{[0-9]+}}.4s
    649 ; CHECK: ext
    650     %1 = fadd fp128 %p, %p
    651     %2 = bitcast fp128 %1 to <4 x i32>
    652     %3 = add <4 x i32> %2, %2
    653     ret <4 x i32> %3
    654 }
    655 
    656 ; CHECK-LABEL: test_v4i32_v2f64:
    657 define <4 x i32> @test_v4i32_v2f64(<2 x double> %p) {
    658 ; CHECK: ext
    659 ; CHECK: rev64 v{{[0-9]+}}.4s
    660 ; CHECK: ext
    661     %1 = fadd <2 x double> %p, %p
    662     %2 = bitcast <2 x double> %1 to <4 x i32>
    663     %3 = add <4 x i32> %2, %2
    664     ret <4 x i32> %3
    665 }
    666 
    667 ; CHECK-LABEL: test_v4i32_v2i64:
    668 define <4 x i32> @test_v4i32_v2i64(<2 x i64> %p) {
    669 ; CHECK: ext
    670 ; CHECK: rev64 v{{[0-9]+}}.4s
    671 ; CHECK: ext
    672     %1 = add <2 x i64> %p, %p
    673     %2 = bitcast <2 x i64> %1 to <4 x i32>
    674     %3 = add <4 x i32> %2, %2
    675     ret <4 x i32> %3
    676 }
    677 
    678 ; CHECK-LABEL: test_v4i32_v4f32:
    679 define <4 x i32> @test_v4i32_v4f32(<4 x float> %p) {
    680 ; CHECK: rev64 v{{[0-9]+}}.4s
    681 ; CHECK: ext
    682 ; CHECK: rev64 v{{[0-9]+}}.4s
    683 ; CHECK: ext
    684     %1 = fadd <4 x float> %p, %p
    685     %2 = bitcast <4 x float> %1 to <4 x i32>
    686     %3 = add <4 x i32> %2, %2
    687     ret <4 x i32> %3
    688 }
    689 
    690 ; CHECK-LABEL: test_v4i32_v8i16:
    691 define <4 x i32> @test_v4i32_v8i16(<8 x i16> %p) {
    692 ; CHECK: rev64 v{{[0-9]+}}.8h
    693 ; CHECK: ext
    694 ; CHECK: rev64 v{{[0-9]+}}.4s
    695 ; CHECK: ext
    696     %1 = add <8 x i16> %p, %p
    697     %2 = bitcast <8 x i16> %1 to <4 x i32>
    698     %3 = add <4 x i32> %2, %2
    699     ret <4 x i32> %3
    700 }
    701 
    702 ; CHECK-LABEL: test_v4i32_v16i8:
    703 define <4 x i32> @test_v4i32_v16i8(<16 x i8> %p) {
    704 ; CHECK: rev64 v{{[0-9]+}}.16b
    705 ; CHECK: ext
    706 ; CHECK: rev64 v{{[0-9]+}}.4s
    707 ; CHECK: ext
    708     %1 = add <16 x i8> %p, %p
    709     %2 = bitcast <16 x i8> %1 to <4 x i32>
    710     %3 = add <4 x i32> %2, %2
    711     ret <4 x i32> %3
    712 }
    713 
    714 ; CHECK-LABEL: test_v8i16_f128:
    715 define <8 x i16> @test_v8i16_f128(fp128 %p) {
    716 ; CHECK: rev64 v{{[0-9]+}}.8h
    717 ; CHECK: ext
    718     %1 = fadd fp128 %p, %p
    719     %2 = bitcast fp128 %1 to <8 x i16>
    720     %3 = add <8 x i16> %2, %2
    721     ret <8 x i16> %3
    722 }
    723 
    724 ; CHECK-LABEL: test_v8i16_v2f64:
    725 define <8 x i16> @test_v8i16_v2f64(<2 x double> %p) {
    726 ; CHECK: ext
    727 ; CHECK: rev64 v{{[0-9]+}}.8h
    728 ; CHECK: ext
    729     %1 = fadd <2 x double> %p, %p
    730     %2 = bitcast <2 x double> %1 to <8 x i16>
    731     %3 = add <8 x i16> %2, %2
    732     ret <8 x i16> %3
    733 }
    734 
    735 ; CHECK-LABEL: test_v8i16_v2i64:
    736 define <8 x i16> @test_v8i16_v2i64(<2 x i64> %p) {
    737 ; CHECK: ext
    738 ; CHECK: rev64 v{{[0-9]+}}.8h
    739 ; CHECK: ext
    740     %1 = add <2 x i64> %p, %p
    741     %2 = bitcast <2 x i64> %1 to <8 x i16>
    742     %3 = add <8 x i16> %2, %2
    743     ret <8 x i16> %3
    744 }
    745 
    746 ; CHECK-LABEL: test_v8i16_v4f32:
    747 define <8 x i16> @test_v8i16_v4f32(<4 x float> %p) {
    748 ; CHECK: rev64 v{{[0-9]+}}.4s
    749 ; CHECK: ext
    750 ; CHECK: rev64 v{{[0-9]+}}.8h
    751 ; CHECK: ext
    752     %1 = fadd <4 x float> %p, %p
    753     %2 = bitcast <4 x float> %1 to <8 x i16>
    754     %3 = add <8 x i16> %2, %2
    755     ret <8 x i16> %3
    756 }
    757 
    758 ; CHECK-LABEL: test_v8i16_v4i32:
    759 define <8 x i16> @test_v8i16_v4i32(<4 x i32> %p) {
    760 ; CHECK: rev64 v{{[0-9]+}}.4s
    761 ; CHECK: ext
    762 ; CHECK: rev64 v{{[0-9]+}}.8h
    763 ; CHECK: ext
    764     %1 = add <4 x i32> %p, %p
    765     %2 = bitcast <4 x i32> %1 to <8 x i16>
    766     %3 = add <8 x i16> %2, %2
    767     ret <8 x i16> %3
    768 }
    769 
    770 ; CHECK-LABEL: test_v8i16_v16i8:
    771 define <8 x i16> @test_v8i16_v16i8(<16 x i8> %p) {
    772 ; CHECK: rev64 v{{[0-9]+}}.16b
    773 ; CHECK: ext
    774 ; CHECK: rev64 v{{[0-9]+}}.8h
    775 ; CHECK: ext
    776     %1 = add <16 x i8> %p, %p
    777     %2 = bitcast <16 x i8> %1 to <8 x i16>
    778     %3 = add <8 x i16> %2, %2
    779     ret <8 x i16> %3
    780 }
    781 
    782 ; CHECK-LABEL: test_v16i8_f128:
    783 define <16 x i8> @test_v16i8_f128(fp128 %p) {
    784 ; CHECK: rev64 v{{[0-9]+}}.16b
    785 ; CHECK: ext
    786     %1 = fadd fp128 %p, %p
    787     %2 = bitcast fp128 %1 to <16 x i8>
    788     %3 = add <16 x i8> %2, %2
    789     ret <16 x i8> %3
    790 }
    791 
    792 ; CHECK-LABEL: test_v16i8_v2f64:
    793 define <16 x i8> @test_v16i8_v2f64(<2 x double> %p) {
    794 ; CHECK: ext
    795 ; CHECK: rev64 v{{[0-9]+}}.16b
    796 ; CHECK: ext
    797     %1 = fadd <2 x double> %p, %p
    798     %2 = bitcast <2 x double> %1 to <16 x i8>
    799     %3 = add <16 x i8> %2, %2
    800     ret <16 x i8> %3
    801 }
    802 
    803 ; CHECK-LABEL: test_v16i8_v2i64:
    804 define <16 x i8> @test_v16i8_v2i64(<2 x i64> %p) {
    805 ; CHECK: ext
    806 ; CHECK: rev64 v{{[0-9]+}}.16b
    807 ; CHECK: ext
    808     %1 = add <2 x i64> %p, %p
    809     %2 = bitcast <2 x i64> %1 to <16 x i8>
    810     %3 = add <16 x i8> %2, %2
    811     ret <16 x i8> %3
    812 }
    813 
    814 ; CHECK-LABEL: test_v16i8_v4f32:
    815 define <16 x i8> @test_v16i8_v4f32(<4 x float> %p) {
    816 ; CHECK: rev64 v{{[0-9]+}}.4s
    817 ; CHECK: ext
    818 ; CHECK: rev64 v{{[0-9]+}}.16b
    819 ; CHECK: ext
    820     %1 = fadd <4 x float> %p, %p
    821     %2 = bitcast <4 x float> %1 to <16 x i8>
    822     %3 = add <16 x i8> %2, %2
    823     ret <16 x i8> %3
    824 }
    825 
    826 ; CHECK-LABEL: test_v16i8_v4i32:
    827 define <16 x i8> @test_v16i8_v4i32(<4 x i32> %p) {
    828 ; CHECK: rev64 v{{[0-9]+}}.4s
    829 ; CHECK: ext
    830 ; CHECK: rev64 v{{[0-9]+}}.16b
    831 ; CHECK: ext
    832     %1 = add <4 x i32> %p, %p
    833     %2 = bitcast <4 x i32> %1 to <16 x i8>
    834     %3 = add <16 x i8> %2, %2
    835     ret <16 x i8> %3
    836 }
    837 
    838 ; CHECK-LABEL: test_v16i8_v8i16:
    839 define <16 x i8> @test_v16i8_v8i16(<8 x i16> %p) {
    840 ; CHECK: rev64 v{{[0-9]+}}.8h
    841 ; CHECK: ext
    842 ; CHECK: rev64 v{{[0-9]+}}.16b
    843 ; CHECK: ext
    844     %1 = add <8 x i16> %p, %p
    845     %2 = bitcast <8 x i16> %1 to <16 x i8>
    846     %3 = add <16 x i8> %2, %2
    847     ret <16 x i8> %3
    848 }
    849