blob: b3861c3098ceafe70a5bd8fcbde205efbfbaa241 [file] [log] [blame] [edit]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 5
# RUN: llc -mtriple=riscv32 -mattr=+zilsd -run-pass=greedy,virtregrewriter %s -o - | FileCheck --check-prefix=WITHOUT-HINT %s
# RUN: llc -mtriple=riscv32 -mattr=+zilsd,+zilsd-4byte-align -run-pass=riscv-prera-zilsd-opt,greedy,virtregrewriter %s -o - | FileCheck --check-prefix=WITH-HINT %s
--- |
define i32 @test_load_pair_hints(ptr %p) {
%v1 = load i32, ptr %p, align 4
%p2 = getelementptr inbounds i8, ptr %p, i32 4
%v2 = load i32, ptr %p2, align 4
%sum = add i32 %v1, %v2
ret i32 %sum
}
define void @test_store_pair_hints(ptr %p, i32 %a, i32 %b) {
store i32 %a, ptr %p, align 4
%p2 = getelementptr inbounds i8, ptr %p, i32 4
store i32 %b, ptr %p2, align 4
ret void
}
...
---
# Test that load pairs get register hints and allocate consecutive registers
# After register allocation, should either keep LD_RV32 or split back to LW
name: test_load_pair_hints
tracksRegLiveness: true
body: |
bb.0:
liveins: $x10
; WITHOUT-HINT-LABEL: name: test_load_pair_hints
; WITHOUT-HINT: liveins: $x10
; WITHOUT-HINT-NEXT: {{ $}}
; WITHOUT-HINT-NEXT: renamable $x11 = LW renamable $x10, 0 :: (load (s32) from %ir.p)
; WITHOUT-HINT-NEXT: renamable $x10 = LW killed renamable $x10, 4 :: (load (s32) from %ir.p2)
; WITHOUT-HINT-NEXT: renamable $x10 = ADD killed renamable $x11, killed renamable $x10
; WITHOUT-HINT-NEXT: PseudoRET implicit $x10
;
; WITH-HINT-LABEL: name: test_load_pair_hints
; WITH-HINT: liveins: $x10
; WITH-HINT-NEXT: {{ $}}
; WITH-HINT-NEXT: renamable $x10, renamable $x11 = PseudoLD_RV32_OPT killed renamable $x10, 0 :: (load (s32) from %ir.p), (load (s32) from %ir.p2)
; WITH-HINT-NEXT: renamable $x10 = ADD killed renamable $x10, killed renamable $x11
; WITH-HINT-NEXT: PseudoRET implicit $x10
%10:gpr = COPY $x10
; These two LW instructions at offset 0 and 4 should be combined
%0:gpr = LW %10, 0 :: (load (s32) from %ir.p)
%1:gpr = LW %10, 4 :: (load (s32) from %ir.p2)
%2:gpr = ADD %0, %1
$x10 = COPY %2
PseudoRET implicit $x10
...
---
# Test that store pairs get register hints and allocate consecutive registers
# After register allocation, should either keep SD_RV32 or split back to SW
name: test_store_pair_hints
tracksRegLiveness: true
body: |
bb.0:
liveins: $x10, $x11, $x12
; WITHOUT-HINT-LABEL: name: test_store_pair_hints
; WITHOUT-HINT: liveins: $x10, $x11, $x12
; WITHOUT-HINT-NEXT: {{ $}}
; WITHOUT-HINT-NEXT: SW killed renamable $x11, renamable $x10, 0 :: (store (s32) into %ir.p)
; WITHOUT-HINT-NEXT: SW killed renamable $x12, killed renamable $x10, 4 :: (store (s32) into %ir.p2)
; WITHOUT-HINT-NEXT: PseudoRET
;
; WITH-HINT-LABEL: name: test_store_pair_hints
; WITH-HINT: liveins: $x10, $x11, $x12
; WITH-HINT-NEXT: {{ $}}
; WITH-HINT-NEXT: renamable $x14 = COPY $x11
; WITH-HINT-NEXT: renamable $x15 = COPY $x12
; WITH-HINT-NEXT: PseudoSD_RV32_OPT killed renamable $x14, killed renamable $x15, killed renamable $x10, 0 :: (store (s32) into %ir.p), (store (s32) into %ir.p2)
; WITH-HINT-NEXT: PseudoRET
%10:gpr = COPY $x10
%11:gpr = COPY $x11
%12:gpr = COPY $x12
; These two SW instructions at offset 0 and 4 should be combined
SW %11, %10, 0 :: (store (s32) into %ir.p)
SW %12, %10, 4 :: (store (s32) into %ir.p2)
PseudoRET
...