1# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py 2# RUN: llc -mtriple=mipsel-linux-gnu -mcpu=mips32r5 -mattr=+msa,+fp64,+nan2008 -run-pass=regbankselect -verify-machineinstrs %s -o - | FileCheck %s -check-prefixes=P5600 3--- | 4 5 define void @mul_v16i8(<16 x i8>* %a, <16 x i8>* %b, <16 x i8>* %c) { entry: ret void } 6 define void @mul_v8i16(<8 x i16>* %a, <8 x i16>* %b, <8 x i16>* %c) { entry: ret void } 7 define void @mul_v4i32(<4 x i32>* %a, <4 x i32>* %b, <4 x i32>* %c) { entry: ret void } 8 define void @mul_v2i64(<2 x i64>* %a, <2 x i64>* %b, <2 x i64>* %c) { entry: ret void } 9 10... 11--- 12name: mul_v16i8 13alignment: 4 14legalized: true 15tracksRegLiveness: true 16body: | 17 bb.1.entry: 18 liveins: $a0, $a1, $a2 19 20 ; P5600-LABEL: name: mul_v16i8 21 ; P5600: liveins: $a0, $a1, $a2 22 ; P5600: [[COPY:%[0-9]+]]:gprb(p0) = COPY $a0 23 ; P5600: [[COPY1:%[0-9]+]]:gprb(p0) = COPY $a1 24 ; P5600: [[COPY2:%[0-9]+]]:gprb(p0) = COPY $a2 25 ; P5600: [[LOAD:%[0-9]+]]:fprb(<16 x s8>) = G_LOAD [[COPY]](p0) :: (load 16 from %ir.a) 26 ; P5600: [[LOAD1:%[0-9]+]]:fprb(<16 x s8>) = G_LOAD [[COPY1]](p0) :: (load 16 from %ir.b) 27 ; P5600: [[MUL:%[0-9]+]]:fprb(<16 x s8>) = G_MUL [[LOAD1]], [[LOAD]] 28 ; P5600: G_STORE [[MUL]](<16 x s8>), [[COPY2]](p0) :: (store 16 into %ir.c) 29 ; P5600: RetRA 30 %0:_(p0) = COPY $a0 31 %1:_(p0) = COPY $a1 32 %2:_(p0) = COPY $a2 33 %3:_(<16 x s8>) = G_LOAD %0(p0) :: (load 16 from %ir.a) 34 %4:_(<16 x s8>) = G_LOAD %1(p0) :: (load 16 from %ir.b) 35 %5:_(<16 x s8>) = G_MUL %4, %3 36 G_STORE %5(<16 x s8>), %2(p0) :: (store 16 into %ir.c) 37 RetRA 38 39... 40--- 41name: mul_v8i16 42alignment: 4 43legalized: true 44tracksRegLiveness: true 45body: | 46 bb.1.entry: 47 liveins: $a0, $a1, $a2 48 49 ; P5600-LABEL: name: mul_v8i16 50 ; P5600: liveins: $a0, $a1, $a2 51 ; P5600: [[COPY:%[0-9]+]]:gprb(p0) = COPY $a0 52 ; P5600: [[COPY1:%[0-9]+]]:gprb(p0) = COPY $a1 53 ; P5600: [[COPY2:%[0-9]+]]:gprb(p0) = COPY $a2 54 ; P5600: [[LOAD:%[0-9]+]]:fprb(<8 x s16>) = G_LOAD [[COPY]](p0) :: (load 16 from %ir.a) 55 ; P5600: [[LOAD1:%[0-9]+]]:fprb(<8 x s16>) = G_LOAD [[COPY1]](p0) :: (load 16 from %ir.b) 56 ; P5600: [[MUL:%[0-9]+]]:fprb(<8 x s16>) = G_MUL [[LOAD1]], [[LOAD]] 57 ; P5600: G_STORE [[MUL]](<8 x s16>), [[COPY2]](p0) :: (store 16 into %ir.c) 58 ; P5600: RetRA 59 %0:_(p0) = COPY $a0 60 %1:_(p0) = COPY $a1 61 %2:_(p0) = COPY $a2 62 %3:_(<8 x s16>) = G_LOAD %0(p0) :: (load 16 from %ir.a) 63 %4:_(<8 x s16>) = G_LOAD %1(p0) :: (load 16 from %ir.b) 64 %5:_(<8 x s16>) = G_MUL %4, %3 65 G_STORE %5(<8 x s16>), %2(p0) :: (store 16 into %ir.c) 66 RetRA 67 68... 69--- 70name: mul_v4i32 71alignment: 4 72legalized: true 73tracksRegLiveness: true 74body: | 75 bb.1.entry: 76 liveins: $a0, $a1, $a2 77 78 ; P5600-LABEL: name: mul_v4i32 79 ; P5600: liveins: $a0, $a1, $a2 80 ; P5600: [[COPY:%[0-9]+]]:gprb(p0) = COPY $a0 81 ; P5600: [[COPY1:%[0-9]+]]:gprb(p0) = COPY $a1 82 ; P5600: [[COPY2:%[0-9]+]]:gprb(p0) = COPY $a2 83 ; P5600: [[LOAD:%[0-9]+]]:fprb(<4 x s32>) = G_LOAD [[COPY]](p0) :: (load 16 from %ir.a) 84 ; P5600: [[LOAD1:%[0-9]+]]:fprb(<4 x s32>) = G_LOAD [[COPY1]](p0) :: (load 16 from %ir.b) 85 ; P5600: [[MUL:%[0-9]+]]:fprb(<4 x s32>) = G_MUL [[LOAD1]], [[LOAD]] 86 ; P5600: G_STORE [[MUL]](<4 x s32>), [[COPY2]](p0) :: (store 16 into %ir.c) 87 ; P5600: RetRA 88 %0:_(p0) = COPY $a0 89 %1:_(p0) = COPY $a1 90 %2:_(p0) = COPY $a2 91 %3:_(<4 x s32>) = G_LOAD %0(p0) :: (load 16 from %ir.a) 92 %4:_(<4 x s32>) = G_LOAD %1(p0) :: (load 16 from %ir.b) 93 %5:_(<4 x s32>) = G_MUL %4, %3 94 G_STORE %5(<4 x s32>), %2(p0) :: (store 16 into %ir.c) 95 RetRA 96 97... 98--- 99name: mul_v2i64 100alignment: 4 101legalized: true 102tracksRegLiveness: true 103body: | 104 bb.1.entry: 105 liveins: $a0, $a1, $a2 106 107 ; P5600-LABEL: name: mul_v2i64 108 ; P5600: liveins: $a0, $a1, $a2 109 ; P5600: [[COPY:%[0-9]+]]:gprb(p0) = COPY $a0 110 ; P5600: [[COPY1:%[0-9]+]]:gprb(p0) = COPY $a1 111 ; P5600: [[COPY2:%[0-9]+]]:gprb(p0) = COPY $a2 112 ; P5600: [[LOAD:%[0-9]+]]:fprb(<2 x s64>) = G_LOAD [[COPY]](p0) :: (load 16 from %ir.a) 113 ; P5600: [[LOAD1:%[0-9]+]]:fprb(<2 x s64>) = G_LOAD [[COPY1]](p0) :: (load 16 from %ir.b) 114 ; P5600: [[MUL:%[0-9]+]]:fprb(<2 x s64>) = G_MUL [[LOAD1]], [[LOAD]] 115 ; P5600: G_STORE [[MUL]](<2 x s64>), [[COPY2]](p0) :: (store 16 into %ir.c) 116 ; P5600: RetRA 117 %0:_(p0) = COPY $a0 118 %1:_(p0) = COPY $a1 119 %2:_(p0) = COPY $a2 120 %3:_(<2 x s64>) = G_LOAD %0(p0) :: (load 16 from %ir.a) 121 %4:_(<2 x s64>) = G_LOAD %1(p0) :: (load 16 from %ir.b) 122 %5:_(<2 x s64>) = G_MUL %4, %3 123 G_STORE %5(<2 x s64>), %2(p0) :: (store 16 into %ir.c) 124 RetRA 125 126... 127