mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-13 21:05:16 +00:00
7f40dea2f1
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48530 91177308-0d34-0410-b5e6-96231b3b80d8
14 lines
428 B
LLVM
14 lines
428 B
LLVM
; With sub reassociation, constant folding can eliminate the two 12 constants.
|
|
;
|
|
; RUN: llvm-as < %s | opt -reassociate -constprop -dce | llvm-dis | not grep 12
|
|
|
|
define i32 @test(i32 %A, i32 %B, i32 %C, i32 %D) {
|
|
%M = add i32 %A, 12 ; <i32> [#uses=1]
|
|
%N = add i32 %M, %B ; <i32> [#uses=1]
|
|
%O = add i32 %N, %C ; <i32> [#uses=1]
|
|
%P = sub i32 %D, %O ; <i32> [#uses=1]
|
|
%Q = add i32 %P, 12 ; <i32> [#uses=1]
|
|
ret i32 %Q
|
|
}
|
|
|