diff options
Diffstat (limited to 'llvm/test/CodeGen/Hexagon/constp-ctb.ll')
-rw-r--r-- | llvm/test/CodeGen/Hexagon/constp-ctb.ll | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/Hexagon/constp-ctb.ll b/llvm/test/CodeGen/Hexagon/constp-ctb.ll new file mode 100644 index 00000000000..76a9820583e --- /dev/null +++ b/llvm/test/CodeGen/Hexagon/constp-ctb.ll @@ -0,0 +1,26 @@ +; RUN: llc < %s +; REQUIRES: asserts + +target datalayout = "e-m:e-p:32:32-i1:32-i64:64-a:0-v32:32-n16:32" +target triple = "hexagon-unknown--elf" + +; Function Attrs: nounwind readnone +define i64 @foo() #0 { +entry: + %0 = tail call i32 @llvm.hexagon.S2.ct0p(i64 18) + %1 = tail call i32 @llvm.hexagon.S2.ct1p(i64 27) + %2 = tail call i64 @llvm.hexagon.A2.combinew(i32 %0, i32 %1) + ret i64 %2 +} + +; Function Attrs: nounwind readnone +declare i32 @llvm.hexagon.S2.ct0p(i64) #0 + +; Function Attrs: nounwind readnone +declare i32 @llvm.hexagon.S2.ct1p(i64) #0 + +; Function Attrs: nounwind readnone +declare i64 @llvm.hexagon.A2.combinew(i32, i32) #0 + +attributes #0 = { nounwind readnone } + |