| # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py |
| # RUN: llc -mtriple aarch64 -run-pass=aarch64-postlegalizer-combiner -verify-machineinstrs %s -o - | FileCheck %s |
| |
| ... |
| --- |
| name: v2s64_split |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; Split a store of <2 x i64> into two scalar stores. |
| |
| ; CHECK-LABEL: name: v2s64_split |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: %zero:_(s64) = G_CONSTANT i64 0 |
| ; CHECK-NEXT: [[C:%[0-9]+]]:_(s64) = G_CONSTANT i64 8 |
| ; CHECK-NEXT: [[PTR_ADD:%[0-9]+]]:_(p0) = G_PTR_ADD [[COPY]], [[C]](s64) |
| ; CHECK-NEXT: G_STORE %zero(s64), [[COPY]](p0) :: (store (s64), align 16) |
| ; CHECK-NEXT: G_STORE %zero(s64), [[PTR_ADD]](p0) :: (store (s64) into unknown-address + 8) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s64) = G_CONSTANT i64 0 |
| %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero, %zero |
| G_STORE %zerovec(<2 x s64>), %0(p0) :: (store (<2 x s64>)) |
| RET_ReallyLR |
| |
| ... |
| --- |
| name: v4i32_split |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: name: v4i32_split |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: [[C:%[0-9]+]]:_(s64) = G_CONSTANT i64 0 |
| ; CHECK-NEXT: [[C1:%[0-9]+]]:_(s64) = G_CONSTANT i64 8 |
| ; CHECK-NEXT: [[PTR_ADD:%[0-9]+]]:_(p0) = G_PTR_ADD [[COPY]], [[C1]](s64) |
| ; CHECK-NEXT: G_STORE [[C]](s64), [[COPY]](p0) :: (store (s64), align 16) |
| ; CHECK-NEXT: G_STORE [[C]](s64), [[PTR_ADD]](p0) :: (store (s64) into unknown-address + 8) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s32) = G_CONSTANT i32 0 |
| %zerovec:_(<4 x s32>) = G_BUILD_VECTOR %zero, %zero, %zero, %zero |
| G_STORE %zerovec(<4 x s32>), %0(p0) :: (store (<4 x s32>)) |
| RET_ReallyLR |
| |
| ... |
| --- |
| name: v8i16_split |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: name: v8i16_split |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: [[C:%[0-9]+]]:_(s64) = G_CONSTANT i64 0 |
| ; CHECK-NEXT: [[C1:%[0-9]+]]:_(s64) = G_CONSTANT i64 8 |
| ; CHECK-NEXT: [[PTR_ADD:%[0-9]+]]:_(p0) = G_PTR_ADD [[COPY]], [[C1]](s64) |
| ; CHECK-NEXT: G_STORE [[C]](s64), [[COPY]](p0) :: (store (s64), align 16) |
| ; CHECK-NEXT: G_STORE [[C]](s64), [[PTR_ADD]](p0) :: (store (s64) into unknown-address + 8) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s16) = G_CONSTANT i16 0 |
| %zerovec:_(<8 x s16>) = G_BUILD_VECTOR %zero, %zero, %zero, %zero, %zero, %zero, %zero, %zero |
| G_STORE %zerovec(<8 x s16>), %0(p0) :: (store (<8 x s16>)) |
| RET_ReallyLR |
| |
| ... |
| |
| # Negative tests |
| --- |
| name: v2i32_nosplit |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: name: v2i32_nosplit |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: %zero:_(s32) = G_CONSTANT i32 0 |
| ; CHECK-NEXT: %zerovec:_(<2 x s32>) = G_BUILD_VECTOR %zero(s32), %zero(s32) |
| ; CHECK-NEXT: G_STORE %zerovec(<2 x s32>), [[COPY]](p0) :: (store (<2 x s32>)) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s32) = G_CONSTANT i32 0 |
| %zerovec:_(<2 x s32>) = G_BUILD_VECTOR %zero, %zero |
| G_STORE %zerovec(<2 x s32>), %0(p0) :: (store (<2 x s32>)) |
| RET_ReallyLR |
| |
| ... |
| --- |
| name: multiple_uses |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: name: multiple_uses |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: %zero:_(s64) = G_CONSTANT i64 0 |
| ; CHECK-NEXT: %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64) |
| ; CHECK-NEXT: G_STORE %zerovec(<2 x s64>), [[COPY]](p0) :: (store (<2 x s64>)) |
| ; CHECK-NEXT: $q0 = COPY %zerovec(<2 x s64>) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s64) = G_CONSTANT i64 0 |
| %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero, %zero |
| G_STORE %zerovec(<2 x s64>), %0(p0) :: (store (<2 x s64>)) |
| $q0 = COPY %zerovec |
| RET_ReallyLR |
| |
| ... |
| --- |
| name: truncating |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: name: truncating |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: %zero:_(s64) = G_CONSTANT i64 0 |
| ; CHECK-NEXT: %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64) |
| ; CHECK-NEXT: G_STORE %zerovec(<2 x s64>), [[COPY]](p0) :: (store (<2 x s32>)) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s64) = G_CONSTANT i64 0 |
| %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero, %zero |
| G_STORE %zerovec(<2 x s64>), %0(p0) :: (store (<2 x s32>)) |
| RET_ReallyLR |
| |
| ... |
| --- |
| name: volatile |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: name: volatile |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: %zero:_(s64) = G_CONSTANT i64 0 |
| ; CHECK-NEXT: %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero(s64), %zero(s64) |
| ; CHECK-NEXT: G_STORE %zerovec(<2 x s64>), [[COPY]](p0) :: (volatile store (<2 x s64>)) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s64) = G_CONSTANT i64 0 |
| %zerovec:_(<2 x s64>) = G_BUILD_VECTOR %zero, %zero |
| G_STORE %zerovec(<2 x s64>), %0(p0) :: (volatile store (<2 x s64>)) |
| RET_ReallyLR |
| |
| ... |
| --- |
| name: s128_scalar |
| legalized: true |
| tracksRegLiveness: true |
| body: | |
| bb.1.entry: |
| liveins: $x0 |
| |
| ; Split a store of <2 x i64> into two scalar stores. |
| |
| ; CHECK-LABEL: name: s128_scalar |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY $x0 |
| ; CHECK-NEXT: %zero:_(s128) = G_CONSTANT i128 0 |
| ; CHECK-NEXT: G_STORE %zero(s128), [[COPY]](p0) :: (store (s128)) |
| ; CHECK-NEXT: RET_ReallyLR |
| %0:_(p0) = COPY $x0 |
| %zero:_(s128) = G_CONSTANT i128 0 |
| G_STORE %zero(s128), %0(p0) :: (store (s128)) |
| RET_ReallyLR |
| |
| ... |