; RUN: opt < %s -passes=instcombine -S | FileCheck %s ; ; Check that SimplifyLibCalls do not (crash or) emit a library call if user ; has made a function alias with the same name. %struct._IO_FILE = type { i32, ptr, ptr, ptr, ptr, ptr, ptr, ptr, ptr, ptr, ptr, ptr, ptr, ptr, i32, i32, i64, i16, i8, [1 x i8], ptr, i64, ptr, ptr, ptr, ptr, i64, i32, [20 x i8] } %struct._IO_marker = type { ptr, ptr, i32 } @stderr = external global ptr, align 8 @.str = private constant [8 x i8] c"crash!\0A\00", align 1 @fwrite = alias i64 (ptr, i64, i64, ptr), ptr @__fwrite_alias define i64 @__fwrite_alias(ptr %ptr, i64 %size, i64 %n, ptr %s) { ; CHECK-LABEL: @__fwrite_alias( ; CHECK-NEXT: entry: ; CHECK-NEXT: ret i64 0 ; entry: %ptr.addr = alloca ptr, align 8 %size.addr = alloca i64, align 8 %n.addr = alloca i64, align 8 %s.addr = alloca ptr, align 8 store ptr %ptr, ptr %ptr.addr, align 8 store i64 %size, ptr %size.addr, align 8 store i64 %n, ptr %n.addr, align 8 store ptr %s, ptr %s.addr, align 8 ret i64 0 } define void @foo() { ; CHECK-LABEL: @foo( ; CHECK-NOT: call i64 @fwrite( ; CHECK: call {{.*}} @fprintf( ; entry: %retval = alloca i32, align 4 store i32 0, ptr %retval, align 4 %0 = load ptr, ptr @stderr, align 8 %call = call i32 (ptr, ptr, ...) @fprintf(ptr %0, ptr @.str) ret void } declare i32 @fprintf(ptr, ptr, ...)