| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ |
| ; RUN: -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \ |
| ; RUN: < %s | FileCheck %s --check-prefix=DEFAULT |
| ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ |
| ; RUN: -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \ |
| ; RUN: -ppc-pcrel-linker-opt=true < %s | FileCheck %s --check-prefix=ON |
| ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ |
| ; RUN: -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \ |
| ; RUN: -ppc-pcrel-linker-opt=false < %s | FileCheck %s --check-prefix=OFF |
| |
| @input8 = external local_unnamed_addr global i8, align 1 |
| |
| define dso_local i8 @Read8() local_unnamed_addr { |
| ; DEFAULT-LABEL: Read8: |
| ; DEFAULT: # %bb.0: # %entry |
| ; DEFAULT-NEXT: pld r3, input8@got@pcrel(0), 1 |
| ; DEFAULT-NEXT: .Lpcrel0: |
| ; DEFAULT-NEXT: .reloc .Lpcrel0-8,R_PPC64_PCREL_OPT,.-(.Lpcrel0-8) |
| ; DEFAULT-NEXT: lbz r3, 0(r3) |
| ; DEFAULT-NEXT: blr |
| ; |
| ; ON-LABEL: Read8: |
| ; ON: # %bb.0: # %entry |
| ; ON-NEXT: pld r3, input8@got@pcrel(0), 1 |
| ; ON-NEXT: .Lpcrel0: |
| ; ON-NEXT: .reloc .Lpcrel0-8,R_PPC64_PCREL_OPT,.-(.Lpcrel0-8) |
| ; ON-NEXT: lbz r3, 0(r3) |
| ; ON-NEXT: blr |
| ; |
| ; OFF-LABEL: Read8: |
| ; OFF: # %bb.0: # %entry |
| ; OFF-NEXT: pld r3, input8@got@pcrel(0), 1 |
| ; OFF-NEXT: lbz r3, 0(r3) |
| ; OFF-NEXT: blr |
| entry: |
| %0 = load i8, i8* @input8, align 1 |
| ret i8 %0 |
| } |