xref: /aosp_15_r20/external/llvm/test/CodeGen/Hexagon/pred-absolute-store.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; Check that we are able to predicate instructions with abosolute
3*9880d681SAndroid Build Coastguard Worker; addressing mode.
4*9880d681SAndroid Build Coastguard Worker; CHECK: if ({{!*}}p{{[0-2]}}.new) memw(##gvar) = r{{[0-9]+}}
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker@gvar = external global i32
7*9880d681SAndroid Build Coastguard Workerdefine i32 @test2(i32 %a, i32 %b) nounwind {
8*9880d681SAndroid Build Coastguard Workerentry:
9*9880d681SAndroid Build Coastguard Worker  %cmp = icmp eq i32 %a, %b
10*9880d681SAndroid Build Coastguard Worker  br i1 %cmp, label %if.then, label %if.end
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Workerif.then:
13*9880d681SAndroid Build Coastguard Worker  store i32 %a, i32* @gvar, align 4
14*9880d681SAndroid Build Coastguard Worker  br label %if.end
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Workerif.end:
17*9880d681SAndroid Build Coastguard Worker  ret i32 %b
18*9880d681SAndroid Build Coastguard Worker}
19