1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 04:02:41 +01:00
llvm-mirror/test/Transforms/InstCombine/shift-trunc-shift.ll
Chris Lattner d64df490ca implement InstCombine/shift-trunc-shift.ll. This allows
us to compile:
#include <math.h>
int t1(double d) { return signbit(d); }

into:

_t1:
	movd	%xmm0, %rax
	shrq	$63, %rax
	ret

instead of:

_t1:
	movd	%xmm0, %rax
	shrq	$32, %rax
	shrl	$31, %eax
	ret

on x86-64.

llvm-svn: 45311
2007-12-22 09:07:47 +00:00

11 lines
273 B
LLVM

; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep lshr.*63
define i32 @t1(i64 %d18) {
entry:
%tmp916 = lshr i64 %d18, 32 ; <i64> [#uses=1]
%tmp917 = trunc i64 %tmp916 to i32 ; <i32> [#uses=1]
%tmp10 = lshr i32 %tmp917, 31 ; <i32> [#uses=1]
ret i32 %tmp10
}