Optimized FCMP_OEQ and FCMP_UNE for x86.
[oota-llvm.git] / test / CodeGen / X86 / 2006-11-28-Memcpy.ll
1 ; PR1022, PR1023
2 ; RUN: llvm-as < %s | llc -march=x86 | \
3 ; RUN:   grep 3721182122 | count 2
4 ; RUN: llvm-as < %s | llc -march=x86 | \
5 ; RUN:   grep -E {movl  _?bytes2} | count 1
6
7 @fmt = constant [4 x i8] c"%x\0A\00"            ; <[4 x i8]*> [#uses=2]
8 @bytes = constant [4 x i8] c"\AA\BB\CC\DD"              ; <[4 x i8]*> [#uses=1]
9 @bytes2 = global [4 x i8] c"\AA\BB\CC\DD"               ; <[4 x i8]*> [#uses=1]
10
11 define i32 @test1() nounwind {
12         %y = alloca i32         ; <i32*> [#uses=2]
13         %c = bitcast i32* %y to i8*             ; <i8*> [#uses=1]
14         %z = getelementptr [4 x i8]* @bytes, i32 0, i32 0               ; <i8*> [#uses=1]
15         call void @llvm.memcpy.i32( i8* %c, i8* %z, i32 4, i32 1 )
16         %r = load i32* %y               ; <i32> [#uses=1]
17         %t = bitcast [4 x i8]* @fmt to i8*              ; <i8*> [#uses=1]
18         %tmp = call i32 (i8*, ...)* @printf( i8* %t, i32 %r )           ; <i32> [#uses=0]
19         ret i32 0
20 }
21
22 define void @test2() nounwind {
23         %y = alloca i32         ; <i32*> [#uses=2]
24         %c = bitcast i32* %y to i8*             ; <i8*> [#uses=1]
25         %z = getelementptr [4 x i8]* @bytes2, i32 0, i32 0              ; <i8*> [#uses=1]
26         call void @llvm.memcpy.i32( i8* %c, i8* %z, i32 4, i32 1 )
27         %r = load i32* %y               ; <i32> [#uses=1]
28         %t = bitcast [4 x i8]* @fmt to i8*              ; <i8*> [#uses=1]
29         %tmp = call i32 (i8*, ...)* @printf( i8* %t, i32 %r )           ; <i32> [#uses=0]
30         ret void
31 }
32
33 declare void @llvm.memcpy.i32(i8*, i8*, i32, i32)
34
35 declare i32 @printf(i8*, ...)
36