mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-07 12:30:57 +00:00
de1d8a544c
it swaps the LHS/RHS of a single binop. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@125700 91177308-0d34-0410-b5e6-96231b3b80d8
30 lines
620 B
LLVM
30 lines
620 B
LLVM
; RUN: opt -S -reassociate < %s | FileCheck %s
|
|
; rdar://8944681
|
|
|
|
; Reassociate should clear optional flags like nsw when reassociating.
|
|
|
|
; CHECK: @test0
|
|
; CHECK: %y = add i64 %b, %a
|
|
; CHECK: %z = add i64 %y, %c
|
|
define i64 @test0(i64 %a, i64 %b, i64 %c) {
|
|
%y = add nsw i64 %c, %b
|
|
%z = add i64 %y, %a
|
|
ret i64 %z
|
|
}
|
|
|
|
; CHECK: @test1
|
|
; CHECK: %y = add i64 %b, %a
|
|
; CHECK: %z = add i64 %y, %c
|
|
define i64 @test1(i64 %a, i64 %b, i64 %c) {
|
|
%y = add i64 %c, %b
|
|
%z = add nsw i64 %y, %a
|
|
ret i64 %z
|
|
}
|
|
|
|
; PR9215
|
|
; CHECK: %s = add nsw i32 %y, %x
|
|
define i32 @test2(i32 %x, i32 %y) {
|
|
%s = add nsw i32 %x, %y
|
|
ret i32 %s
|
|
}
|