mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-10-11 07:24:06 +00:00
3da59db637
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
18 lines
618 B
LLVM
18 lines
618 B
LLVM
; This file contains various testcases that check to see that instcombine
|
|
; is narrowing computations when possible.
|
|
|
|
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep 'ret bool false'
|
|
|
|
; test1 - Eliminating the casts in this testcase (by narrowing the AND
|
|
; operation) allows instcombine to realize the function always returns false.
|
|
;
|
|
bool %test1(int %A, int %B) {
|
|
%C1 = setlt int %A, %B
|
|
%ELIM1 = zext bool %C1 to uint
|
|
%C2 = setgt int %A, %B
|
|
%ELIM2 = zext bool %C2 to uint
|
|
%C3 = and uint %ELIM1, %ELIM2
|
|
%ELIM3 = trunc uint %C3 to bool
|
|
ret bool %ELIM3
|
|
}
|