mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
ddbc274169
I followed three heuristics for deciding whether to set 'true' or 'false': - Everything target independent got 'true' as that is the expected common output of the GCC builtins. - If the target arch only has one way of implementing this operation, set the flag in the way that exercises the most of codegen. For most architectures this is also the likely path from a GCC builtin, with 'true' being set. It will (eventually) require lowering away that difference, and then lowering to the architecture's operation. - Otherwise, set the flag differently dependending on which target operation should be tested. Let me know if anyone has any issue with this pattern or would like specific tests of another form. This should allow the x86 codegen to just iteratively improve as I teach the backend how to differentiate between the two forms, and everything else should remain exactly the same. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@146370 91177308-0d34-0410-b5e6-96231b3b80d8
63 lines
1.8 KiB
LLVM
63 lines
1.8 KiB
LLVM
; Make sure this testcase is supported by all code generators
|
|
; RUN: llc < %s
|
|
|
|
declare i64 @llvm.ctpop.i64(i64)
|
|
|
|
declare i32 @llvm.ctpop.i32(i32)
|
|
|
|
declare i16 @llvm.ctpop.i16(i16)
|
|
|
|
declare i8 @llvm.ctpop.i8(i8)
|
|
|
|
define void @ctpoptest(i8 %A, i16 %B, i32 %C, i64 %D, i8* %AP, i16* %BP, i32* %CP, i64* %DP) {
|
|
%a = call i8 @llvm.ctpop.i8( i8 %A ) ; <i8> [#uses=1]
|
|
%b = call i16 @llvm.ctpop.i16( i16 %B ) ; <i16> [#uses=1]
|
|
%c = call i32 @llvm.ctpop.i32( i32 %C ) ; <i32> [#uses=1]
|
|
%d = call i64 @llvm.ctpop.i64( i64 %D ) ; <i64> [#uses=1]
|
|
store i8 %a, i8* %AP
|
|
store i16 %b, i16* %BP
|
|
store i32 %c, i32* %CP
|
|
store i64 %d, i64* %DP
|
|
ret void
|
|
}
|
|
|
|
declare i64 @llvm.ctlz.i64(i64, i1)
|
|
|
|
declare i32 @llvm.ctlz.i32(i32, i1)
|
|
|
|
declare i16 @llvm.ctlz.i16(i16, i1)
|
|
|
|
declare i8 @llvm.ctlz.i8(i8, i1)
|
|
|
|
define void @ctlztest(i8 %A, i16 %B, i32 %C, i64 %D, i8* %AP, i16* %BP, i32* %CP, i64* %DP) {
|
|
%a = call i8 @llvm.ctlz.i8( i8 %A, i1 true ) ; <i8> [#uses=1]
|
|
%b = call i16 @llvm.ctlz.i16( i16 %B, i1 true ) ; <i16> [#uses=1]
|
|
%c = call i32 @llvm.ctlz.i32( i32 %C, i1 true ) ; <i32> [#uses=1]
|
|
%d = call i64 @llvm.ctlz.i64( i64 %D, i1 true ) ; <i64> [#uses=1]
|
|
store i8 %a, i8* %AP
|
|
store i16 %b, i16* %BP
|
|
store i32 %c, i32* %CP
|
|
store i64 %d, i64* %DP
|
|
ret void
|
|
}
|
|
|
|
declare i64 @llvm.cttz.i64(i64, i1)
|
|
|
|
declare i32 @llvm.cttz.i32(i32, i1)
|
|
|
|
declare i16 @llvm.cttz.i16(i16, i1)
|
|
|
|
declare i8 @llvm.cttz.i8(i8, i1)
|
|
|
|
define void @cttztest(i8 %A, i16 %B, i32 %C, i64 %D, i8* %AP, i16* %BP, i32* %CP, i64* %DP) {
|
|
%a = call i8 @llvm.cttz.i8( i8 %A, i1 true ) ; <i8> [#uses=1]
|
|
%b = call i16 @llvm.cttz.i16( i16 %B, i1 true ) ; <i16> [#uses=1]
|
|
%c = call i32 @llvm.cttz.i32( i32 %C, i1 true ) ; <i32> [#uses=1]
|
|
%d = call i64 @llvm.cttz.i64( i64 %D, i1 true ) ; <i64> [#uses=1]
|
|
store i8 %a, i8* %AP
|
|
store i16 %b, i16* %BP
|
|
store i32 %c, i32* %CP
|
|
store i64 %d, i64* %DP
|
|
ret void
|
|
}
|