Home | History | Annotate | Download | only in PowerPC
      1 ; RUN: llc -verify-machineinstrs -mcpu=pwr7 -mtriple=powerpc64le-unknown-linux-gnu < %s | FileCheck %s
      2 ; RUN: llc -verify-machineinstrs -mcpu=pwr7 -mtriple=powerpc64-unknown-linux-gnu < %s | FileCheck %s \
      3 ; RUN:   --check-prefix=CHECK-BE
      4 
      5 define <4 x float> @test0f(<4 x float> %a) {
      6 entry:
      7   %0 = bitcast <4 x float> %a to <16 x i8>
      8   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3>
      9   %2 = bitcast <16 x i8> %1 to <4 x float>
     10   ret <4 x float> %2
     11 ; CHECK-LABEL: test0f
     12 ; CHECK xxspltw: 34, 34, 3
     13 ; CHECK-BE-LABEL: test0f
     14 ; CHECK-BE: xxspltw 34, 34, 0
     15 }
     16 
     17 define <4 x float> @test1f(<4 x float> %a) {
     18 entry:
     19   %0 = bitcast <4 x float> %a to <16 x i8>
     20   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7>
     21   %2 = bitcast <16 x i8> %1 to <4 x float>
     22   ret <4 x float> %2
     23 ; CHECK-LABEL: test1f
     24 ; CHECK xxspltw: 34, 34, 2
     25 ; CHECK-BE-LABEL: test1f
     26 ; CHECK-BE: xxspltw 34, 34, 1
     27 }
     28 
     29 define <4 x float> @test2f(<4 x float> %a) {
     30 entry:
     31   %0 = bitcast <4 x float> %a to <16 x i8>
     32   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11>
     33   %2 = bitcast <16 x i8> %1 to <4 x float>
     34   ret <4 x float> %2
     35 ; CHECK-LABEL: test2f
     36 ; CHECK xxspltw: 34, 34, 1
     37 ; CHECK-LABEL: test2f
     38 ; CHECK-BE: xxspltw 34, 34, 2
     39 }
     40 
     41 define <4 x float> @test3f(<4 x float> %a) {
     42 entry:
     43   %0 = bitcast <4 x float> %a to <16 x i8>
     44   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15>
     45   %2 = bitcast <16 x i8> %1 to <4 x float>
     46   ret <4 x float> %2
     47 ; CHECK-LABEL: test3f
     48 ; CHECK xxspltw: 34, 34, 0
     49 ; CHECK-BE-LABEL: test3f
     50 ; CHECK-BE: xxspltw 34, 34, 3
     51 }
     52 
     53 define <4 x i32> @test0si(<4 x i32> %a) {
     54 entry:
     55   %0 = bitcast <4 x i32> %a to <16 x i8>
     56   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3>
     57   %2 = bitcast <16 x i8> %1 to <4 x i32>
     58   ret <4 x i32> %2
     59 ; CHECK-LABEL: test0si
     60 ; CHECK xxspltw: 34, 34, 3
     61 ; CHECK-BE-LABEL: test0si
     62 ; CHECK-BE: xxspltw 34, 34, 0
     63 }
     64 
     65 define <4 x i32> @test1si(<4 x i32> %a) {
     66 entry:
     67   %0 = bitcast <4 x i32> %a to <16 x i8>
     68   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7>
     69   %2 = bitcast <16 x i8> %1 to <4 x i32>
     70   ret <4 x i32> %2
     71 ; CHECK-LABEL: test1si
     72 ; CHECK xxspltw: 34, 34, 2
     73 ; CHECK-BE-LABEL: test1si
     74 ; CHECK-BE: xxspltw 34, 34, 1
     75 }
     76 
     77 define <4 x i32> @test2si(<4 x i32> %a) {
     78 entry:
     79   %0 = bitcast <4 x i32> %a to <16 x i8>
     80   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11>
     81   %2 = bitcast <16 x i8> %1 to <4 x i32>
     82   ret <4 x i32> %2
     83 ; CHECK-LABEL: test2si
     84 ; CHECK xxspltw: 34, 34, 1
     85 ; CHECK-BE-LABEL: test2si
     86 ; CHECK-BE: xxspltw 34, 34, 2
     87 }
     88 
     89 define <4 x i32> @test3si(<4 x i32> %a) {
     90 entry:
     91   %0 = bitcast <4 x i32> %a to <16 x i8>
     92   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15>
     93   %2 = bitcast <16 x i8> %1 to <4 x i32>
     94   ret <4 x i32> %2
     95 ; CHECK-LABEL: test3si
     96 ; CHECK xxspltw: 34, 34, 0
     97 ; CHECK-BE-LABEL: test3si
     98 ; CHECK-BE: xxspltw 34, 34, 3
     99 }
    100 
    101 define <4 x i32> @test0ui(<4 x i32> %a) {
    102 entry:
    103   %0 = bitcast <4 x i32> %a to <16 x i8>
    104   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3, i32 0, i32 1, i32 2, i32 3>
    105   %2 = bitcast <16 x i8> %1 to <4 x i32>
    106   ret <4 x i32> %2
    107 ; CHECK-LABEL: test0ui
    108 ; CHECK xxspltw: 34, 34, 3
    109 ; CHECK-BE-LABEL: test0ui
    110 ; CHECK-BE: xxspltw 34, 34, 0
    111 }
    112 
    113 define <4 x i32> @test1ui(<4 x i32> %a) {
    114 entry:
    115   %0 = bitcast <4 x i32> %a to <16 x i8>
    116   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7, i32 4, i32 5, i32 6, i32 7>
    117   %2 = bitcast <16 x i8> %1 to <4 x i32>
    118   ret <4 x i32> %2
    119 ; CHECK-LABEL: test1ui
    120 ; CHECK xxspltw: 34, 34, 2
    121 ; CHECK-BE-LABEL: test1ui
    122 ; CHECK-BE: xxspltw 34, 34, 1
    123 }
    124 
    125 define <4 x i32> @test2ui(<4 x i32> %a) {
    126 entry:
    127   %0 = bitcast <4 x i32> %a to <16 x i8>
    128   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11, i32 8, i32 9, i32 10, i32 11>
    129   %2 = bitcast <16 x i8> %1 to <4 x i32>
    130   ret <4 x i32> %2
    131 ; CHECK-LABEL: test2ui
    132 ; CHECK xxspltw: 34, 34, 1
    133 ; CHECK-BE-LABEL: test2ui
    134 ; CHECK-BE: xxspltw 34, 34, 2
    135 }
    136 
    137 define <4 x i32> @test3ui(<4 x i32> %a) {
    138 entry:
    139   %0 = bitcast <4 x i32> %a to <16 x i8>
    140   %1 = shufflevector <16 x i8> %0, <16 x i8> undef, <16 x i32> <i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15, i32 12, i32 13, i32 14, i32 15>
    141   %2 = bitcast <16 x i8> %1 to <4 x i32>
    142   ret <4 x i32> %2
    143 ; CHECK-LABEL: test3ui
    144 ; CHECK xxspltw: 34, 34, 0
    145 ; CHECK-BE-LABEL: test3ui
    146 ; CHECK-BE: xxspltw 34, 34, 3
    147 }
    148