[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / PowerPC / pr45301.ll
blobee0c6c341cc0cdd048bae6c15c643fec130592d6
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] }
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
50 declare i32 @i(...) local_unnamed_addr
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
55 ; Function Attrs: nounwind readnone speculatable willreturn
56 declare i32 @llvm.bswap.i32(i32)
58 attributes #0 = { nounwind }