blob: 741e4ce40c5445f464a7d9bfeabb55b1ef2cfb6d [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc < %s -verify-machineinstrs -mtriple=riscv32 -mattr=+xqcilo | FileCheck %s --check-prefixes=RV32I
; RUN: llc < %s -verify-machineinstrs -mtriple=riscv32 -mattr=+xqcilo,+short-forward-branch-ialu | \
; RUN: FileCheck %s --check-prefixes=RV32I-SFB
; RUN: llc < %s -verify-machineinstrs -mtriple=riscv32 -mattr=+xqcilo,+short-forward-branch-iload | \
; RUN: FileCheck %s --check-prefixes=RV32I-SFBILOAD
define i32 @test_i8_s(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i8_s:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: beqz a1, .LBB0_2
; RV32I-NEXT: # %bb.1:
; RV32I-NEXT: qc.e.lb a2, 10000(a0)
; RV32I-NEXT: .LBB0_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_s:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB0_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB0_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_s:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB0_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lb a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB0_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = sext i8 %val to i32 ; sign-extend to 32 bits
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i8_z(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i8_z:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: beqz a1, .LBB1_2
; RV32I-NEXT: # %bb.1:
; RV32I-NEXT: qc.e.lbu a2, 10000(a0)
; RV32I-NEXT: .LBB1_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_z:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB1_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB1_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_z:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB1_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lbu a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB1_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = zext i8 %val to i32 ; zero-extend to 32 bits
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i16_s(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i16_s:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: beqz a1, .LBB2_2
; RV32I-NEXT: # %bb.1:
; RV32I-NEXT: qc.e.lh a2, 20000(a0)
; RV32I-NEXT: .LBB2_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_s:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB2_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB2_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_s:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB2_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lh a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB2_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = sext i16 %val to i32 ; sign-extend to 32 bits
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i16_z(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i16_z:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: beqz a1, .LBB3_2
; RV32I-NEXT: # %bb.1:
; RV32I-NEXT: qc.e.lhu a2, 20000(a0)
; RV32I-NEXT: .LBB3_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_z:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB3_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB3_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_z:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB3_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lhu a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB3_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = zext i16 %val to i32 ; zero-extend to 32 bits
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i32(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i32:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: beqz a1, .LBB4_2
; RV32I-NEXT: # %bb.1:
; RV32I-NEXT: qc.e.lw a2, 40000(a0)
; RV32I-NEXT: .LBB4_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i32:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB4_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB4_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i32:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB4_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lw a2, 40000(a0)
; RV32I-SFBILOAD-NEXT: .LBB4_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i32, ptr %base, i32 10000 ; compute base + 10000
%val = load i32, ptr %addr ; load 32-bit value
%res = select i1 %x, i32 %val, i32 %b
ret i32 %res
}
define i32 @test_i8_s_store(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i8_s_store:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB5_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: .LBB5_2: # %entry
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_s_store:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB5_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB5_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_s_store:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB5_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB5_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = sext i8 %val to i32 ; sign-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i8_z_store(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i8_z_store:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB6_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: .LBB6_2: # %entry
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_z_store:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB6_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB6_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_z_store:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB6_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB6_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = zext i8 %val to i32 ; zero-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i16_s_store(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i16_s_store:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB7_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: .LBB7_2: # %entry
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_s_store:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB7_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB7_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_s_store:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB7_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB7_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = sext i16 %val to i32 ; sign-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i16_z_store(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i16_z_store:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB8_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: .LBB8_2: # %entry
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_z_store:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB8_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB8_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_z_store:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB8_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB8_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = zext i16 %val to i32 ; zero-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
ret i32 %res
}
define i32 @test_i32_store(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i32_store:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB9_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: .LBB9_2: # %entry
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i32_store:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFB-NEXT: bnez a1, .LBB9_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB9_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i32_store:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB9_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB9_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i32, ptr %base, i32 10000 ; compute base + 10000
%val = load i32, ptr %addr ; load 32-bit value
store i32 %c, ptr %base1
%res = select i1 %x, i32 %val, i32 %b
ret i32 %res
}
define i32 @test_i8_s_volatile(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i8_s_volatile:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lb a4, 10000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB10_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a4, a2
; RV32I-NEXT: .LBB10_2: # %entry
; RV32I-NEXT: add a0, a0, a4
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_s_volatile:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: bnez a1, .LBB10_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB10_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_s_volatile:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB10_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lb a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB10_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = sext i8 %val to i32 ; sign-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i8_z_volatile(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i8_z_volatile:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lbu a4, 10000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB11_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a4, a2
; RV32I-NEXT: .LBB11_2: # %entry
; RV32I-NEXT: add a0, a0, a4
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_z_volatile:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: bnez a1, .LBB11_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB11_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_z_volatile:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB11_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lbu a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB11_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = zext i8 %val to i32 ; zero-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i16_s_volatile(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i16_s_volatile:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lh a4, 20000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB12_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a4, a2
; RV32I-NEXT: .LBB12_2: # %entry
; RV32I-NEXT: add a0, a0, a4
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_s_volatile:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: bnez a1, .LBB12_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB12_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_s_volatile:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB12_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lh a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB12_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = sext i16 %val to i32 ; sign-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i16_z_volatile(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i16_z_volatile:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lhu a4, 20000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB13_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a4, a2
; RV32I-NEXT: .LBB13_2: # %entry
; RV32I-NEXT: add a0, a0, a4
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_z_volatile:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: bnez a1, .LBB13_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB13_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_z_volatile:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB13_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lhu a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB13_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = zext i16 %val to i32 ; zero-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %ext, i32 %b
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i32_volatile(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i32_volatile:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lw a4, 40000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB14_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a4, a2
; RV32I-NEXT: .LBB14_2: # %entry
; RV32I-NEXT: add a0, a0, a4
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i32_volatile:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: bnez a1, .LBB14_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB14_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i32_volatile:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB14_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lw a2, 40000(a0)
; RV32I-SFBILOAD-NEXT: .LBB14_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i32, ptr %base, i32 10000 ; compute base + 10000
%val = load i32, ptr %addr ; load 32-bit value
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %val, i32 %b
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i8_s_op(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i8_s_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: bnez a1, .LBB15_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: qc.e.lb a2, 10000(a0)
; RV32I-NEXT: .LBB15_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_s_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB15_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB15_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_s_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB15_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lb a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB15_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = sext i8 %val to i32 ; sign-extend to 32 bits
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i8_z_op(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i8_z_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: bnez a1, .LBB16_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: qc.e.lbu a2, 10000(a0)
; RV32I-NEXT: .LBB16_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_z_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB16_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB16_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_z_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB16_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lbu a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB16_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = zext i8 %val to i32 ; zero-extend to 32 bits
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i16_s_op(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i16_s_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: bnez a1, .LBB17_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: qc.e.lh a2, 20000(a0)
; RV32I-NEXT: .LBB17_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_s_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB17_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB17_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_s_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB17_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lh a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB17_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = sext i16 %val to i32 ; sign-extend to 32 bits
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i16_z_op(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i16_z_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: bnez a1, .LBB18_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: qc.e.lhu a2, 20000(a0)
; RV32I-NEXT: .LBB18_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_z_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB18_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB18_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_z_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB18_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lhu a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB18_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = zext i16 %val to i32 ; zero-extend to 32 bits
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i32_op(ptr %base, i1 zeroext %x, i32 %b) nounwind {
; RV32I-LABEL: test_i32_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: bnez a1, .LBB19_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: qc.e.lw a2, 40000(a0)
; RV32I-NEXT: .LBB19_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i32_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB19_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB19_2: # %entry
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i32_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB19_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lw a2, 40000(a0)
; RV32I-SFBILOAD-NEXT: .LBB19_2: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i32, ptr %base, i32 10000 ; compute base + 10000
%val = load i32, ptr %addr ; load 32-bit value
%res = select i1 %x, i32 %b, i32 %val
ret i32 %res
}
define i32 @test_i8_s_store_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i8_s_store_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB20_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a0
; RV32I-NEXT: .LBB20_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_s_store_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB20_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB20_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_s_store_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB20_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB20_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = sext i8 %val to i32 ; sign-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i8_z_store_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i8_z_store_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB21_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a0
; RV32I-NEXT: .LBB21_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_z_store_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB21_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB21_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_z_store_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB21_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB21_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = zext i8 %val to i32 ; zero-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i16_s_store_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i16_s_store_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB22_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a0
; RV32I-NEXT: .LBB22_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_s_store_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB22_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB22_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_s_store_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB22_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB22_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = sext i16 %val to i32 ; sign-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i16_z_store_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i16_z_store_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB23_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a0
; RV32I-NEXT: .LBB23_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_z_store_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB23_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB23_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_z_store_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB23_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB23_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = zext i16 %val to i32 ; zero-extend to 32 bits
store i32 %c, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
ret i32 %res
}
define i32 @test_i32_store_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1, i32 %c) nounwind {
; RV32I-LABEL: test_i32_store_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-NEXT: sw a4, 0(a3)
; RV32I-NEXT: bnez a1, .LBB24_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a0
; RV32I-NEXT: .LBB24_2: # %entry
; RV32I-NEXT: mv a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i32_store_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFB-NEXT: beqz a1, .LBB24_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB24_2: # %entry
; RV32I-SFB-NEXT: sw a4, 0(a3)
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i32_store_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFBILOAD-NEXT: beqz a1, .LBB24_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: mv a0, a2
; RV32I-SFBILOAD-NEXT: .LBB24_2: # %entry
; RV32I-SFBILOAD-NEXT: sw a4, 0(a3)
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i32, ptr %base, i32 10000 ; compute base + 10000
%val = load i32, ptr %addr ; load 32-bit value
store i32 %c, ptr %base1
%res = select i1 %x, i32 %b, i32 %val
ret i32 %res
}
define i32 @test_i8_s_volatile_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i8_s_volatile_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lb a4, 10000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB25_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a4
; RV32I-NEXT: .LBB25_2: # %entry
; RV32I-NEXT: add a0, a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_s_volatile_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lb a0, 10000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: beqz a1, .LBB25_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB25_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_s_volatile_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB25_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lb a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB25_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = sext i8 %val to i32 ; sign-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i8_z_volatile_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i8_z_volatile_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lbu a4, 10000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB26_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a4
; RV32I-NEXT: .LBB26_2: # %entry
; RV32I-NEXT: add a0, a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i8_z_volatile_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lbu a0, 10000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: beqz a1, .LBB26_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB26_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i8_z_volatile_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB26_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lbu a2, 10000(a0)
; RV32I-SFBILOAD-NEXT: .LBB26_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i8, ptr %base, i32 10000 ; compute base + 10000
%val = load i8, ptr %addr ; load 8-bit value
%ext = zext i8 %val to i32 ; zero-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i16_s_volatile_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i16_s_volatile_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lh a4, 20000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB27_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a4
; RV32I-NEXT: .LBB27_2: # %entry
; RV32I-NEXT: add a0, a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_s_volatile_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lh a0, 20000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: beqz a1, .LBB27_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB27_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_s_volatile_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB27_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lh a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB27_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = sext i16 %val to i32 ; sign-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i16_z_volatile_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i16_z_volatile_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lhu a4, 20000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB28_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a4
; RV32I-NEXT: .LBB28_2: # %entry
; RV32I-NEXT: add a0, a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i16_z_volatile_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lhu a0, 20000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: beqz a1, .LBB28_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB28_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i16_z_volatile_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB28_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lhu a2, 20000(a0)
; RV32I-SFBILOAD-NEXT: .LBB28_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i16, ptr %base, i32 10000 ; compute base + 10000
%val = load i16, ptr %addr ; load 16-bit value
%ext = zext i16 %val to i32 ; zero-extend to 32 bits
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %b, i32 %ext
%res1 = add i32 %res, %val1
ret i32 %res1
}
define i32 @test_i32_volatile_op(ptr %base, i1 zeroext %x, i32 %b, ptr %base1) nounwind {
; RV32I-LABEL: test_i32_volatile_op:
; RV32I: # %bb.0: # %entry
; RV32I-NEXT: qc.e.lw a4, 40000(a0)
; RV32I-NEXT: lw a0, 0(a3)
; RV32I-NEXT: bnez a1, .LBB29_2
; RV32I-NEXT: # %bb.1: # %entry
; RV32I-NEXT: mv a2, a4
; RV32I-NEXT: .LBB29_2: # %entry
; RV32I-NEXT: add a0, a0, a2
; RV32I-NEXT: ret
;
; RV32I-SFB-LABEL: test_i32_volatile_op:
; RV32I-SFB: # %bb.0: # %entry
; RV32I-SFB-NEXT: qc.e.lw a0, 40000(a0)
; RV32I-SFB-NEXT: lw a3, 0(a3)
; RV32I-SFB-NEXT: beqz a1, .LBB29_2
; RV32I-SFB-NEXT: # %bb.1: # %entry
; RV32I-SFB-NEXT: mv a0, a2
; RV32I-SFB-NEXT: .LBB29_2: # %entry
; RV32I-SFB-NEXT: add a0, a0, a3
; RV32I-SFB-NEXT: ret
;
; RV32I-SFBILOAD-LABEL: test_i32_volatile_op:
; RV32I-SFBILOAD: # %bb.0: # %entry
; RV32I-SFBILOAD-NEXT: lw a3, 0(a3)
; RV32I-SFBILOAD-NEXT: bnez a1, .LBB29_2
; RV32I-SFBILOAD-NEXT: # %bb.1: # %entry
; RV32I-SFBILOAD-NEXT: qc.e.lw a2, 40000(a0)
; RV32I-SFBILOAD-NEXT: .LBB29_2: # %entry
; RV32I-SFBILOAD-NEXT: add a0, a2, a3
; RV32I-SFBILOAD-NEXT: ret
entry:
%addr = getelementptr i32, ptr %base, i32 10000 ; compute base + 10000
%val = load i32, ptr %addr ; load 32-bit value
%val1 = load volatile i32, ptr %base1
%res = select i1 %x, i32 %b, i32 %val
%res1 = add i32 %res, %val1
ret i32 %res1
}