forked from OSchip/llvm-project
877 lines
23 KiB
LLVM
877 lines
23 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -mtriple=thumbv8.1m.main-arm-none-eabi -mattr=+mve -verify-machineinstrs %s -o - | FileCheck %s
|
|
|
|
declare {i32, i32} @llvm.arm.mve.asrl(i32, i32, i32)
|
|
declare {i32, i32} @llvm.arm.mve.lsll(i32, i32, i32)
|
|
|
|
define i32 @ashr_demand_bottom3(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottom3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #3
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottom3(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottom3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #3
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_bottomm3(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottomm3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #3
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottomm3(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottomm3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #3
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_bottom31(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottom31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #31
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottom31(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottom31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #31
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_bottomm31(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottomm31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #31
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottomm31(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottomm31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #31
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_bottom32(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottom32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #32
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottom32(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottom32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #32
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_bottomm32(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottomm32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #32
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottomm32(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottomm32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #32
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_bottom44(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottom44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: movs r2, #44
|
|
; CHECK-NEXT: asrl r0, r1, r2
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottom44(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottom44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: movs r2, #44
|
|
; CHECK-NEXT: lsll r0, r1, r2
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_bottomm44(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottomm44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: mvn r2, #43
|
|
; CHECK-NEXT: asrl r0, r1, r2
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_bottomm44(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottomm44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: mvn r2, #43
|
|
; CHECK-NEXT: lsll r0, r1, r2
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
define i32 @ashr_demand_top3(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_top3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #3
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_top3(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_top3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #3
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_topm3(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_topm3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #3
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_topm3(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_topm3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #3
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_top31(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_top31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #31
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_top31(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_top31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #31
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_topm31(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_topm31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #31
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_topm31(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_topm31:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #31
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -31)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_top32(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_top32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #32
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_top32(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_top32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #32
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_topm32(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_topm32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #32
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_topm32(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_topm32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #32
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_top44(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_top44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: movs r2, #44
|
|
; CHECK-NEXT: asrl r0, r1, r2
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_top44(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_top44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: movs r2, #44
|
|
; CHECK-NEXT: lsll r0, r1, r2
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @ashr_demand_topm44(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_topm44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: mvn r2, #43
|
|
; CHECK-NEXT: asrl r0, r1, r2
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
define i32 @lsll_demand_topm44(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_topm44:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: mvn r2, #43
|
|
; CHECK-NEXT: lsll r0, r1, r2
|
|
; CHECK-NEXT: mov r0, r1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -44)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%sm = lshr i64 %shr, 32
|
|
%t = trunc i64 %sm to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
|
|
|
|
define i32 @ashr_demand_bottommask3(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottommask3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #3
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @lsll_demand_bottommask3(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottommask3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #3
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @ashr_demand_bottommaskm3(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottommaskm3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #3
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @lsll_demand_bottommaskm3(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottommaskm3:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #3
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -3)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
|
|
define i32 @ashr_demand_bottommask32(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottommask32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: asrl r0, r1, #32
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @lsll_demand_bottommask32(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottommask32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #32
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @ashr_demand_bottommaskm32(i64 %X) {
|
|
; CHECK-LABEL: ashr_demand_bottommaskm32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsll r0, r1, #32
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.asrl(i32 %2, i32 %1, i32 -32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @lsll_demand_bottommaskm32(i64 %X) {
|
|
; CHECK-LABEL: lsll_demand_bottommaskm32:
|
|
; CHECK: @ %bb.0: @ %entry
|
|
; CHECK-NEXT: lsrl r0, r1, #32
|
|
; CHECK-NEXT: bic r0, r0, #1
|
|
; CHECK-NEXT: bx lr
|
|
entry:
|
|
%0 = lshr i64 %X, 32
|
|
%1 = trunc i64 %0 to i32
|
|
%2 = trunc i64 %X to i32
|
|
%3 = call { i32, i32 } @llvm.arm.mve.lsll(i32 %2, i32 %1, i32 -32)
|
|
%4 = extractvalue { i32, i32 } %3, 1
|
|
%5 = zext i32 %4 to i64
|
|
%6 = shl nuw i64 %5, 32
|
|
%7 = extractvalue { i32, i32 } %3, 0
|
|
%8 = zext i32 %7 to i64
|
|
%shr = or i64 %6, %8
|
|
%t = trunc i64 %shr to i32
|
|
%a = and i32 %t, -2
|
|
ret i32 %a
|
|
}
|