1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-22 12:33:33 +02:00
llvm-mirror/test/CodeGen/X86/wide-integer-fold.ll
Dan Gohman 01b8a3593b Fix a few places in DAGCombiner that were creating all-ones-bits
and high-bits values in ways that weren't correct for integer
types wider than 64 bits. This fixes a miscompile in
PPMacroExpansion.cpp in clang on x86-64.

llvm-svn: 78295
2009-08-06 09:18:59 +00:00

13 lines
375 B
LLVM

; RUN: llvm-as < %s | llc -march=x86-64 | FileCheck %s
; CHECK: movq $-65535, %rax
; DAGCombiner should fold this to a simple constant.
define i64 @foo(i192 %a) nounwind {
%t = or i192 %a, -22300404916163702203072254898040925442801665
%s = and i192 %t, -22300404916163702203072254898040929737768960
%u = lshr i192 %s, 128
%v = trunc i192 %u to i64
ret i64 %v
}