mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-08 21:32:39 +00:00
The long awaited CAST patch. This introduces 12 new instructions into LLVM to replace the cast instruction. Corresponding changes throughout LLVM are provided. This passes llvm-test, llvm/test, and SPEC CPUINT2000 with the exception of 175.vpr which fails only on a slight floating point output difference. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31931 91177308-0d34-0410-b5e6-96231b3b80d8
10 lines
321 B
LLVM
10 lines
321 B
LLVM
; The optimizer should be able to remove cast operation here.
|
|
; RUN: llvm-as %s -o - | opt -instcombine | llvm-dis | not grep 'sext.*int'
|
|
|
|
bool %eq_signed_to_small_unsigned(sbyte %SB) {
|
|
%Y = cast sbyte %SB to uint ; <uint> [#uses=1]
|
|
%C = seteq uint %Y, 17 ; <bool> [#uses=1]
|
|
ret bool %C
|
|
}
|
|
|