blob: fb19cda303d365c8ac597a55ac3f150a447e4b9e [file] [log] [blame]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -mtriple aarch64 -run-pass=aarch64-prelegalizer-combiner -verify-machineinstrs %s -o - | FileCheck %s
...
---
name: add_64_mask_32
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: add_64_mask_32
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC %binop_lhs(s64)
; CHECK: [[TRUNC1:%[0-9]+]]:_(s32) = G_TRUNC %binop_rhs(s64)
; CHECK: [[ADD:%[0-9]+]]:_(s32) = G_ADD [[TRUNC]], [[TRUNC1]]
; CHECK: [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[ADD]](s32)
; CHECK: $x0 = COPY [[ZEXT]](s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: sub_64_mask_32
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: sub_64_mask_32
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC %binop_lhs(s64)
; CHECK: [[TRUNC1:%[0-9]+]]:_(s32) = G_TRUNC %binop_rhs(s64)
; CHECK: [[SUB:%[0-9]+]]:_(s32) = G_SUB [[TRUNC]], [[TRUNC1]]
; CHECK: [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[SUB]](s32)
; CHECK: $x0 = COPY [[ZEXT]](s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_SUB %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: mul_64_mask_32
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: mul_64_mask_32
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC %binop_lhs(s64)
; CHECK: [[TRUNC1:%[0-9]+]]:_(s32) = G_TRUNC %binop_rhs(s64)
; CHECK: [[MUL:%[0-9]+]]:_(s32) = G_MUL [[TRUNC]], [[TRUNC1]]
; CHECK: [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[MUL]](s32)
; CHECK: $x0 = COPY [[ZEXT]](s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_MUL %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: and_64_mask_32
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: and_64_mask_32
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC %binop_lhs(s64)
; CHECK: [[TRUNC1:%[0-9]+]]:_(s32) = G_TRUNC %binop_rhs(s64)
; CHECK: [[AND:%[0-9]+]]:_(s32) = G_AND [[TRUNC]], [[TRUNC1]]
; CHECK: [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[AND]](s32)
; CHECK: $x0 = COPY [[ZEXT]](s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_AND %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: or_64_mask_32
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: or_64_mask_32
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: %mask_32:_(s64) = G_CONSTANT i64 4294967295
; CHECK: %binop:_(s64) = G_SUB %binop_lhs, %binop_rhs
; CHECK: %and:_(s64) = G_OR %binop, %mask_32
; CHECK: $x0 = COPY %and(s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_SUB %binop_lhs, %binop_rhs
%and:_(s64) = G_OR %binop, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: xor_64_mask_32
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: xor_64_mask_32
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC %binop_lhs(s64)
; CHECK: [[TRUNC1:%[0-9]+]]:_(s32) = G_TRUNC %binop_rhs(s64)
; CHECK: [[XOR:%[0-9]+]]:_(s32) = G_XOR [[TRUNC]], [[TRUNC1]]
; CHECK: [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[XOR]](s32)
; CHECK: $x0 = COPY [[ZEXT]](s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_XOR %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: walk_thru_copy
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: walk_thru_copy
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC %binop_lhs(s64)
; CHECK: [[TRUNC1:%[0-9]+]]:_(s32) = G_TRUNC %binop_rhs(s64)
; CHECK: [[ADD:%[0-9]+]]:_(s32) = G_ADD [[TRUNC]], [[TRUNC1]]
; CHECK: [[ZEXT:%[0-9]+]]:_(s64) = G_ZEXT [[ADD]](s32)
; CHECK: $x0 = COPY [[ZEXT]](s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%copy:_(s64) = COPY %binop
%and:_(s64) = G_AND %copy, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: dont_combine_zext_not_free_add_64_mask_16
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: dont_combine_zext_not_free_add_64_mask_16
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: %mask_16:_(s64) = G_CONSTANT i64 65535
; CHECK: %binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
; CHECK: %and:_(s64) = G_AND %binop, %mask_16
; CHECK: $x0 = COPY %and(s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_16:_(s64) = G_CONSTANT i64 65535
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_16
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: dont_combine_zext_not_free_add_64_mask_8
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: dont_combine_zext_not_free_add_64_mask_8
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: %mask_8:_(s64) = G_CONSTANT i64 255
; CHECK: %binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
; CHECK: %and:_(s64) = G_AND %binop, %mask_8
; CHECK: $x0 = COPY %and(s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_8:_(s64) = G_CONSTANT i64 255
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_8
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: dont_combine_not_a_mask
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: dont_combine_not_a_mask
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: %not_a_mask:_(s64) = G_CONSTANT i64 26
; CHECK: %binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
; CHECK: %and:_(s64) = G_AND %binop, %not_a_mask
; CHECK: $x0 = COPY %and(s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%not_a_mask:_(s64) = G_CONSTANT i64 26
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %not_a_mask
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: dont_combine_more_than_one_use
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: dont_combine_more_than_one_use
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: %not_a_mask:_(s64) = G_CONSTANT i64 26
; CHECK: %binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
; CHECK: %and:_(s64) = G_AND %binop, %not_a_mask
; CHECK: %or:_(s64) = G_OR %and, %binop
; CHECK: $x0 = COPY %or(s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%not_a_mask:_(s64) = G_CONSTANT i64 26
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %not_a_mask
%or:_(s64) = G_OR %and, %binop
$x0 = COPY %or(s64)
RET_ReallyLR implicit $x0
...
---
name: dont_combine_vector
tracksRegLiveness: true
body: |
bb.0:
liveins: $q0, $q1
; CHECK-LABEL: name: dont_combine_vector
; CHECK: liveins: $q0, $q1
; CHECK: %binop_lhs:_(<2 x s64>) = COPY $q0
; CHECK: %binop_rhs:_(<2 x s64>) = COPY $q1
; CHECK: %mask_elt:_(s64) = G_CONSTANT i64 4294967295
; CHECK: %mask:_(<2 x s64>) = G_BUILD_VECTOR %mask_elt(s64), %mask_elt(s64)
; CHECK: %binop:_(<2 x s64>) = G_ADD %binop_lhs, %binop_rhs
; CHECK: %and:_(<2 x s64>) = G_AND %binop, %mask
; CHECK: $q0 = COPY %and(<2 x s64>)
; CHECK: RET_ReallyLR implicit $q0
%binop_lhs:_(<2 x s64>) = COPY $q0
%binop_rhs:_(<2 x s64>) = COPY $q1
%mask_elt:_(s64) = G_CONSTANT i64 4294967295
%mask:_(<2 x s64>) = G_BUILD_VECTOR %mask_elt, %mask_elt
%binop:_(<2 x s64>) = G_ADD %binop_lhs, %binop_rhs
%and:_(<2 x s64>) = G_AND %binop, %mask
$q0 = COPY %and(<2 x s64>)
RET_ReallyLR implicit $q0
...
---
name: dont_combine_add_64_mask_64
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: dont_combine_add_64_mask_64
; CHECK: liveins: $x0, $x1
; CHECK: %binop_lhs:_(s64) = COPY $x0
; CHECK: %binop_rhs:_(s64) = COPY $x1
; CHECK: %binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
; CHECK: $x0 = COPY %binop(s64)
; CHECK: RET_ReallyLR implicit $x0
%binop_lhs:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_64:_(s64) = G_CONSTANT i64 18446744073709551615
%binop:_(s64) = G_ADD %binop_lhs, %binop_rhs
%and:_(s64) = G_AND %binop, %mask_64
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0
...
---
name: dont_combine_copy_from_physreg
tracksRegLiveness: true
body: |
bb.0:
liveins: $x0, $x1
; CHECK-LABEL: name: dont_combine_copy_from_physreg
; CHECK: liveins: $x0, $x1
; CHECK: %copy_from_physreg:_(s64) = COPY $x0
; CHECK: %mask_32:_(s64) = G_CONSTANT i64 4294967295
; CHECK: %and:_(s64) = G_AND %copy_from_physreg, %mask_32
; CHECK: $x0 = COPY %and(s64)
; CHECK: RET_ReallyLR implicit $x0
%copy_from_physreg:_(s64) = COPY $x0
%binop_rhs:_(s64) = COPY $x1
%mask_32:_(s64) = G_CONSTANT i64 4294967295
%copy:_(s64) = COPY %copy_from_physreg
%and:_(s64) = G_AND %copy, %mask_32
$x0 = COPY %and(s64)
RET_ReallyLR implicit $x0