forked from OSchip/llvm-project
22 lines
881 B
LLVM
22 lines
881 B
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt < %s -instcombine -S | FileCheck %s
|
|
|
|
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
|
|
|
|
@hello_world = constant [13 x i8] c"hello world\0A\00"
|
|
|
|
declare void @sprintf(i8*, i8*, ...)
|
|
|
|
; Check that a sprintf call, that would otherwise be optimized, but with
|
|
; optimized out return type, doesn't crash the optimizer.
|
|
|
|
define void @test_simplify1(i8* %dst) {
|
|
; CHECK-LABEL: @test_simplify1(
|
|
; CHECK-NEXT: call void (i8*, i8*, ...) @sprintf(i8* [[DST:%.*]], i8* getelementptr inbounds ([13 x i8], [13 x i8]* @hello_world, i32 0, i32 0))
|
|
; CHECK-NEXT: ret void
|
|
;
|
|
%fmt = getelementptr [13 x i8], [13 x i8]* @hello_world, i32 0, i32 0
|
|
call void (i8*, i8*, ...) @sprintf(i8* %dst, i8* %fmt)
|
|
ret void
|
|
}
|