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