|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| 2 | +; RUN: llc --mtriple=loongarch64 < %s | FileCheck %s |
| 3 | + |
| 4 | +%Box = type [6 x i64] |
| 5 | + |
| 6 | +define void @box(ptr noalias nocapture noundef writeonly sret(%Box) align 16 dereferenceable(48) %b, i64 %i) { |
| 7 | +; CHECK-LABEL: box: |
| 8 | +; CHECK: # %bb.0: |
| 9 | +; CHECK-NEXT: addi.d $sp, $sp, -96 |
| 10 | +; CHECK-NEXT: .cfi_def_cfa_offset 96 |
| 11 | +; CHECK-NEXT: slli.d $a2, $a1, 5 |
| 12 | +; CHECK-NEXT: alsl.d $a1, $a1, $a2, 4 |
| 13 | +; CHECK-NEXT: addi.d $a2, $sp, 0 |
| 14 | +; CHECK-NEXT: add.d $a3, $a2, $a1 |
| 15 | +; CHECK-NEXT: ldx.d $a1, $a1, $a2 |
| 16 | +; CHECK-NEXT: st.d $a1, $a0, 0 |
| 17 | +; CHECK-NEXT: ld.d $a1, $a3, 40 |
| 18 | +; CHECK-NEXT: st.d $a1, $a0, 40 |
| 19 | +; CHECK-NEXT: ld.d $a1, $a3, 32 |
| 20 | +; CHECK-NEXT: st.d $a1, $a0, 32 |
| 21 | +; CHECK-NEXT: ld.d $a1, $a3, 24 |
| 22 | +; CHECK-NEXT: st.d $a1, $a0, 24 |
| 23 | +; CHECK-NEXT: ld.d $a1, $a3, 16 |
| 24 | +; CHECK-NEXT: st.d $a1, $a0, 16 |
| 25 | +; CHECK-NEXT: ori $a1, $a3, 8 |
| 26 | +; CHECK-NEXT: ld.d $a1, $a1, 0 |
| 27 | +; CHECK-NEXT: st.d $a1, $a0, 8 |
| 28 | +; CHECK-NEXT: addi.d $sp, $sp, 96 |
| 29 | +; CHECK-NEXT: ret |
| 30 | + %1 = alloca [2 x %Box], align 16 |
| 31 | + %2 = getelementptr inbounds [2 x %Box], ptr %1, i64 0, i64 %i |
| 32 | + call void @llvm.memcpy.p0.p0.i64(ptr noundef nonnull align 16 dereferenceable(48) %b, ptr noundef nonnull align 16 dereferenceable(48) %2, i64 48, i1 false) |
| 33 | + ret void |
| 34 | +} |
0 commit comments