| ; 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 } |