2019-06-05 22:08:01 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
2019-08-26 02:25:22 +08:00
|
|
|
; RUN: llc -mtriple=hexagon < %s | FileCheck %s
|
2018-03-12 22:01:28 +08:00
|
|
|
|
|
|
|
; Function Attrs: nounwind readnone
|
|
|
|
define i32 @f0(i32 %a0, i32 %a1) #0 {
|
2019-06-05 22:08:01 +08:00
|
|
|
; CHECK-LABEL: f0:
|
|
|
|
; CHECK: // %bb.0: // %b0
|
|
|
|
; CHECK-NEXT: {
|
|
|
|
; CHECK-NEXT: p0 = tstbit(r0,r1)
|
|
|
|
; CHECK-NEXT: }
|
|
|
|
; CHECK-NEXT: {
|
|
|
|
; CHECK-NEXT: r0 = mux(p0,#1,#0)
|
|
|
|
; CHECK-NEXT: jumpr r31
|
|
|
|
; CHECK-NEXT: }
|
2018-03-12 22:01:28 +08:00
|
|
|
b0:
|
|
|
|
%v0 = shl i32 1, %a1
|
|
|
|
%v1 = and i32 %v0, %a0
|
|
|
|
%v2 = icmp ne i32 %v1, 0
|
|
|
|
%v3 = zext i1 %v2 to i32
|
|
|
|
ret i32 %v3
|
|
|
|
}
|
|
|
|
|
2019-08-26 02:34:07 +08:00
|
|
|
define i64 @is_upper_bit_clear_i64(i64 %x) #0 {
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-LABEL: is_upper_bit_clear_i64:
|
2019-08-26 02:34:07 +08:00
|
|
|
; CHECK: // %bb.0:
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: p0 = !tstbit(r1,#5)
|
|
|
|
; CHECK-NEXT: r1 = #0
|
2019-09-02 22:52:09 +08:00
|
|
|
; CHECK-NEXT: }
|
|
|
|
; CHECK-NEXT: {
|
|
|
|
; CHECK-NEXT: r0 = mux(p0,#1,#0)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: jumpr r31
|
|
|
|
; CHECK-NEXT: }
|
|
|
|
%sh = lshr i64 %x, 37
|
|
|
|
%m = and i64 %sh, 1
|
|
|
|
%r = xor i64 %m, 1
|
|
|
|
ret i64 %r
|
|
|
|
}
|
|
|
|
|
2019-08-26 02:34:07 +08:00
|
|
|
define i64 @is_lower_bit_clear_i64(i64 %x) #0 {
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-LABEL: is_lower_bit_clear_i64:
|
2019-08-26 02:34:07 +08:00
|
|
|
; CHECK: // %bb.0:
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: p0 = !tstbit(r0,#27)
|
2019-08-27 03:08:08 +08:00
|
|
|
; CHECK-NEXT: r1 = #0
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: }
|
|
|
|
; CHECK-NEXT: {
|
2019-09-02 22:52:09 +08:00
|
|
|
; CHECK-NEXT: r0 = mux(p0,#1,#0)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: jumpr r31
|
|
|
|
; CHECK-NEXT: }
|
|
|
|
%sh = lshr i64 %x, 27
|
|
|
|
%m = and i64 %sh, 1
|
|
|
|
%r = xor i64 %m, 1
|
|
|
|
ret i64 %r
|
|
|
|
}
|
|
|
|
|
2019-08-26 02:34:07 +08:00
|
|
|
define i32 @is_bit_clear_i32(i32 %x) #0 {
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-LABEL: is_bit_clear_i32:
|
2019-08-26 02:34:07 +08:00
|
|
|
; CHECK: // %bb.0:
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: p0 = !tstbit(r0,#27)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: }
|
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: r0 = mux(p0,#1,#0)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: jumpr r31
|
|
|
|
; CHECK-NEXT: }
|
|
|
|
%sh = lshr i32 %x, 27
|
|
|
|
%n = xor i32 %sh, -1
|
|
|
|
%r = and i32 %n, 1
|
|
|
|
ret i32 %r
|
|
|
|
}
|
|
|
|
|
2019-08-26 02:34:07 +08:00
|
|
|
define i16 @is_bit_clear_i16(i16 %x) #0 {
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-LABEL: is_bit_clear_i16:
|
2019-08-26 02:34:07 +08:00
|
|
|
; CHECK: // %bb.0:
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: p0 = !tstbit(r0,#7)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: }
|
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: r0 = mux(p0,#1,#0)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: jumpr r31
|
|
|
|
; CHECK-NEXT: }
|
|
|
|
%sh = lshr i16 %x, 7
|
|
|
|
%m = and i16 %sh, 1
|
|
|
|
%r = xor i16 %m, 1
|
|
|
|
ret i16 %r
|
|
|
|
}
|
|
|
|
|
2019-08-26 02:34:07 +08:00
|
|
|
define i8 @is_bit_clear_i8(i8 %x) #0 {
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-LABEL: is_bit_clear_i8:
|
2019-08-26 02:34:07 +08:00
|
|
|
; CHECK: // %bb.0:
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: p0 = !tstbit(r0,#3)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: }
|
|
|
|
; CHECK-NEXT: {
|
2019-09-04 23:22:36 +08:00
|
|
|
; CHECK-NEXT: r0 = mux(p0,#1,#0)
|
2019-08-26 02:25:22 +08:00
|
|
|
; CHECK-NEXT: jumpr r31
|
|
|
|
; CHECK-NEXT: }
|
|
|
|
%sh = lshr i8 %x, 3
|
|
|
|
%m = and i8 %sh, 1
|
|
|
|
%r = xor i8 %m, 1
|
|
|
|
ret i8 %r
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-03-12 22:01:28 +08:00
|
|
|
attributes #0 = { nounwind readnone }
|