| # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py |
| # RUN: llc -mtriple=thumbv8.1m.main-none-none-eabi -mattr=+mve.fp -run-pass arm-prera-ldst-opt %s -o - -verify-machineinstrs | FileCheck %s |
| |
| --- | |
| define ptr @MVE_VLDRWU32(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHU16(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU8(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBS32(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU32(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHS32(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHU32(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBS16(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU16(ptr %x) { unreachable } |
| define ptr @MVE_VSTRWU32(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRHU16(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRBU8(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRH32(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRB32(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRB16(ptr %x, <4 x i32> %y) { unreachable } |
| |
| define ptr @ld0ld4(ptr %x) { unreachable } |
| define ptr @ld4ld0(ptr %x) { unreachable } |
| define ptr @ld0ld4ld0(ptr %x) { unreachable } |
| define ptr @ld4ld0ld4(ptr %x) { unreachable } |
| define ptr @addload(ptr %x) { unreachable } |
| define ptr @sub(ptr %x) { unreachable } |
| define ptr @otherUse(ptr %x) { unreachable } |
| define ptr @postincUse(ptr %x) { unreachable } |
| define ptr @badScale(ptr %x) { unreachable } |
| define ptr @badRange(ptr %x) { unreachable } |
| |
| define ptr @addUseOK(ptr %x) { unreachable } |
| define ptr @addUseDom(ptr %x) { unreachable } |
| define ptr @addUseKilled(ptr %x) { unreachable } |
| |
| define ptr @MVE_VLDRWU32_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHU16_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU8_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBS32_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU32_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHS32_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHU32_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBS16_post(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU16_post(ptr %x) { unreachable } |
| define ptr @MVE_VSTRWU32_post(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRHU16_post(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRBU8_post(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRH32_post(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRB32_post(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRB16_post(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VLDRWU32_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHU16_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU8_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBS32_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU32_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHS32_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRHU32_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBS16_pre(ptr %x) { unreachable } |
| define ptr @MVE_VLDRBU16_pre(ptr %x) { unreachable } |
| define ptr @MVE_VSTRWU32_pre(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRHU16_pre(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRBU8_pre(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRH32_pre(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRB32_pre(ptr %x, <4 x i32> %y) { unreachable } |
| define ptr @MVE_VSTRB16_pre(ptr %x, <4 x i32> %y) { unreachable } |
| |
| define ptr @multiple2(ptr %x) { unreachable } |
| define ptr @multiple3(ptr %x) { unreachable } |
| define ptr @multiple4(ptr %x) { unreachable } |
| define ptr @badScale2(ptr %x) { unreachable } |
| define ptr @badRange2(ptr %x) { unreachable } |
| define ptr @regtype(ptr %x) { unreachable } |
| |
| ... |
| --- |
| name: MVE_VLDRWU32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRWU32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHU16 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHU16 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHU16_post:%[0-9]+]]:rgpr, [[MVE_VLDRHU16_post1:%[0-9]+]]:mqpr = MVE_VLDRHU16_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHU16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRHU16 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU8 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU8 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU8_post:%[0-9]+]]:rgpr, [[MVE_VLDRBU8_post1:%[0-9]+]]:mqpr = MVE_VLDRBU8_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU8_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRBU8 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBS32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBS32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBS32_post:%[0-9]+]]:tgpr, [[MVE_VLDRBS32_post1:%[0-9]+]]:mqpr = MVE_VLDRBS32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s32), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBS32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %1:mqpr = MVE_VLDRBS32 %0, 0, 0, $noreg, $noreg :: (load (s32), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU32_post:%[0-9]+]]:tgpr, [[MVE_VLDRBU32_post1:%[0-9]+]]:mqpr = MVE_VLDRBU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s32), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %1:mqpr = MVE_VLDRBU32 %0, 0, 0, $noreg, $noreg :: (load (s32), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHS32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHS32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHS32_post:%[0-9]+]]:tgpr, [[MVE_VLDRHS32_post1:%[0-9]+]]:mqpr = MVE_VLDRHS32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s64)) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHS32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %1:mqpr = MVE_VLDRHS32 %0, 0, 0, $noreg, $noreg :: (load (s64), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHU32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHU32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHU32_post:%[0-9]+]]:tgpr, [[MVE_VLDRHU32_post1:%[0-9]+]]:mqpr = MVE_VLDRHU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s64)) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %1:mqpr = MVE_VLDRHU32 %0, 0, 0, $noreg, $noreg :: (load (s64), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBS16 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBS16 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBS16_post:%[0-9]+]]:tgpr, [[MVE_VLDRBS16_post1:%[0-9]+]]:mqpr = MVE_VLDRBS16_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s64)) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBS16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %1:mqpr = MVE_VLDRBS16 %0, 0, 0, $noreg, $noreg :: (load (s64), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU16 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU16 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU16_post:%[0-9]+]]:tgpr, [[MVE_VLDRBU16_post1:%[0-9]+]]:mqpr = MVE_VLDRBU16_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s64)) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %1:mqpr = MVE_VLDRBU16 %0, 0, 0, $noreg, $noreg :: (load (s64), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRWU32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRWU32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRWU32_post:%[0-9]+]]:rgpr = MVE_VSTRWU32_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:gprnopc = COPY $r0 |
| MVE_VSTRWU32 %1, %0, 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRHU16 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRHU16 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRHU16_post:%[0-9]+]]:rgpr = MVE_VSTRHU16_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRHU16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:gprnopc = COPY $r0 |
| MVE_VSTRHU16 %1, %0, 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRBU8 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRBU8 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRBU8_post:%[0-9]+]]:rgpr = MVE_VSTRBU8_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRBU8_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:gprnopc = COPY $r0 |
| MVE_VSTRBU8 %1, %0, 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRH32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRH32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRH32_post:%[0-9]+]]:tgpr = MVE_VSTRH32_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s64)) |
| ; CHECK: $r0 = COPY [[MVE_VSTRH32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| MVE_VSTRH32 %1, %0, 0, 0, $noreg, $noreg :: (store (s64), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRB32 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRB32 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB32_post:%[0-9]+]]:tgpr = MVE_VSTRB32_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s32), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| MVE_VSTRB32 %1, %0, 0, 0, $noreg, $noreg :: (store (s32), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRB16 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRB16 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_post:%[0-9]+]]:tgpr = MVE_VSTRB16_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s64)) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| MVE_VSTRB16 %1, %0, 0, 0, $noreg, $noreg :: (store (s64), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: ld0ld4 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: ld0ld4 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], -28, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: ld4ld0 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: ld4ld0 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: ld0ld4ld0 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| - { id: 4, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: ld0ld4ld0 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_1:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| %4:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: ld4ld0ld4 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| - { id: 4, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: ld4ld0ld4 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_1:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], -28, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %4:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: addload |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: addload |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], -28, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: sub |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: sub |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], -32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], 36, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2SUBri %0, 32, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: otherUse |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: otherUse |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:gprnopc = COPY $r0 |
| ; CHECK: [[t2ADDri:%[0-9]+]]:rgpr = nuw t2ADDri [[COPY]], 32, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_1:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[COPY]] |
| ; CHECK: $r0 = COPY [[t2ADDri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %0 |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: postincUse |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| - { id: 4, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: postincUse |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[t2ADDri:%[0-9]+]]:rgpr = nuw t2ADDri [[COPY]], 32, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[t2ADDri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %4:rgpr, %3:mqpr = MVE_VLDRWU32_post %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: badScale |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: badScale |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:gprnopc = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[t2SUBri:%[0-9]+]]:rgpr = nuw t2SUBri [[COPY]], 3, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[MVE_VLDRWU32_1:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[t2SUBri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2SUBri %0, 3, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: badRange |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: badRange |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:gprnopc = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[t2SUBri:%[0-9]+]]:rgpr = nuw t2SUBri [[COPY]], -300, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[MVE_VLDRWU32_1:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], -300, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[t2SUBri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2SUBri %0, -300, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, -300, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: addUseOK |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| - { id: 4, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: addUseOK |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], -32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], 36, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[t2LSRri:%[0-9]+]]:rgpr = nuw t2LSRri [[MVE_VLDRWU32_post]], 2, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: $r0 = COPY [[t2LSRri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2SUBri %0, 32, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| %4:rgpr = nuw t2LSRri %2, 2, 14, $noreg, $noreg |
| $r0 = COPY %4 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: addUseDom |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| - { id: 4, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: addUseDom |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:gprnopc = COPY $r0 |
| ; CHECK: [[t2SUBri:%[0-9]+]]:rgpr = nuw t2SUBri [[COPY]], 32, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[t2LSRri:%[0-9]+]]:rgpr = nuw t2LSRri [[t2SUBri]], 2, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_1:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[COPY]], 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[t2LSRri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %2:rgpr = nuw t2SUBri %0, 32, 14, $noreg, $noreg |
| %4:rgpr = nuw t2LSRri %2, 2, 14, $noreg, $noreg |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %4 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: addUseKilled |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gprnopc, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: mqpr, preferred-register: '' } |
| - { id: 4, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: addUseKilled |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], -32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[t2LSRri:%[0-9]+]]:rgpr = nuw t2LSRri [[MVE_VLDRWU32_post]], 2, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], 36, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[t2LSRri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:gprnopc = COPY $r0 |
| %1:mqpr = MVE_VLDRWU32 %0, 0, 0, $noreg, $noreg :: (load (s128), align 8) |
| %2:rgpr = nuw t2SUBri %0, 32, 14, $noreg, $noreg |
| %4:rgpr = nuw t2LSRri killed %2, 2, 14, $noreg, $noreg |
| %3:mqpr = MVE_VLDRWU32 %0, 4, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %4 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRWU32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRWU32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_post:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_post1:%[0-9]+]]:mqpr = MVE_VLDRWU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr, %1:mqpr = MVE_VLDRWU32_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRWU32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHU16_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHU16_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHU16_post:%[0-9]+]]:rgpr, [[MVE_VLDRHU16_post1:%[0-9]+]]:mqpr = MVE_VLDRHU16_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRHU16_:%[0-9]+]]:mqpr = MVE_VLDRHU16 [[MVE_VLDRHU16_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHU16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr, %1:mqpr = MVE_VLDRHU16_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRHU16 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU8_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU8_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU8_post:%[0-9]+]]:rgpr, [[MVE_VLDRBU8_post1:%[0-9]+]]:mqpr = MVE_VLDRBU8_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBU8_:%[0-9]+]]:mqpr = MVE_VLDRBU8 [[MVE_VLDRBU8_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU8_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr, %1:mqpr = MVE_VLDRBU8_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBU8 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBS32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBS32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBS32_post:%[0-9]+]]:tgpr, [[MVE_VLDRBS32_post1:%[0-9]+]]:mqpr = MVE_VLDRBS32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBS32_:%[0-9]+]]:mqpr = MVE_VLDRBS32 [[MVE_VLDRBS32_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBS32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBS32_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBS32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU32_post:%[0-9]+]]:tgpr, [[MVE_VLDRBU32_post1:%[0-9]+]]:mqpr = MVE_VLDRBU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBU32_:%[0-9]+]]:mqpr = MVE_VLDRBU32 [[MVE_VLDRBU32_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBU32_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBU32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHS32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHS32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHS32_post:%[0-9]+]]:tgpr, [[MVE_VLDRHS32_post1:%[0-9]+]]:mqpr = MVE_VLDRHS32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRHS32_:%[0-9]+]]:mqpr = MVE_VLDRHS32 [[MVE_VLDRHS32_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHS32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRHS32_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRHS32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHU32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHU32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHU32_post:%[0-9]+]]:tgpr, [[MVE_VLDRHU32_post1:%[0-9]+]]:mqpr = MVE_VLDRHU32_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRHU32_:%[0-9]+]]:mqpr = MVE_VLDRHU32 [[MVE_VLDRHU32_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRHU32_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRHU32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBS16_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBS16_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBS16_post:%[0-9]+]]:tgpr, [[MVE_VLDRBS16_post1:%[0-9]+]]:mqpr = MVE_VLDRBS16_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBS16_:%[0-9]+]]:mqpr = MVE_VLDRBS16 [[MVE_VLDRBS16_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBS16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBS16_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBS16 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU16_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU16_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU16_post:%[0-9]+]]:tgpr, [[MVE_VLDRBU16_post1:%[0-9]+]]:mqpr = MVE_VLDRBU16_post [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBU16_:%[0-9]+]]:mqpr = MVE_VLDRBU16 [[MVE_VLDRBU16_post]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBU16_post %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBU16 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRWU32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRWU32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRWU32_post:%[0-9]+]]:rgpr = MVE_VSTRWU32_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRWU32 [[COPY]], [[MVE_VSTRWU32_post]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRWU32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = MVE_VSTRWU32_post %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRWU32 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRHU16_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRHU16_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRHU16_post:%[0-9]+]]:rgpr = MVE_VSTRHU16_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRHU16 [[COPY]], [[MVE_VSTRHU16_post]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRHU16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = MVE_VSTRHU16_post %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRHU16 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRBU8_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRBU8_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRBU8_post:%[0-9]+]]:rgpr = MVE_VSTRBU8_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRBU8 [[COPY]], [[MVE_VSTRBU8_post]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRBU8_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = MVE_VSTRBU8_post %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRBU8 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRH32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRH32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRH32_post:%[0-9]+]]:tgpr = MVE_VSTRH32_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRH32 [[COPY]], [[MVE_VSTRH32_post]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRH32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRH32_post %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRH32 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRB32_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRB32_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB32_post:%[0-9]+]]:tgpr = MVE_VSTRB32_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB32 [[COPY]], [[MVE_VSTRB32_post]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB32_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB32_post %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB32 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRB16_post |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRB16_post |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_post:%[0-9]+]]:tgpr = MVE_VSTRB16_post [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[MVE_VSTRB16_post]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB16_post]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB16_post %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRWU32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRWU32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRWU32_pre:%[0-9]+]]:rgpr, [[MVE_VLDRWU32_pre1:%[0-9]+]]:mqpr = MVE_VLDRWU32_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRWU32_:%[0-9]+]]:mqpr = MVE_VLDRWU32 [[MVE_VLDRWU32_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRWU32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr, %1:mqpr = MVE_VLDRWU32_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRWU32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHU16_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHU16_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHU16_pre:%[0-9]+]]:rgpr, [[MVE_VLDRHU16_pre1:%[0-9]+]]:mqpr = MVE_VLDRHU16_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRHU16_:%[0-9]+]]:mqpr = MVE_VLDRHU16 [[MVE_VLDRHU16_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHU16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr, %1:mqpr = MVE_VLDRHU16_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRHU16 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU8_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU8_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU8_pre:%[0-9]+]]:rgpr, [[MVE_VLDRBU8_pre1:%[0-9]+]]:mqpr = MVE_VLDRBU8_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBU8_:%[0-9]+]]:mqpr = MVE_VLDRBU8 [[MVE_VLDRBU8_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU8_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr, %1:mqpr = MVE_VLDRBU8_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBU8 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBS32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBS32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBS32_pre:%[0-9]+]]:tgpr, [[MVE_VLDRBS32_pre1:%[0-9]+]]:mqpr = MVE_VLDRBS32_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBS32_:%[0-9]+]]:mqpr = MVE_VLDRBS32 [[MVE_VLDRBS32_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBS32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBS32_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBS32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU32_pre:%[0-9]+]]:tgpr, [[MVE_VLDRBU32_pre1:%[0-9]+]]:mqpr = MVE_VLDRBU32_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBU32_:%[0-9]+]]:mqpr = MVE_VLDRBU32 [[MVE_VLDRBU32_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBU32_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBU32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHS32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHS32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHS32_pre:%[0-9]+]]:tgpr, [[MVE_VLDRHS32_pre1:%[0-9]+]]:mqpr = MVE_VLDRHS32_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRHS32_:%[0-9]+]]:mqpr = MVE_VLDRHS32 [[MVE_VLDRHS32_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHS32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRHS32_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRHS32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRHU32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRHU32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRHU32_pre:%[0-9]+]]:tgpr, [[MVE_VLDRHU32_pre1:%[0-9]+]]:mqpr = MVE_VLDRHU32_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRHU32_:%[0-9]+]]:mqpr = MVE_VLDRHU32 [[MVE_VLDRHU32_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRHU32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRHU32_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRHU32 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBS16_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBS16_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBS16_pre:%[0-9]+]]:tgpr, [[MVE_VLDRBS16_pre1:%[0-9]+]]:mqpr = MVE_VLDRBS16_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBS16_:%[0-9]+]]:mqpr = MVE_VLDRBS16 [[MVE_VLDRBS16_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBS16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBS16_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBS16 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VLDRBU16_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VLDRBU16_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VLDRBU16_pre:%[0-9]+]]:tgpr, [[MVE_VLDRBU16_pre1:%[0-9]+]]:mqpr = MVE_VLDRBU16_pre [[COPY]], 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: [[MVE_VLDRBU16_:%[0-9]+]]:mqpr = MVE_VLDRBU16 [[MVE_VLDRBU16_pre]], -16, 0, $noreg, $noreg :: (load (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VLDRBU16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr, %1:mqpr = MVE_VLDRBU16_pre %0, 32, 0, $noreg, $noreg :: (load (s128), align 8) |
| %1:mqpr = MVE_VLDRBU16 %0, 16, 0, $noreg, $noreg :: (load (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRWU32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRWU32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRWU32_pre:%[0-9]+]]:rgpr = MVE_VSTRWU32_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRWU32 [[COPY]], [[MVE_VSTRWU32_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRWU32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = MVE_VSTRWU32_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRWU32 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRHU16_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRHU16_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRHU16_pre:%[0-9]+]]:rgpr = MVE_VSTRHU16_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRHU16 [[COPY]], [[MVE_VSTRHU16_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRHU16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = MVE_VSTRHU16_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRHU16 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRBU8_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: rgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRBU8_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:rgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRBU8_pre:%[0-9]+]]:rgpr = MVE_VSTRBU8_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRBU8 [[COPY]], [[MVE_VSTRBU8_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRBU8_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:rgpr = COPY $r0 |
| %2:rgpr = MVE_VSTRBU8_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRBU8 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRH32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRH32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRH32_pre:%[0-9]+]]:tgpr = MVE_VSTRH32_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRH32 [[COPY]], [[MVE_VSTRH32_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRH32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRH32_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRH32 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRB32_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRB32_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB32_pre:%[0-9]+]]:tgpr = MVE_VSTRB32_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB32 [[COPY]], [[MVE_VSTRB32_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB32_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB32_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB32 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: MVE_VSTRB16_pre |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: MVE_VSTRB16_pre |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_pre:%[0-9]+]]:tgpr = MVE_VSTRB16_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[MVE_VSTRB16_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB16_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: multiple2 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: multiple2 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_pre:%[0-9]+]]:tgpr = MVE_VSTRB16_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[MVE_VSTRB16_pre]], -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[MVE_VSTRB16_pre]], -48, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[MVE_VSTRB16_pre]], 2, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB16_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, -16, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, 34, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: multiple3 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| - { id: 3, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: multiple3 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_pre:%[0-9]+]]:tgpr = MVE_VSTRB16_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: [[MVE_VSTRB16_pre1:%[0-9]+]]:tgpr = MVE_VSTRB16_pre [[COPY]], [[COPY1]], 64, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[MVE_VSTRB16_pre1]], -48, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB16_pre1]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB16_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| %3:tgpr = MVE_VSTRB16_pre %1, %0, 64, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, 16, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %3 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: multiple4 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| - { id: 3, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: multiple4 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_pre:%[0-9]+]]:tgpr = MVE_VSTRB16_pre [[COPY]], [[COPY1]], 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[COPY1]], 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: [[t2ADDri:%[0-9]+]]:tgpr = nuw t2ADDri [[COPY1]], 32, 14 /* CC::al */, $noreg, $noreg |
| ; CHECK: $r0 = COPY [[t2ADDri]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB16_pre %1, %0, 32, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| %3:tgpr = nuw t2ADDri %0, 32, 14, $noreg, $noreg |
| $r0 = COPY %3 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: badScale2 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: badScale2 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRBU8_pre:%[0-9]+]]:tgpr = MVE_VSTRBU8_pre [[COPY]], [[COPY1]], 33, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRWU32 [[COPY]], [[COPY1]], 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRBU8_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRBU8_pre %1, %0, 33, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRWU32 %1, %0, 0, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: badRange2 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: tgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: badRange2 |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[MVE_VSTRB16_pre:%[0-9]+]]:tgpr = MVE_VSTRB16_pre [[COPY]], [[COPY1]], 100, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: MVE_VSTRB16 [[COPY]], [[COPY1]], -100, 0, $noreg, $noreg :: (store (s128), align 8) |
| ; CHECK: $r0 = COPY [[MVE_VSTRB16_pre]] |
| ; CHECK: tBX_RET 14 /* CC::al */, $noreg, implicit $r0 |
| %1:mqpr = COPY $q0 |
| %0:tgpr = COPY $r0 |
| %2:tgpr = MVE_VSTRB16_pre %1, %0, 100, 0, $noreg, $noreg :: (store (s128), align 8) |
| MVE_VSTRB16 %1, %0, -100, 0, $noreg, $noreg :: (store (s128), align 8) |
| $r0 = COPY %2 |
| tBX_RET 14, $noreg, implicit $r0 |
| |
| ... |
| --- |
| name: regtype |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: tgpr, preferred-register: '' } |
| - { id: 1, class: mqpr, preferred-register: '' } |
| - { id: 2, class: rgpr, preferred-register: '' } |
| - { id: 3, class: rgpr, preferred-register: '' } |
| liveins: |
| - { reg: '$r0', virtual-reg: '%0' } |
| - { reg: '$q0', virtual-reg: '%1' } |
| body: | |
| bb.0: |
| liveins: $r0, $q0 |
| |
| ; CHECK-LABEL: name: regtype |
| ; CHECK: liveins: $r0, $q0 |
| ; CHECK: [[COPY:%[0-9]+]]:mqpr = COPY $q0 |
| ; CHECK: [[COPY1:%[0-9]+]]:tgpr = COPY $r0 |
| ; CHECK: [[t2LDRB_POST:%[0-9]+]]:rgpr, [[t2LDRB_POST1:%[0-9]+]]:tgpr = t2LDRB_POST [[COPY1]], 32, 14 /* CC::al */, $noreg :: (load (s8), align 2) |
| ; CHECK: MVE_VSTRB16 [[COPY |