[ConstraintElim] Add support for decomposing gep nuw (#118639)
[llvm-project.git] / llvm / test / CodeGen / AVR / icall-func-pointer-correct-addr-space.ll
blob51b8f219a26d56033e3f2f7e57006ada0ecb1947
1 ; RUN: llc -mattr=lpm,lpmw < %s -march=avr | FileCheck %s
3 @callbackPtr = common global ptr addrspace(1) null, align 8
4 @myValuePtr = common global ptr null, align 8
6 @externalConstant = external global i16, align 2
8 declare void @externalFunction(i16 signext)
9 declare void @bar(i8 signext, ptr, ptr)
11 ; CHECK-LABEL: loadCallbackPtr
12 define void @loadCallbackPtr() {
13 entry:
14   ; CHECK:      ldi     r{{[0-9]+}}, pm_lo8(externalFunction)
15   ; CHECK-NEXT: ldi     r{{[0-9]+}}, pm_hi8(externalFunction)
16   store ptr addrspace(1) @externalFunction, ptr @callbackPtr, align 8
17   ret void
20 ; CHECK-LABEL: loadValuePtr
21 define void @loadValuePtr() {
22 entry:
23   ; CHECK:      ldi     r{{[0-9]+}}, lo8(externalConstant)
24   ; CHECK-NEXT: ldi     r{{[0-9]+}}, hi8(externalConstant)
25   store ptr @externalConstant, ptr @myValuePtr, align 8
26   ret void