llvm/llvm/test/CodeGen/ARM/simplifysetcc_narrow_load.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
; RUN: llc -O1 -mtriple arm -o - %s | FileCheck --check-prefix CHECK-LE %s
; RUN: llc -O1 -mtriple armv7 -o - %s | FileCheck --check-prefix CHECK-V7-LE %s
; RUN: llc -O1 -mtriple armeb -o - %s | FileCheck --check-prefix CHECK-BE %s
; RUN: llc -O1 -mtriple armv7eb -o - %s | FileCheck --check-prefix CHECK-V7-BE %s

; A collection of regression tests to verify the load-narrowing part of
; TargetLowering::SimplifySetCC (and/or other similar rewrites such as
; combining AND+LOAD into ZEXTLOAD).
;
; Using both arm and armv7 to show that alignment restrictions are
; considered for the narrowed load (armv7 is a bit more relaxed when it
; comes to unaligned memory accesses).

;--------------------------------------------------------------------------
; Test non byte-sized types.
;
; As long as LLVM IR isn't defining where the padding goes we can't really
; optimize these (without adding a target lowering hook that can inform
; ISel about which bits are padding).
; --------------------------------------------------------------------------

define i1 @test_129_15_0(ptr %y) {
; CHECK-LE-LABEL: test_129_15_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0]
; CHECK-LE-NEXT:    mov r1, #255
; CHECK-LE-NEXT:    orr r1, r1, #32512
; CHECK-LE-NEXT:    ands r0, r0, r1
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_129_15_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0]
; CHECK-V7-LE-NEXT:    bfc r0, #15, #17
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_129_15_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldr r1, [r0, #12]
; CHECK-BE-NEXT:    ldrb r0, [r0, #16]
; CHECK-BE-NEXT:    orr r0, r0, r1, lsl #8
; CHECK-BE-NEXT:    mov r1, #255
; CHECK-BE-NEXT:    orr r1, r1, #32512
; CHECK-BE-NEXT:    ands r0, r0, r1
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_129_15_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0, #15]
; CHECK-V7-BE-NEXT:    bfc r0, #15, #17
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i129, ptr %y
  %b = and i129 %a, u0x7fff
  %cmp = icmp ne i129 %b, 0
  ret i1 %cmp
}

define i1 @test_126_20_4(ptr %y) {
; CHECK-LE-LABEL: test_126_20_4:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldr r0, [r0]
; CHECK-LE-NEXT:    mvn r1, #15
; CHECK-LE-NEXT:    sub r1, r1, #-16777216
; CHECK-LE-NEXT:    ands r0, r0, r1
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_126_20_4:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldr r0, [r0]
; CHECK-V7-LE-NEXT:    movw r1, #65520
; CHECK-V7-LE-NEXT:    movt r1, #255
; CHECK-V7-LE-NEXT:    ands r0, r0, r1
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_126_20_4:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldr r0, [r0, #12]
; CHECK-BE-NEXT:    mvn r1, #15
; CHECK-BE-NEXT:    sub r1, r1, #-16777216
; CHECK-BE-NEXT:    ands r0, r0, r1
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_126_20_4:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldr r0, [r0, #12]
; CHECK-V7-BE-NEXT:    movw r1, #65520
; CHECK-V7-BE-NEXT:    movt r1, #255
; CHECK-V7-BE-NEXT:    ands r0, r0, r1
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i126, ptr %y
  %b = and i126 %a, u0xfffff0
  %cmp = icmp ne i126 %b, 0
  ret i1 %cmp
}

define i1 @test_33_8_0(ptr %y) {
; CHECK-LE-LABEL: test_33_8_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0]
; CHECK-LE-NEXT:    cmp r0, #0
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_33_8_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_33_8_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrb r0, [r0, #4]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_33_8_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrb r0, [r0, #4]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i33, ptr %y
  %b = and i33 %a, u0xff
  %cmp = icmp ne i33 %b, 0
  ret i1 %cmp
}

define i1 @test_33_1_32(ptr %y) {
; CHECK-LE-LABEL: test_33_1_32:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0, #4]
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_33_1_32:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0, #4]
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_33_1_32:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldr r0, [r0]
; CHECK-BE-NEXT:    lsr r0, r0, #24
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_33_1_32:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldr r0, [r0]
; CHECK-V7-BE-NEXT:    lsr r0, r0, #24
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i33, ptr %y
  %b = and i33 %a, u0x100000000
  %cmp = icmp ne i33 %b, 0
  ret i1 %cmp
}

define i1 @test_33_1_31(ptr %y) {
; CHECK-LE-LABEL: test_33_1_31:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0, #3]
; CHECK-LE-NEXT:    lsr r0, r0, #7
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_33_1_31:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0, #3]
; CHECK-V7-LE-NEXT:    lsr r0, r0, #7
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_33_1_31:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrb r0, [r0, #1]
; CHECK-BE-NEXT:    lsr r0, r0, #7
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_33_1_31:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrb r0, [r0, #1]
; CHECK-V7-BE-NEXT:    lsr r0, r0, #7
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i33, ptr %y
  %b = and i33 %a, u0x80000000
  %cmp = icmp ne i33 %b, 0
  ret i1 %cmp
}

define i1 @test_33_1_0(ptr %y) {
; CHECK-LE-LABEL: test_33_1_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0]
; CHECK-LE-NEXT:    and r0, r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_33_1_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0]
; CHECK-V7-LE-NEXT:    and r0, r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_33_1_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrb r0, [r0, #4]
; CHECK-BE-NEXT:    and r0, r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_33_1_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrb r0, [r0, #4]
; CHECK-V7-BE-NEXT:    and r0, r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i33, ptr %y
  %b = and i33 %a, u0x1
  %cmp = icmp ne i33 %b, 0
  ret i1 %cmp
}

;--------------------------------------------------------------------------
; Test byte-sized types.
;--------------------------------------------------------------------------


define i1 @test_128_20_4(ptr %y) {
; CHECK-LE-LABEL: test_128_20_4:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldr r0, [r0]
; CHECK-LE-NEXT:    mvn r1, #15
; CHECK-LE-NEXT:    sub r1, r1, #-16777216
; CHECK-LE-NEXT:    ands r0, r0, r1
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_128_20_4:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldr r0, [r0]
; CHECK-V7-LE-NEXT:    movw r1, #65520
; CHECK-V7-LE-NEXT:    movt r1, #255
; CHECK-V7-LE-NEXT:    ands r0, r0, r1
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_128_20_4:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldr r0, [r0, #12]
; CHECK-BE-NEXT:    mvn r1, #15
; CHECK-BE-NEXT:    sub r1, r1, #-16777216
; CHECK-BE-NEXT:    ands r0, r0, r1
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_128_20_4:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldr r0, [r0, #12]
; CHECK-V7-BE-NEXT:    movw r1, #65520
; CHECK-V7-BE-NEXT:    movt r1, #255
; CHECK-V7-BE-NEXT:    ands r0, r0, r1
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i128, ptr %y
  %b = and i128 %a, u0xfffff0
  %cmp = icmp ne i128 %b, 0
  ret i1 %cmp
}

define i1 @test_48_16_0(ptr %y) {
; CHECK-LE-LABEL: test_48_16_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0]
; CHECK-LE-NEXT:    cmp r0, #0
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_48_16_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_48_16_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0, #4]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_48_16_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0, #4]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i48, ptr %y
  %b = and i48 %a, u0xffff
  %cmp = icmp ne i48 %b, 0
  ret i1 %cmp
}

define i1 @test_48_16_8(ptr %y) {
; CHECK-LE-LABEL: test_48_16_8:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0, #1]
; CHECK-LE-NEXT:    lsls r0, r0, #8
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_48_16_8:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0, #1]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_48_16_8:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0, #3]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_48_16_8:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0, #3]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i48, ptr %y
  %b = and i48 %a, u0xffff00
  %cmp = icmp ne i48 %b, 0
  ret i1 %cmp
}

define i1 @test_48_16_16(ptr %y) {
; CHECK-LE-LABEL: test_48_16_16:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0, #2]
; CHECK-LE-NEXT:    cmp r0, #0
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_48_16_16:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0, #2]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_48_16_16:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0, #2]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_48_16_16:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0, #2]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i48, ptr %y
  %b = and i48 %a, u0xffff0000
  %cmp = icmp ne i48 %b, 0
  ret i1 %cmp
}

define i1 @test_48_16_32(ptr %y) {
; CHECK-LE-LABEL: test_48_16_32:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0, #4]
; CHECK-LE-NEXT:    cmp r0, #0
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_48_16_32:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0, #4]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_48_16_32:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_48_16_32:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i48, ptr %y
  %b = and i48 %a, u0xffff00000000
  %cmp = icmp ne i48 %b, 0
  ret i1 %cmp
}

define i1 @test_48_17_0(ptr %y) {
; CHECK-LE-LABEL: test_48_17_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldr r0, [r0]
; CHECK-LE-NEXT:    ldr r1, .LCPI11_0
; CHECK-LE-NEXT:    ands r0, r0, r1
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
; CHECK-LE-NEXT:    .p2align 2
; CHECK-LE-NEXT:  @ %bb.1:
; CHECK-LE-NEXT:  .LCPI11_0:
; CHECK-LE-NEXT:    .long 131071 @ 0x1ffff
;
; CHECK-V7-LE-LABEL: test_48_17_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldr r0, [r0]
; CHECK-V7-LE-NEXT:    bfc r0, #17, #15
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_48_17_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldr r1, [r0]
; CHECK-BE-NEXT:    ldrh r0, [r0, #4]
; CHECK-BE-NEXT:    orr r0, r0, r1, lsl #16
; CHECK-BE-NEXT:    ldr r1, .LCPI11_0
; CHECK-BE-NEXT:    ands r0, r0, r1
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
; CHECK-BE-NEXT:    .p2align 2
; CHECK-BE-NEXT:  @ %bb.1:
; CHECK-BE-NEXT:  .LCPI11_0:
; CHECK-BE-NEXT:    .long 131071 @ 0x1ffff
;
; CHECK-V7-BE-LABEL: test_48_17_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldr r0, [r0, #2]
; CHECK-V7-BE-NEXT:    bfc r0, #17, #15
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i48, ptr %y
  %b = and i48 %a, u0x1ffff
  %cmp = icmp ne i48 %b, 0
  ret i1 %cmp
}

define i1 @test_40_16_0(ptr %y) {
; CHECK-LE-LABEL: test_40_16_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0]
; CHECK-LE-NEXT:    cmp r0, #0
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_40_16_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_40_16_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0, #3]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_40_16_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0, #3]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i40, ptr %y
  %b = and i40 %a, u0xffff
  %cmp = icmp ne i40 %b, 0
  ret i1 %cmp
}

define i1 @test_40_1_32(ptr %y) {
; CHECK-LE-LABEL: test_40_1_32:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0, #4]
; CHECK-LE-NEXT:    and r0, r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_40_1_32:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0, #4]
; CHECK-V7-LE-NEXT:    and r0, r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_40_1_32:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrb r0, [r0]
; CHECK-BE-NEXT:    and r0, r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_40_1_32:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrb r0, [r0]
; CHECK-V7-BE-NEXT:    and r0, r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i40, ptr %y
  %b = and i40 %a, u0x100000000
  %cmp = icmp ne i40 %b, 0
  ret i1 %cmp
}

define i1 @test_24_16_0(ptr %y) {
; CHECK-LE-LABEL: test_24_16_0:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrh r0, [r0]
; CHECK-LE-NEXT:    cmp r0, #0
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_24_16_0:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrh r0, [r0]
; CHECK-V7-LE-NEXT:    cmp r0, #0
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_24_16_0:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0, #1]
; CHECK-BE-NEXT:    cmp r0, #0
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_24_16_0:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0, #1]
; CHECK-V7-BE-NEXT:    cmp r0, #0
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i24, ptr %y
  %b = and i24 %a, u0xffff
  %cmp = icmp ne i24 %b, 0
  ret i1 %cmp
}

define i1 @test_24_8_8(ptr %y) {
; CHECK-LE-LABEL: test_24_8_8:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0, #1]
; CHECK-LE-NEXT:    lsls r0, r0, #8
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_24_8_8:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0, #1]
; CHECK-V7-LE-NEXT:    lsls r0, r0, #8
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_24_8_8:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrb r0, [r0, #1]
; CHECK-BE-NEXT:    lsls r0, r0, #8
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_24_8_8:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrb r0, [r0, #1]
; CHECK-V7-BE-NEXT:    lsls r0, r0, #8
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i24, ptr %y
  %b = and i24 %a, u0xff00
  %cmp = icmp ne i24 %b, 0
  ret i1 %cmp
}

define i1 @test_24_8_12(ptr %y) {
; CHECK-LE-LABEL: test_24_8_12:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r1, [r0, #2]
; CHECK-LE-NEXT:    ldrh r0, [r0]
; CHECK-LE-NEXT:    orr r0, r0, r1, lsl #16
; CHECK-LE-NEXT:    ands r0, r0, #1044480
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_24_8_12:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r1, [r0, #2]
; CHECK-V7-LE-NEXT:    ldrh r0, [r0]
; CHECK-V7-LE-NEXT:    orr r0, r0, r1, lsl #16
; CHECK-V7-LE-NEXT:    ands r0, r0, #1044480
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_24_8_12:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrh r0, [r0]
; CHECK-BE-NEXT:    mov r1, #1044480
; CHECK-BE-NEXT:    ands r0, r1, r0, lsl #8
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_24_8_12:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrh r0, [r0]
; CHECK-V7-BE-NEXT:    mov r1, #1044480
; CHECK-V7-BE-NEXT:    ands r0, r1, r0, lsl #8
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i24, ptr %y
  %b = and i24 %a, u0xff000
  %cmp = icmp ne i24 %b, 0
  ret i1 %cmp
}

define i1 @test_24_8_16(ptr %y) {
; CHECK-LE-LABEL: test_24_8_16:
; CHECK-LE:       @ %bb.0:
; CHECK-LE-NEXT:    ldrb r0, [r0, #2]
; CHECK-LE-NEXT:    lsls r0, r0, #16
; CHECK-LE-NEXT:    movne r0, #1
; CHECK-LE-NEXT:    mov pc, lr
;
; CHECK-V7-LE-LABEL: test_24_8_16:
; CHECK-V7-LE:       @ %bb.0:
; CHECK-V7-LE-NEXT:    ldrb r0, [r0, #2]
; CHECK-V7-LE-NEXT:    lsls r0, r0, #16
; CHECK-V7-LE-NEXT:    movwne r0, #1
; CHECK-V7-LE-NEXT:    bx lr
;
; CHECK-BE-LABEL: test_24_8_16:
; CHECK-BE:       @ %bb.0:
; CHECK-BE-NEXT:    ldrb r0, [r0]
; CHECK-BE-NEXT:    lsls r0, r0, #16
; CHECK-BE-NEXT:    movne r0, #1
; CHECK-BE-NEXT:    mov pc, lr
;
; CHECK-V7-BE-LABEL: test_24_8_16:
; CHECK-V7-BE:       @ %bb.0:
; CHECK-V7-BE-NEXT:    ldrb r0, [r0]
; CHECK-V7-BE-NEXT:    lsls r0, r0, #16
; CHECK-V7-BE-NEXT:    movwne r0, #1
; CHECK-V7-BE-NEXT:    bx lr
  %a = load i24, ptr %y
  %b = and i24 %a, u0xff0000
  %cmp = icmp ne i24 %b, 0
  ret i1 %cmp
}