blob: 688719b6cb43daefd2929fc8d6854ebe5800a00f [file] [edit]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 6
# RUN: llc -mtriple=riscv32 -mattr=+xqcilsm -run-pass=riscv-load-store-opt %s -o - | FileCheck %s
--- |
define void @lwmi() { ret void }
define void @lwmi_x0() { ret void }
define void @lwmi_nonconsecutive() { ret void }
define void @lwmi_misaligned() { ret void }
define void @swmi() { ret void }
define void @swmi_x0() { ret void }
define void @swmi_nonconsecutive() { ret void }
define void @swmi_misaligned() { ret void}
define void @setwmi(ptr %a, ptr %b, ptr %c, ptr %d) {
entry:
store i32 0, ptr %a, align 4
store i32 0, ptr %b, align 4
store i32 0, ptr %c, align 4
store i32 0, ptr %d, align 4
ret void
}
define void @setwmi_no_pair_move_insn_back() { ret void }
...
---
name: lwmi
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: lwmi
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: $x28 = QC_LWMI $x10, 4, 0, implicit-def $x29, implicit-def $x30, implicit-def $x31 :: (load (s32))
; CHECK-NEXT: $x10 = ADD $x28, $x29
; CHECK-NEXT: $x10 = ADD $x10, $x30
; CHECK-NEXT: $x10 = ADD $x10, $x31
; CHECK-NEXT: PseudoRET
$x28 = LW $x10, 0 :: (load (s32), align 4)
$x29 = LW $x10, 4 :: (load (s32), align 4)
$x30 = LW $x10, 8 :: (load (s32), align 4)
$x31 = LW $x10, 12 :: (load (s32), align 4)
$x10 = ADD $x28, $x29
$x10 = ADD $x10, $x30
$x10 = ADD $x10, $x31
PseudoRET
...
---
name: lwmi_x0
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: lwmi_x0
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: $x0 = LW $x10, 0 :: (load (s32))
; CHECK-NEXT: $x1 = QC_LWMI killed $x10, 3, 4, implicit-def $x2, implicit-def $x3 :: (load (s32))
; CHECK-NEXT: PseudoRET
$x0 = LW $x10, 0 :: (load (s32), align 4)
$x1 = LW $x10, 4 :: (load (s32), align 4)
$x2 = LW $x10, 8 :: (load (s32), align 4)
$x3 = LW killed $x10, 12 :: (load (s32), align 4)
PseudoRET
...
---
name: lwmi_nonconsecutive
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: lwmi_nonconsecutive
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: $x28 = LW $x10, 0 :: (load (s32))
; CHECK-NEXT: $x29 = LW $x10, 8 :: (load (s32))
; CHECK-NEXT: $x30 = LW $x10, 4 :: (load (s32))
; CHECK-NEXT: $x31 = LW $x10, 12 :: (load (s32))
; CHECK-NEXT: PseudoRET
$x28 = LW $x10, 0 :: (load (s32), align 4)
$x29 = LW $x10, 8 :: (load (s32), align 4)
$x30 = LW $x10, 4 :: (load (s32), align 4)
$x31 = LW $x10, 12 :: (load (s32), align 4)
PseudoRET
...
---
name: lwmi_misaligned
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: lwmi_misaligned
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: $x28 = LW $x10, 2 :: (load (s32))
; CHECK-NEXT: $x29 = LW $x10, 6 :: (load (s32))
; CHECK-NEXT: $x30 = LW $x10, 10 :: (load (s32))
; CHECK-NEXT: PseudoRET
$x28 = LW $x10, 2 :: (load (s32), align 4)
$x29 = LW $x10, 6 :: (load (s32), align 4)
$x30 = LW $x10, 10 :: (load (s32), align 4)
PseudoRET
...
---
name: swmi
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: swmi
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: QC_SWMI killed $x28, $x10, 4, 0, implicit killed $x29, implicit $x30, implicit killed $x31 :: (store (s32))
; CHECK-NEXT: PseudoRET
SW killed $x28, $x10, 0 :: (store (s32), align 4)
SW killed $x29, $x10, 4 :: (store (s32), align 4)
SW $x30, $x10, 8 :: (store (s32), align 4)
SW killed $x31, $x10, 12 :: (store (s32), align 4)
PseudoRET
...
---
name: swmi_x0
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: swmi_x0
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: SW $x0, $x10, 0 :: (store (s32))
; CHECK-NEXT: QC_SWMI $x1, $x10, 3, 4, implicit $x2, implicit $x3 :: (store (s32))
; CHECK-NEXT: PseudoRET
SW $x0, $x10, 0 :: (store (s32), align 4)
SW $x1, $x10, 4 :: (store (s32), align 4)
SW $x2, $x10, 8 :: (store (s32), align 4)
SW $x3, $x10, 12 :: (store (s32), align 4)
PseudoRET
...
---
name: swmi_nonconsecutive
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: swmi_nonconsecutive
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: QC_SWMI $x28, $x10, 2, 0, implicit killed $x29 :: (store (s32))
; CHECK-NEXT: $x11 = ADDI $x28, 1
; CHECK-NEXT: QC_SWMI $x30, $x10, 2, 8, implicit killed $x31 :: (store (s32))
; CHECK-NEXT: $x12 = ADDI $x30, 1
; CHECK-NEXT: PseudoRET
SW $x28, $x10, 0 :: (store (s32), align 4)
$x11 = ADDI $x28, 1
SW killed $x29, $x10, 4 :: (store (s32), align 4)
SW $x30, $x10, 8 :: (store (s32), align 4)
$x12 = ADDI $x30, 1
SW killed $x31, $x10, 12 :: (store (s32), align 4)
PseudoRET
...
---
name: swmi_misaligned
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: swmi_misaligned
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: SW $x0, $x10, 0 :: (store (s32))
; CHECK-NEXT: SW $x1, $x10, 4 :: (store (s32))
; CHECK-NEXT: SW $x2, $x10, 8 :: (store (s32), align 2)
; CHECK-NEXT: SW $x3, $x10, 12 :: (store (s32))
; CHECK-NEXT: PseudoRET
SW $x0, $x10, 0 :: (store (s32), align 4)
SW $x1, $x10, 4 :: (store (s32), align 4)
SW $x2, $x10, 8 :: (store (s32), align 2)
SW $x3, $x10, 12 :: (store (s32), align 4)
PseudoRET
...
---
name: setwmi
body: |
bb.0:
liveins: $x10
; CHECK-LABEL: name: setwmi
; CHECK: liveins: $x10
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: QC_SETWMI $x0, $x10, 4, 0 :: (store (s32) into %ir.a), (store (s32) into %ir.b), (store (s32) into %ir.c), (store (s32) into %ir.d)
; CHECK-NEXT: PseudoRET
SW $x0, $x10, 0 :: (store (s32) into %ir.a, align 4)
SW $x0, $x10, 4 :: (store (s32) into %ir.b, align 4)
SW $x0, $x10, 8 :: (store (s32) into %ir.c, align 4)
SW $x0, $x10, 12 :: (store (s32) into %ir.d, align 4)
PseudoRET
...
---
name: setwmi_no_pair_move_insn_back
body: |
bb.0:
liveins: $x1, $x2
; CHECK-LABEL: name: setwmi_no_pair_move_insn_back
; CHECK: liveins: $x1, $x2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: SW killed $x1, $x2, 12 :: (store (s32))
; CHECK-NEXT: QC_SETWMI $x0, $x2, 3, 0 :: (store (s32))
; CHECK-NEXT: PseudoRET
SW killed $x1, $x2, 12 :: (store (s32), align 4)
SW $x0, $x2, 0 :: (store (s32), align 4)
SW $x0, $x2, 4 :: (store (s32), align 4)
SW $x0, $x2, 8 :: (store (s32), align 4)
PseudoRET
...