; RUN: opt %s -passes='default<O0>,globalopt' -S -o - ; This is a regression test against very slow execution... ; In bad case it should fail by timeout. ; Hand-reduced from this example. ; clang++ -mllvm -disable-llvm-optzns ;#include <stdio.h> ; ;namespace { ; char LargeBuffer[64 * 1024 * 1024]; ;} ; ;int main ( void ) { ; ; LargeBuffer[0] = 0; ; ; printf(""); ; ; return LargeBuffer[0] == 0; ;} ; check that global array LargeBufferE was optimized out ; and local variable LargeBufferE.0 was used instead. ; CHECK-NOT: global ; CHECK: main() ; CHECK-NEXT: LargeBufferE.0 ; CHECK-NOT: global ; ModuleID = 'test.cpp' source_filename = "test.cpp" target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-unknown-linux-gnu" @LargeBufferE = internal global [67108864 x i8] zeroinitializer, align 16 @.str = private unnamed_addr constant [1 x i8] c"\00", align 1 ; Function Attrs: norecurse uwtable define dso_local i32 @main() #0 { %1 = alloca i32, align 4 store i32 0, i32* %1, align 4 store i8 0, i8* getelementptr inbounds ([67108864 x i8], [67108864 x i8]* @LargeBufferE, i64 0, i64 0), align 16 %2 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([1 x i8], [1 x i8]* @.str, i64 0, i64 0)) %3 = load i8, i8* getelementptr inbounds ([67108864 x i8], [67108864 x i8]* @LargeBufferE, i64 0, i64 0), align 16 %4 = sext i8 %3 to i32 %5 = icmp eq i32 %4, 0 %6 = zext i1 %5 to i32 ret i32 %6 } declare dso_local i32 @printf(i8*, ...) #0 attributes #0 = { norecurse uwtable } !llvm.module.flags = !{!0} !llvm.ident = !{!1} !0 = !{i32 1, !"wchar_size", i32 4} !1 = !{!"clang version 10.0.0 "}