xref: /aosp_15_r20/external/llvm/test/CodeGen/Hexagon/combine.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon -mcpu=hexagonv5 -disable-hsdr < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; CHECK: combine(r{{[0-9]+}}, r{{[0-9]+}})
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker@j = external global i32
5*9880d681SAndroid Build Coastguard Worker@k = external global i64
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Workerdefine void @foo() nounwind {
8*9880d681SAndroid Build Coastguard Workerentry:
9*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* @j, align 4
10*9880d681SAndroid Build Coastguard Worker  %1 = load i64, i64* @k, align 8
11*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %1 to i32
12*9880d681SAndroid Build Coastguard Worker  %2 = call i64 @llvm.hexagon.A2.combinew(i32 %0, i32 %conv)
13*9880d681SAndroid Build Coastguard Worker  store i64 %2, i64* @k, align 8
14*9880d681SAndroid Build Coastguard Worker  ret void
15*9880d681SAndroid Build Coastguard Worker}
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.hexagon.A2.combinew(i32, i32) nounwind readnone
18