[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / GlobalOpt / evaluate-constfold-call.ll
blob83d8bc6e7c24fba74fd12a34c455aa94098a460b
1 ; Check if we can evaluate a bitcasted call to a function which is constant folded.
2 ; Evaluator folds call to fmodf, replacing it with constant value in case both operands
3 ; are known at compile time.
4 ; RUN: opt -passes=globalopt,instcombine %s -S -o - | FileCheck %s
6 ; CHECK:        @_q = dso_local local_unnamed_addr global %struct.Q { i32 1066527622 }
7 ; CHECK:        define dso_local i32 @main
8 ; CHECK-NEXT:     %[[V:.+]] = load i32, ptr @_q
9 ; CHECK-NEXT:     ret i32 %[[V]]
11 source_filename = "main.cpp"
12 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
13 target triple = "x86_64-none-linux-gnu"
15 %struct.Q = type { i32 }
17 $_ZN1QC2Ev = comdat any
19 @_q = dso_local global %struct.Q zeroinitializer, align 4
20 @llvm.global_ctors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr @_GLOBAL__sub_I_main.cpp, ptr null }]
22 define internal void @__cxx_global_var_init() section ".text.startup" {
23   call void @_ZN1QC2Ev(ptr @_q)
24   ret void
27 define linkonce_odr dso_local void @_ZN1QC2Ev(ptr) unnamed_addr #1 comdat align 2 {
28   %2 = alloca ptr, align 8
29   store ptr %0, ptr %2, align 8
30   %3 = load ptr, ptr %2, align 8
31   %4 = call i32 @fmodf(float 0x40091EB860000000, float 2.000000e+00)
32   store i32 %4, ptr %3, align 4
33   ret void
36 define dso_local i32 @main(i32, ptr) {
37   %3 = alloca i32, align 4
38   %4 = alloca i32, align 4
39   %5 = alloca ptr, align 8
40   store i32 0, ptr %3, align 4
41   store i32 %0, ptr %4, align 4
42   store ptr %1, ptr %5, align 8
43   %6 = load i32, ptr @_q, align 4
44   ret i32 %6
47 ; Function Attrs: nounwind
48 declare dso_local float @fmodf(float, float)
50 ; Function Attrs: noinline uwtable
51 define internal void @_GLOBAL__sub_I_main.cpp() section ".text.startup" {
52   call void @__cxx_global_var_init()
53   ret void