blob: 040bee5803026e6fa0f974aa8150a2974906db61 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc -mtriple=riscv32 -mattr=+zilsd < %s | FileCheck %s --check-prefixes=RV32ZILSD
; RUN: llc -mtriple=riscv32 -mattr=+zilsd,+zba < %s | FileCheck %s --check-prefixes=RV32ZILSDZBA
define i64 @test_sh3add_load(ptr %p, i32 %x, i32 %y) {
; RV32ZILSD-LABEL: test_sh3add_load:
; RV32ZILSD: # %bb.0: # %entry
; RV32ZILSD-NEXT: slli a1, a1, 3
; RV32ZILSD-NEXT: slli a2, a2, 3
; RV32ZILSD-NEXT: add a1, a1, a0
; RV32ZILSD-NEXT: add a0, a0, a2
; RV32ZILSD-NEXT: ld a2, 480(a1)
; RV32ZILSD-NEXT: ld a4, 400(a0)
; RV32ZILSD-NEXT: add a1, a5, a3
; RV32ZILSD-NEXT: add a0, a4, a2
; RV32ZILSD-NEXT: sltu a2, a0, a4
; RV32ZILSD-NEXT: add a1, a1, a2
; RV32ZILSD-NEXT: ret
;
; RV32ZILSDZBA-LABEL: test_sh3add_load:
; RV32ZILSDZBA: # %bb.0: # %entry
; RV32ZILSDZBA-NEXT: sh3add a1, a1, a0
; RV32ZILSDZBA-NEXT: sh3add a0, a2, a0
; RV32ZILSDZBA-NEXT: ld a2, 480(a1)
; RV32ZILSDZBA-NEXT: ld a4, 400(a0)
; RV32ZILSDZBA-NEXT: add a1, a5, a3
; RV32ZILSDZBA-NEXT: add a0, a4, a2
; RV32ZILSDZBA-NEXT: sltu a2, a0, a4
; RV32ZILSDZBA-NEXT: add a1, a1, a2
; RV32ZILSDZBA-NEXT: ret
entry:
%b = getelementptr inbounds nuw i8, ptr %p, i64 400
%add = add i32 %x, 10
%arrayidx = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i32 %add
%0 = load i64, ptr %arrayidx, align 8
%arrayidx2 = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i32 %y
%1 = load i64, ptr %arrayidx2, align 8
%add3 = add nsw i64 %1, %0
ret i64 %add3
}
define i64 @test_sh3add_load_minsize(ptr %p, i32 %x, i32 %y) minsize {
; RV32ZILSD-LABEL: test_sh3add_load_minsize:
; RV32ZILSD: # %bb.0: # %entry
; RV32ZILSD-NEXT: addi a0, a0, 400
; RV32ZILSD-NEXT: slli a1, a1, 3
; RV32ZILSD-NEXT: slli a2, a2, 3
; RV32ZILSD-NEXT: add a1, a1, a0
; RV32ZILSD-NEXT: add a0, a0, a2
; RV32ZILSD-NEXT: ld a2, 80(a1)
; RV32ZILSD-NEXT: ld a4, 0(a0)
; RV32ZILSD-NEXT: add a1, a5, a3
; RV32ZILSD-NEXT: add a0, a4, a2
; RV32ZILSD-NEXT: sltu a2, a0, a4
; RV32ZILSD-NEXT: add a1, a1, a2
; RV32ZILSD-NEXT: ret
;
; RV32ZILSDZBA-LABEL: test_sh3add_load_minsize:
; RV32ZILSDZBA: # %bb.0: # %entry
; RV32ZILSDZBA-NEXT: addi a0, a0, 400
; RV32ZILSDZBA-NEXT: sh3add a1, a1, a0
; RV32ZILSDZBA-NEXT: sh3add a0, a2, a0
; RV32ZILSDZBA-NEXT: ld a2, 80(a1)
; RV32ZILSDZBA-NEXT: ld a4, 0(a0)
; RV32ZILSDZBA-NEXT: add a1, a5, a3
; RV32ZILSDZBA-NEXT: add a0, a4, a2
; RV32ZILSDZBA-NEXT: sltu a2, a0, a4
; RV32ZILSDZBA-NEXT: add a1, a1, a2
; RV32ZILSDZBA-NEXT: ret
entry:
%b = getelementptr inbounds nuw i8, ptr %p, i64 400
%add = add i32 %x, 10
%arrayidx = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i32 %add
%0 = load i64, ptr %arrayidx, align 8
%arrayidx2 = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i32 %y
%1 = load i64, ptr %arrayidx2, align 8
%add3 = add nsw i64 %1, %0
ret i64 %add3
}
define void @test_sh3add_store(ptr %p, i64 %x, i64 %y) {
; RV32ZILSD-LABEL: test_sh3add_store:
; RV32ZILSD: # %bb.0: # %entry
; RV32ZILSD-NEXT: mv a5, a4
; RV32ZILSD-NEXT: mv a7, a2
; RV32ZILSD-NEXT: mv a4, a3
; RV32ZILSD-NEXT: mv a6, a1
; RV32ZILSD-NEXT: slli a1, a1, 3
; RV32ZILSD-NEXT: slli a2, a3, 3
; RV32ZILSD-NEXT: add a1, a0, a1
; RV32ZILSD-NEXT: add a0, a0, a2
; RV32ZILSD-NEXT: sd a6, 400(a1)
; RV32ZILSD-NEXT: sd a4, 400(a0)
; RV32ZILSD-NEXT: ret
;
; RV32ZILSDZBA-LABEL: test_sh3add_store:
; RV32ZILSDZBA: # %bb.0: # %entry
; RV32ZILSDZBA-NEXT: mv a5, a4
; RV32ZILSDZBA-NEXT: mv a7, a2
; RV32ZILSDZBA-NEXT: mv a4, a3
; RV32ZILSDZBA-NEXT: mv a6, a1
; RV32ZILSDZBA-NEXT: sh3add a1, a1, a0
; RV32ZILSDZBA-NEXT: sh3add a0, a3, a0
; RV32ZILSDZBA-NEXT: sd a6, 400(a1)
; RV32ZILSDZBA-NEXT: sd a4, 400(a0)
; RV32ZILSDZBA-NEXT: ret
entry:
%b = getelementptr inbounds nuw i8, ptr %p, i64 400
%arrayidx = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i64 %x
store i64 %x, ptr %arrayidx, align 8
%arrayidx2 = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i64 %y
store i64 %y , ptr %arrayidx2, align 8
ret void
}
define void @test_sh3add_store_optsize(ptr %p, i64 %x, i64 %y) optsize {
; RV32ZILSD-LABEL: test_sh3add_store_optsize:
; RV32ZILSD: # %bb.0: # %entry
; RV32ZILSD-NEXT: mv a5, a4
; RV32ZILSD-NEXT: mv a7, a2
; RV32ZILSD-NEXT: addi a0, a0, 400
; RV32ZILSD-NEXT: mv a4, a3
; RV32ZILSD-NEXT: mv a6, a1
; RV32ZILSD-NEXT: slli a1, a1, 3
; RV32ZILSD-NEXT: slli a2, a3, 3
; RV32ZILSD-NEXT: add a1, a0, a1
; RV32ZILSD-NEXT: add a0, a0, a2
; RV32ZILSD-NEXT: sd a6, 0(a1)
; RV32ZILSD-NEXT: sd a4, 0(a0)
; RV32ZILSD-NEXT: ret
;
; RV32ZILSDZBA-LABEL: test_sh3add_store_optsize:
; RV32ZILSDZBA: # %bb.0: # %entry
; RV32ZILSDZBA-NEXT: mv a5, a4
; RV32ZILSDZBA-NEXT: mv a7, a2
; RV32ZILSDZBA-NEXT: addi a0, a0, 400
; RV32ZILSDZBA-NEXT: mv a4, a3
; RV32ZILSDZBA-NEXT: mv a6, a1
; RV32ZILSDZBA-NEXT: sh3add a1, a1, a0
; RV32ZILSDZBA-NEXT: sh3add a0, a3, a0
; RV32ZILSDZBA-NEXT: sd a6, 0(a1)
; RV32ZILSDZBA-NEXT: sd a4, 0(a0)
; RV32ZILSDZBA-NEXT: ret
entry:
%b = getelementptr inbounds nuw i8, ptr %p, i64 400
%arrayidx = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i64 %x
store i64 %x, ptr %arrayidx, align 8
%arrayidx2 = getelementptr inbounds nuw [100 x i64], ptr %b, i64 0, i64 %y
store i64 %y , ptr %arrayidx2, align 8
ret void
}