llvm/test/CodeGen/Hexagon/constp-ctb.ll
Krzysztof Parzyszek 5559171657 [Hexagon] Implement MI-level constant propagation
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@277028 91177308-0d34-0410-b5e6-96231b3b80d8
2016-07-28 20:01:59 +00:00

27 lines
676 B
LLVM

; 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 }