mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-21 20:12:56 +02:00
74fa421281
LowerSubregs, and fix an x86-64 isel bug that this exposed. SUBREG_TO_REG for x86-64 implicit zero extension is only safe for isel to generate when the source is known to always have zeros in the high 32 bits. The EXTRACT_SUBREG instruction does not clear the high 32 bits. llvm-svn: 54444
11 lines
265 B
LLVM
11 lines
265 B
LLVM
; RUN: llvm-as < %s | llc -march=x86-64 | grep {movl %e.\*, %e.\*} | count 1
|
|
|
|
; Don't eliminate or coalesce away the explicit zero-extension!
|
|
|
|
define i64 @foo(i64 %a) {
|
|
%b = add i64 %a, 4294967295
|
|
%c = and i64 %b, 4294967295
|
|
%d = add i64 %c, 1
|
|
ret i64 %d
|
|
}
|