2002-05-02 17:01:39 +00:00
|
|
|
; Tests to make sure elimination of casts is working correctly
|
2006-04-12 18:07:41 +00:00
|
|
|
; RUN: llvm-as < %s | opt -instcombine -disable-output &&
|
2004-02-28 05:26:06 +00:00
|
|
|
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep '%c' | not grep cast
|
2002-05-02 17:01:39 +00:00
|
|
|
|
2004-02-22 05:24:09 +00:00
|
|
|
%inbuf = external global [32832 x ubyte]
|
|
|
|
|
2002-05-02 17:01:39 +00:00
|
|
|
implementation
|
|
|
|
|
2002-08-02 18:48:09 +00:00
|
|
|
int %test1(int %A) {
|
2002-05-02 17:01:39 +00:00
|
|
|
%c1 = cast int %A to uint
|
|
|
|
%c2 = cast uint %c1 to int
|
|
|
|
ret int %c2
|
2002-08-02 18:48:09 +00:00
|
|
|
}
|
2002-05-02 17:01:39 +00:00
|
|
|
|
2002-08-02 18:48:09 +00:00
|
|
|
ulong %test2(ubyte %A) {
|
2002-05-02 17:01:39 +00:00
|
|
|
%c1 = cast ubyte %A to ushort
|
|
|
|
%c2 = cast ushort %c1 to uint
|
|
|
|
%Ret = cast uint %c2 to ulong
|
|
|
|
ret ulong %Ret
|
2002-08-02 18:48:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ulong %test3(ulong %A) { ; This function should just use bitwise AND
|
|
|
|
%c1 = cast ulong %A to ubyte
|
|
|
|
%c2 = cast ubyte %c1 to ulong
|
|
|
|
ret ulong %c2
|
|
|
|
}
|
2002-08-15 16:13:29 +00:00
|
|
|
|
|
|
|
uint %test4(int %A, int %B) {
|
|
|
|
%COND = setlt int %A, %B
|
|
|
|
%c = cast bool %COND to ubyte ; Booleans are unsigned integrals
|
|
|
|
%result = cast ubyte %c to uint ; for the cast elim purpose
|
|
|
|
ret uint %result
|
|
|
|
}
|
|
|
|
|
|
|
|
int %test5(bool %B) {
|
|
|
|
%c = cast bool %B to ubyte ; This cast should get folded into
|
|
|
|
%result = cast ubyte %c to int ; this cast
|
|
|
|
ret int %result
|
|
|
|
}
|
|
|
|
|
|
|
|
int %test6(ulong %A) {
|
|
|
|
%c1 = cast ulong %A to uint
|
|
|
|
%res = cast uint %c1 to int
|
|
|
|
ret int %res
|
|
|
|
}
|
|
|
|
|
|
|
|
long %test7(bool %A) {
|
|
|
|
%c1 = cast bool %A to int
|
|
|
|
%res = cast int %c1 to long
|
|
|
|
ret long %res
|
|
|
|
}
|
|
|
|
|
|
|
|
long %test8(sbyte %A) {
|
|
|
|
%c1 = cast sbyte %A to ulong
|
|
|
|
%res = cast ulong %c1 to long
|
|
|
|
ret long %res
|
|
|
|
}
|
|
|
|
|
2002-09-23 23:39:17 +00:00
|
|
|
short %test9(short %A) {
|
|
|
|
%c1 = cast short %A to int
|
|
|
|
%c2 = cast int %c1 to short
|
|
|
|
ret short %c2
|
|
|
|
}
|
|
|
|
|
|
|
|
short %test10(short %A) {
|
|
|
|
%c1 = cast short %A to uint
|
|
|
|
%c2 = cast uint %c1 to short
|
|
|
|
ret short %c2
|
|
|
|
}
|
2003-06-23 21:48:26 +00:00
|
|
|
|
2003-10-07 22:53:46 +00:00
|
|
|
declare void %varargs(int, ...)
|
|
|
|
|
|
|
|
void %test11(int* %P) {
|
|
|
|
%c = cast int* %P to short*
|
|
|
|
call void(int, ...)* %varargs(int 5, short* %c)
|
|
|
|
ret void
|
|
|
|
}
|
2003-11-02 05:56:58 +00:00
|
|
|
|
|
|
|
int* %test12() {
|
|
|
|
%p = malloc [4 x sbyte]
|
|
|
|
%c = cast [4 x sbyte]* %p to int*
|
|
|
|
ret int* %c
|
|
|
|
}
|
2004-02-22 05:24:09 +00:00
|
|
|
|
|
|
|
ubyte *%test13(long %A) {
|
|
|
|
%c = getelementptr [0 x ubyte]* cast ([32832 x ubyte]* %inbuf to [0 x ubyte]*), long 0, long %A
|
|
|
|
ret ubyte* %c
|
|
|
|
}
|
2004-02-23 07:16:03 +00:00
|
|
|
|
|
|
|
bool %test14(sbyte %A) {
|
2004-05-25 04:28:43 +00:00
|
|
|
%c = cast sbyte %A to ubyte
|
|
|
|
%X = setlt ubyte %c, 128 ; setge %A, 0
|
2004-02-23 07:16:03 +00:00
|
|
|
ret bool %X
|
|
|
|
}
|
|
|
|
|
|
|
|
bool %test15(ubyte %A) {
|
2004-05-25 04:28:43 +00:00
|
|
|
%c = cast ubyte %A to sbyte
|
|
|
|
%X = setlt sbyte %c, 0 ; setgt %A, 127
|
2004-02-23 07:16:03 +00:00
|
|
|
ret bool %X
|
|
|
|
}
|
|
|
|
|
2004-05-25 04:28:43 +00:00
|
|
|
bool %test16(int* %P) {
|
|
|
|
%c = cast int* %P to bool ;; setne P, null
|
|
|
|
ret bool %c
|
|
|
|
}
|
2004-07-20 00:57:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
short %test17(bool %tmp3) {
|
|
|
|
%c = cast bool %tmp3 to int
|
|
|
|
%t86 = cast int %c to short
|
|
|
|
ret short %t86
|
|
|
|
}
|
|
|
|
|
|
|
|
short %test18(sbyte %tmp3) {
|
|
|
|
%c = cast sbyte %tmp3 to int
|
|
|
|
%t86 = cast int %c to short
|
|
|
|
ret short %t86
|
|
|
|
}
|
|
|
|
|
2004-09-29 03:18:20 +00:00
|
|
|
bool %test19(int %X) {
|
2005-01-31 05:17:31 +00:00
|
|
|
%c = cast int %X to long
|
|
|
|
%Z = setlt long %c, 12345
|
2004-09-29 03:18:20 +00:00
|
|
|
ret bool %Z
|
|
|
|
}
|
|
|
|
|
|
|
|
bool %test20(bool %B) {
|
2005-01-31 05:17:31 +00:00
|
|
|
%c = cast bool %B to int
|
|
|
|
%D = setlt int %c, -1
|
2004-09-29 03:18:20 +00:00
|
|
|
ret bool %D ;; false
|
|
|
|
}
|
2005-01-01 16:13:43 +00:00
|
|
|
|
|
|
|
uint %test21(uint %X) {
|
2005-01-31 05:17:31 +00:00
|
|
|
%c1 = cast uint %X to sbyte
|
|
|
|
%c2 = cast sbyte %c1 to uint ;; sext -> zext -> and -> nop
|
|
|
|
%RV = and uint %c2, 255
|
2005-01-01 16:13:43 +00:00
|
|
|
ret uint %RV
|
|
|
|
}
|
|
|
|
|
|
|
|
uint %test22(uint %X) {
|
2005-01-31 05:17:31 +00:00
|
|
|
%c1 = cast uint %X to sbyte
|
|
|
|
%c2 = cast sbyte %c1 to uint ;; sext -> zext -> and -> nop
|
|
|
|
%RV = shl uint %c2, ubyte 24
|
2005-01-01 16:13:43 +00:00
|
|
|
ret uint %RV
|
|
|
|
}
|
|
|
|
|
|
|
|
int %test23(int %X) {
|
2005-01-31 05:17:31 +00:00
|
|
|
%c1 = cast int %X to ushort ;; Turn into an AND even though X
|
|
|
|
%c2 = cast ushort %c1 to int ;; and Z are signed.
|
|
|
|
ret int %c2
|
2005-01-01 16:13:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool %test24(bool %C) {
|
|
|
|
%X = select bool %C, uint 14, uint 1234
|
2005-01-31 05:17:31 +00:00
|
|
|
%c = cast uint %X to bool ;; Fold cast into select
|
|
|
|
ret bool %c
|
2005-01-01 16:13:43 +00:00
|
|
|
}
|
|
|
|
|
2005-01-31 05:51:18 +00:00
|
|
|
void %test25(int** %P) {
|
|
|
|
%c = cast int** %P to float**
|
|
|
|
store float* null, float** %c ;; Fold cast into null
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2006-01-19 07:39:20 +00:00
|
|
|
int %test26(float %F) {
|
|
|
|
%c = cast float %F to double ;; no need to cast from float->double.
|
|
|
|
%D = cast double %c to int
|
|
|
|
ret int %D
|
|
|
|
}
|
2006-04-12 18:07:41 +00:00
|
|
|
|
|
|
|
[4 x float]* %test27([9 x [4 x float]]* %A) {
|
|
|
|
%c = cast [9 x [4 x float]]* %A to [4 x float]*
|
|
|
|
ret [4 x float]* %c
|
|
|
|
}
|
|
|
|
|
|
|
|
float* %test28([4 x float]* %A) {
|
|
|
|
%c = cast [4 x float]* %A to float*
|
|
|
|
ret float* %c
|
|
|
|
}
|
|
|
|
|
2006-05-05 06:38:40 +00:00
|
|
|
uint %test29(uint %c1, uint %c2) {
|
|
|
|
%tmp1 = cast uint %c1 to ubyte
|
|
|
|
%tmp4.mask = cast uint %c2 to ubyte
|
|
|
|
%tmp = or ubyte %tmp4.mask, %tmp1
|
|
|
|
%tmp10 = cast ubyte %tmp to uint
|
|
|
|
ret uint %tmp10
|
|
|
|
}
|
|
|
|
|