|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| 2 | +; RUN: llc -mtriple=powerpc64-- -verify-machineinstrs \ |
| 3 | +; RUN: -ppc-asm-full-reg-names < %s | FileCheck %s |
| 4 | +%struct.e.0.1.2.3.12.29 = type { [10 x i32] } |
| 5 | + |
| 6 | +define dso_local void @g(%struct.e.0.1.2.3.12.29* %agg.result) local_unnamed_addr #0 { |
| 7 | +; CHECK-LABEL: g: |
| 8 | +; CHECK: # %bb.0: # %entry |
| 9 | +; CHECK-NEXT: mflr r0 |
| 10 | +; CHECK-NEXT: std r0, 16(r1) |
| 11 | +; CHECK-NEXT: stdu r1, -112(r1) |
| 12 | +; CHECK-NEXT: bl i |
| 13 | +; CHECK-NEXT: nop |
| 14 | +; CHECK-NEXT: addis r4, r2, g@toc@ha |
| 15 | +; CHECK-NEXT: addi r4, r4, g@toc@l |
| 16 | +; CHECK-NEXT: ld r5, 0(r4) |
| 17 | +; CHECK-NEXT: std r5, 0(r3) |
| 18 | +; CHECK-NEXT: ld r5, 16(r4) |
| 19 | +; CHECK-NEXT: std r5, 16(r3) |
| 20 | +; CHECK-NEXT: ld r6, 8(r4) |
| 21 | +; CHECK-NEXT: std r6, 8(r3) |
| 22 | +; CHECK-NEXT: ld r6, 24(r4) |
| 23 | +; CHECK-NEXT: std r6, 24(r3) |
| 24 | +; CHECK-NEXT: lwz r6, 0(r3) |
| 25 | +; CHECK-NEXT: ld r4, 32(r4) |
| 26 | +; CHECK-NEXT: std r4, 32(r3) |
| 27 | +; CHECK-NEXT: li r4, 20 |
| 28 | +; CHECK-NEXT: stwbrx r6, 0, r3 |
| 29 | +; CHECK-NEXT: stwbrx r5, r3, r4 |
| 30 | +; CHECK-NEXT: addi r1, r1, 112 |
| 31 | +; CHECK-NEXT: ld r0, 16(r1) |
| 32 | +; CHECK-NEXT: mtlr r0 |
| 33 | +; CHECK-NEXT: blr |
| 34 | +entry: |
| 35 | + %call = tail call signext i32 bitcast (i32 (...)* @i to i32 ()*)() |
| 36 | + %conv = sext i32 %call to i64 |
| 37 | + %0 = inttoptr i64 %conv to i8* |
| 38 | + tail call void @llvm.memcpy.p0i8.p0i8.i64(i8* nonnull align 4 dereferenceable(40) %0, i8* nonnull align 4 dereferenceable(40) bitcast (void (%struct.e.0.1.2.3.12.29*)* @g to i8*), i64 40, i1 false) |
| 39 | + %1 = inttoptr i64 %conv to i32* |
| 40 | + %2 = load i32, i32* %1, align 4 |
| 41 | + %rev.i = tail call i32 @llvm.bswap.i32(i32 %2) |
| 42 | + store i32 %rev.i, i32* %1, align 4 |
| 43 | + %incdec.ptr.i.4 = getelementptr inbounds i32, i32* %1, i64 5 |
| 44 | + %3 = load i32, i32* %incdec.ptr.i.4, align 4 |
| 45 | + %rev.i.5 = tail call i32 @llvm.bswap.i32(i32 %3) |
| 46 | + store i32 %rev.i.5, i32* %incdec.ptr.i.4, align 4 |
| 47 | + ret void |
| 48 | +} |
| 49 | + |
| 50 | +declare i32 @i(...) local_unnamed_addr |
| 51 | + |
| 52 | +; Function Attrs: argmemonly nounwind willreturn |
| 53 | +declare void @llvm.memcpy.p0i8.p0i8.i64(i8* noalias nocapture writeonly, i8* noalias nocapture readonly, i64, i1 immarg) #1 |
| 54 | + |
| 55 | +; Function Attrs: nounwind readnone speculatable willreturn |
| 56 | +declare i32 @llvm.bswap.i32(i32) |
| 57 | + |
| 58 | +attributes #0 = { nounwind } |
0 commit comments