xref: /llvm-project/llvm/test/CodeGen/AVR/brind.ll (revision 9ef1d37ffb5f56a9b949a6307bbb16c2ea0130e3)
1; RUN: llc -mattr=sram,eijmpcall < %s -mtriple=avr -verify-machineinstrs | FileCheck %s
2
3@brind.k = private unnamed_addr constant [2 x ptr addrspace(1)] [ptr addrspace(1) blockaddress(@brind, %return), ptr addrspace(1) blockaddress(@brind, %b)], align 1
4
5define i8 @brind(i8 %p) {
6; CHECK-LABEL: brind:
7; CHECK: ijmp
8entry:
9  %idxprom = sext i8 %p to i16
10  %arrayidx = getelementptr inbounds [2 x ptr addrspace(1)], ptr @brind.k, i16 0, i16 %idxprom
11  %s = load ptr addrspace(1), ptr %arrayidx
12  indirectbr ptr addrspace(1) %s, [label %return, label %b]
13b:
14  br label %return
15return:
16  %retval.0 = phi i8 [ 4, %b ], [ 2, %entry ]
17  ret i8 %retval.0
18}
19