mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-11 23:16:20 +00:00
6994040a95
This also changes the syntax for llvm.bswap, llvm.part.set, llvm.part.select, and llvm.ct* intrinsics. They are automatically upgraded by both the LLVM ASM reader and the bitcode reader. The test cases have been updated, with special tests added to ensure the automatic upgrading is supported. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40807 91177308-0d34-0410-b5e6-96231b3b80d8
20 lines
630 B
LLVM
20 lines
630 B
LLVM
; Tests to make sure bit counts of constants are folded
|
|
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {ret i32 19}
|
|
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
|
; RUN: grep -v declare | not grep llvm.ct
|
|
|
|
declare i31 @llvm.ctpop.i31(i31 %val)
|
|
declare i32 @llvm.cttz.i32(i32 %val)
|
|
declare i33 @llvm.ctlz.i33(i33 %val)
|
|
|
|
define i32 @test(i32 %A) {
|
|
%c1 = call i31 @llvm.ctpop.i31(i31 12415124)
|
|
%c2 = call i32 @llvm.cttz.i32(i32 87359874)
|
|
%c3 = call i33 @llvm.ctlz.i33(i33 87359874)
|
|
%t1 = zext i31 %c1 to i32
|
|
%t3 = trunc i33 %c3 to i32
|
|
%r1 = add i32 %t1, %c2
|
|
%r2 = add i32 %r1, %t3
|
|
ret i32 %r2
|
|
}
|