[rtsan] Add fork/execve interceptors (#117198)
[llvm-project.git] / llvm / test / Transforms / Reassociate / pr21205.ll
blobfb47055fe73cf766854918fe81bbdfd0e94c95f2
1 ; RUN: opt -passes=reassociate -S < %s | FileCheck %s
2 ; PR21205
4 @a = common global i32 0, align 4
5 @b = common global i32 0, align 4
7 ; Don't canonicalize %conv - undef into %conv + (-undef).
8 ; CHECK-LABEL: @test1
9 ; CHECK: %sub = fsub fast float %conv, undef
10 ; CHECK: %sub1 = fadd fast float %sub, -1.000000e+00
12 define i32 @test1() {
13 entry:
14   %0 = load i32, ptr @a, align 4
15   %conv = sitofp i32 %0 to float
16   %sub = fsub fast float %conv, undef
17   %sub1 = fadd fast float %sub, -1.000000e+00
18   %conv2 = fptosi float %sub1 to i32
19   store i32 %conv2, ptr @b, align 4
20   ret i32 undef