mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-10 22:46:25 +00:00
bc72c8f0d8
This patch modifies SelectionDAGBuilder to construct SDNodes with associated NoSignedWrap, NoUnsignedWrap and Exact flags coming from IR BinaryOperator instructions. Added a new SDNode type called 'BinaryWithFlagsSDNode' to allow accessing nsw/nuw/exact flags during codegen. Patch by Marcello Maggioni. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@210467 91177308-0d34-0410-b5e6-96231b3b80d8
21 lines
807 B
LLVM
21 lines
807 B
LLVM
; RUN: llc < %s -march=x86-64 | FileCheck %s
|
|
; CHECK: addl
|
|
|
|
; The two additions are the same , but have different flags.
|
|
; In theory this code should never be generated by the frontend, but this
|
|
; tries to test that two identical instructions with two different flags
|
|
; actually generate two different nodes.
|
|
;
|
|
; Normally the combiner would see this condition without the flags
|
|
; and optimize the result of the sub into a register clear
|
|
; (the final result would be 0). With the different flags though the combiner
|
|
; needs to keep the add + sub nodes, because the two nodes result as different
|
|
; nodes and so cannot assume that the subtraction of the two nodes
|
|
; generates 0 as result
|
|
define i32 @foo(i32 %a, i32 %b) {
|
|
%1 = add i32 %a, %b
|
|
%2 = add nsw i32 %a, %b
|
|
%3 = sub i32 %1, %2
|
|
ret i32 %3
|
|
}
|