mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
e3d920699c
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. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54444 91177308-0d34-0410-b5e6-96231b3b80d8
12 lines
275 B
LLVM
12 lines
275 B
LLVM
; RUN: llvm-as < %s | llc -march=x86-64 | grep mov | count 1
|
|
|
|
; Do eliminate the zero-extension instruction and rely on
|
|
; x86-64's implicit zero-extension!
|
|
|
|
define i64 @foo(i32* %p) nounwind {
|
|
%t = load i32* %p
|
|
%n = add i32 %t, 1
|
|
%z = zext i32 %n to i64
|
|
ret i64 %z
|
|
}
|