mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-10 14:12:11 +00:00
8047d9a6be
SDISel. This optimization was causing simplifylibcalls to introduce type-unsafe nastiness. This is the first step, I'll be expanding the memcmp optimizations shortly, covering things that we really really wouldn't want simplifylibcalls to do. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@92098 91177308-0d34-0410-b5e6-96231b3b80d8
24 lines
952 B
LLVM
24 lines
952 B
LLVM
; Test that the memcmpOptimizer works correctly
|
|
; RUN: opt < %s -simplify-libcalls -S | not grep {call.*memcmp}
|
|
|
|
@h = constant [2 x i8] c"h\00" ; <[2 x i8]*> [#uses=0]
|
|
@hel = constant [4 x i8] c"hel\00" ; <[4 x i8]*> [#uses=0]
|
|
@hello_u = constant [8 x i8] c"hello_u\00" ; <[8 x i8]*> [#uses=0]
|
|
|
|
declare i32 @memcmp(i8*, i8*, i32)
|
|
|
|
define void @test(i8* %P, i8* %Q, i32 %N, i32* %IP, i1* %BP) {
|
|
%A = call i32 @memcmp( i8* %P, i8* %P, i32 %N ) ; <i32> [#uses=1]
|
|
volatile store i32 %A, i32* %IP
|
|
%B = call i32 @memcmp( i8* %P, i8* %Q, i32 0 ) ; <i32> [#uses=1]
|
|
volatile store i32 %B, i32* %IP
|
|
%C = call i32 @memcmp( i8* %P, i8* %Q, i32 1 ) ; <i32> [#uses=1]
|
|
volatile store i32 %C, i32* %IP
|
|
%F = call i32 @memcmp(i8* getelementptr ([4 x i8]* @hel, i32 0, i32 0),
|
|
i8* getelementptr ([8 x i8]* @hello_u, i32 0, i32 0),
|
|
i32 3)
|
|
volatile store i32 %F, i32* %IP
|
|
ret void
|
|
}
|
|
|