; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mcpu=pwr10 -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ ; RUN: -mattr=+quadword-atomics -ppc-asm-full-reg-names -o - %s | FileCheck %s %struct.StructA = type { [16 x i8] } @s1 = dso_local global i128 324929342, align 16 ; Function Attrs: mustprogress noinline nounwind optnone uwtable define dso_local void @STQ() #0 { ; CHECK-LABEL: STQ: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: lis r0, -16 ; CHECK-NEXT: ori r0, r0, 51488 ; CHECK-NEXT: stdux r1, r1, r0 ; CHECK-NEXT: .cfi_def_cfa_offset 997088 ; CHECK-NEXT: pld r3, s1@PCREL+8(0), 1 ; CHECK-NEXT: std r3, 40(r1) ; CHECK-NEXT: pld r3, s1@PCREL(0), 1 ; CHECK-NEXT: std r3, 32(r1) ; CHECK-NEXT: ld r3, 40(r1) ; CHECK-NEXT: ld r4, 32(r1) ; CHECK-NEXT: sync ; CHECK-NEXT: mr r5, r4 ; CHECK-NEXT: mr r4, r3 ; CHECK-NEXT: lis r3, 15 ; CHECK-NEXT: ori r3, r3, 14032 ; CHECK-NEXT: add r3, r3, r1 ; CHECK-NEXT: stq r4, 0(r3) ; CHECK-NEXT: ld r1, 0(r1) ; CHECK-NEXT: blr entry: %s2 = alloca %struct.StructA, align 16 %s3 = alloca %struct.StructA, align 16 %arr = alloca [997003 x i8], align 1 %tmp = alloca %struct.StructA, align 16 call void @llvm.memcpy.p0.p0.i64(ptr align 16 %tmp, ptr align 16 @s1, i64 16, i1 false) %0 = load i128, ptr %tmp, align 16 store atomic i128 %0, ptr %s2 seq_cst, align 16 ret void } define dso_local void @LQ() #0 { ; CHECK-LABEL: LQ: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: lis r0, -16 ; CHECK-NEXT: ori r0, r0, 51488 ; CHECK-NEXT: stdux r1, r1, r0 ; CHECK-NEXT: .cfi_def_cfa_offset 997088 ; CHECK-NEXT: pld r3, s1@PCREL+8(0), 1 ; CHECK-NEXT: std r3, 40(r1) ; CHECK-NEXT: pld r3, s1@PCREL(0), 1 ; CHECK-NEXT: std r3, 32(r1) ; CHECK-NEXT: sync ; CHECK-NEXT: lis r3, 15 ; CHECK-NEXT: ori r3, r3, 14016 ; CHECK-NEXT: add r3, r3, r1 ; CHECK-NEXT: lq r4, 0(r3) ; CHECK-NEXT: cmpd cr7, r5, r5 ; CHECK-NEXT: bne- cr7, .+4 ; CHECK-NEXT: isync ; CHECK-NEXT: ld r1, 0(r1) ; CHECK-NEXT: blr entry: %s2 = alloca %struct.StructA, align 16 %s3 = alloca %struct.StructA, align 16 %arr = alloca [997003 x i8], align 1 %tmp = alloca %struct.StructA, align 16 call void @llvm.memcpy.p0.p0.i64(ptr align 16 %tmp, ptr align 16 @s1, i64 16, i1 false) %0 = load i128, ptr %tmp, align 16 %1 = load atomic i128, ptr %s3 seq_cst, align 16 ret void } ; Function Attrs: argmemonly nofree nounwind willreturn declare void @llvm.memcpy.p0.p0.i64(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i64, i1 immarg) #1 attributes #0 = { noinline optnone }