; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mcpu=ppc -mtriple powerpc-ibm-aix-xcoff -verify-machineinstrs < %s | FileCheck %s --check-prefix=CHECK ; RUN: llc -mcpu=ppc -mtriple powerpc64-ibm-aix-xcoff -verify-machineinstrs < %s | FileCheck %s --check-prefix=CHECK-64 ; RUN: llc -filetype=obj -mcpu=ppc -mtriple powerpc-ibm-aix-xcoff -verify-machineinstrs < %s -o %t32.o ; RUN: llvm-objdump -t --symbol-description %t32.o | FileCheck %s --check-prefix=OBJ32 ; RUN: llc -filetype=obj -mcpu=ppc -mtriple powerpc64-ibm-aix-xcoff -verify-machineinstrs < %s -o %t64.o ; RUN: llvm-objdump -t --symbol-description %t64.o | FileCheck %s --check-prefix=OBJ64 @a1 = common global i32 0, align 4 #0 @a2 = global i32 0, align 4 #0 @a3 = common global i32 0, align 4 @a4 = global i32 0, align 4 define void @set(i32 noundef %_a) { ; CHECK-LABEL: set: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: la 4, a2[TD](2) ; CHECK-NEXT: lwz 5, L..C0(2) # @a4 ; CHECK-NEXT: stw 3, 0(4) ; CHECK-NEXT: la 4, a1[TD](2) ; CHECK-NEXT: stw 3, 0(4) ; CHECK-NEXT: lwz 4, L..C1(2) # @a3 ; CHECK-NEXT: stw 3, 0(5) ; CHECK-NEXT: stw 3, 0(4) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: set: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: la 4, a2[TD](2) ; CHECK-64-NEXT: ld 5, L..C0(2) # @a4 ; CHECK-64-NEXT: stw 3, 0(4) ; CHECK-64-NEXT: la 4, a1[TD](2) ; CHECK-64-NEXT: stw 3, 0(4) ; CHECK-64-NEXT: ld 4, L..C1(2) # @a3 ; CHECK-64-NEXT: stw 3, 0(5) ; CHECK-64-NEXT: stw 3, 0(4) ; CHECK-64-NEXT: blr entry: store i32 %_a, ptr @a2, align 4 store i32 %_a, ptr @a1, align 4 store i32 %_a, ptr @a4, align 4 store i32 %_a, ptr @a3, align 4 ret void } define i32 @get1() { ; CHECK-LABEL: get1: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: la 3, a2[TD](2) ; CHECK-NEXT: lwz 3, 0(3) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: get1: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: la 3, a2[TD](2) ; CHECK-64-NEXT: lwz 3, 0(3) ; CHECK-64-NEXT: blr entry: %0 = load i32, ptr @a2, align 4 ret i32 %0 } define i32 @get2() { ; CHECK-LABEL: get2: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: la 3, a1[TD](2) ; CHECK-NEXT: lwz 3, 0(3) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: get2: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: la 3, a1[TD](2) ; CHECK-64-NEXT: lwz 3, 0(3) ; CHECK-64-NEXT: blr entry: %0 = load i32, ptr @a1, align 4 ret i32 %0 } define i32 @get3() { ; CHECK-LABEL: get3: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: lwz 3, L..C0(2) # @a4 ; CHECK-NEXT: lwz 3, 0(3) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: get3: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: ld 3, L..C0(2) # @a4 ; CHECK-64-NEXT: lwz 3, 0(3) ; CHECK-64-NEXT: blr entry: %0 = load i32, ptr @a4, align 4 ret i32 %0 } define i32 @get4() { ; CHECK-LABEL: get4: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: lwz 3, L..C1(2) # @a3 ; CHECK-NEXT: lwz 3, 0(3) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: get4: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: ld 3, L..C1(2) # @a3 ; CHECK-64-NEXT: lwz 3, 0(3) ; CHECK-64-NEXT: blr entry: %0 = load i32, ptr @a3, align 4 ret i32 %0 } define nonnull ptr @escape1() { ; CHECK-LABEL: escape1: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: la 3, a2[TD](2) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: escape1: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: la 3, a2[TD](2) ; CHECK-64-NEXT: blr entry: ret ptr @a2 } define nonnull ptr @escape2() { ; CHECK-LABEL: escape2: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: la 3, a1[TD](2) ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: escape2: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: la 3, a1[TD](2) ; CHECK-64-NEXT: blr entry: ret ptr @a1 } define nonnull ptr @escape3() { ; CHECK-LABEL: escape3: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: lwz 3, L..C0(2) # @a4 ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: escape3: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: ld 3, L..C0(2) # @a4 ; CHECK-64-NEXT: blr entry: ret ptr @a4 } define nonnull ptr @escape4() { ; CHECK-LABEL: escape4: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: lwz 3, L..C1(2) # @a3 ; CHECK-NEXT: blr ; ; CHECK-64-LABEL: escape4: ; CHECK-64: # %bb.0: # %entry ; CHECK-64-NEXT: ld 3, L..C1(2) # @a3 ; CHECK-64-NEXT: blr entry: ret ptr @a3 } attributes #0 = { "toc-data" } ; CHECK: .comm a3[RW],4,2 # @a3 ; CHECK-NEXT: .csect a4[RW],2 ; CHECK-NEXT: .globl a4[RW] # @a4 ; CHECK-NEXT: .align 2 ; CHECK-NEXT: .vbyte 4, 0 # 0x0 ; CHECK-NEXT: .toc ; CHECK-LABEL: L..C0: ; CHECK-NEXT: .tc a4[TC],a4[RW] ; CHECK-LABEL: L..C1: ; CHECK-NEXT: .tc a3[TC],a3[RW] ; CHECK-NEXT: .csect a2[TD],2 ; CHECK-NEXT: .globl a2[TD] # @a2 ; CHECK-NEXT: .align 2 ; CHECK-NEXT: .vbyte 4, 0 # 0x0 ; CHECK-NEXT: .comm a1[TD],4,2 # @a1 ; OBJ32: {{([[:xdigit:]]{8})}} g O .data 00000004 (idx: {{[0-9]+}}) a4[RW] ; OBJ32-LABEL: {{([[:xdigit:]]{8})}} l .data 00000000 (idx: {{[0-9]+}}) TOC[TC0] ; OBJ32-NEXT: {{([[:xdigit:]]{8})}} l O .data 00000004 (idx: {{[0-9]+}}) a4[TC] ; OBJ32-NEXT: {{([[:xdigit:]]{8})}} l O .data 00000004 (idx: {{[0-9]+}}) a3[TC] ; OBJ32-NEXT: {{([[:xdigit:]]{8})}} g O .data 00000004 (idx: {{[0-9]+}}) a2[TD] ; OBJ32-NEXT: {{([[:xdigit:]]{8})}} g O *COM* 00000004 (idx: {{[0-9]+}}) a1[TD] ; OBJ32-NEXT: {{([[:xdigit:]]{8})}} g O *COM* 00000004 (idx: {{[0-9]+}}) a3[RW] ; OBJ64: {{([[:xdigit:]]{16})}} g O .data 0000000000000004 (idx: {{[0-9]+}}) a4[RW] ; OBJ64-LABEL: {{([[:xdigit:]]{16})}} l .data 0000000000000000 (idx: {{[0-9]+}}) TOC[TC0] ; OBJ64-NEXT: {{([[:xdigit:]]{16})}} l O .data 0000000000000008 (idx: {{[0-9]+}}) a4[TC] ; OBJ64-NEXT: {{([[:xdigit:]]{16})}} l O .data 0000000000000008 (idx: {{[0-9]+}}) a3[TC] ; OBJ64-NEXT: {{([[:xdigit:]]{16})}} g O .data 0000000000000004 (idx: {{[0-9]+}}) a2[TD] ; OBJ64-NEXT: {{([[:xdigit:]]{16})}} g O *COM* 0000000000000004 (idx: {{[0-9]+}}) a1[TD] ; OBJ64-NEXT: {{([[:xdigit:]]{16})}} g O *COM* 0000000000000004 (idx: {{[0-9]+}}) a3[RW]