b53c6a3766754fe6d69f92ea00fef6531832c011
[oota-llvm.git] / test / CodeGen / X86 / 2006-11-28-Memcpy.ll
1 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 &&
2 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep 3721182122 | wc -l | grep 2 &&
3 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep -E 'movl _?bytes2' | wc -l | grep 1
4 ; PR1022, 1023
5
6 %fmt = constant [4 x sbyte] c"%x\0A\00"
7 %bytes = constant [4 x sbyte] c"\AA\BB\CC\DD"
8 %bytes2 = global [4 x sbyte] c"\AA\BB\CC\DD"
9
10
11 int %test1() {
12         %y = alloca uint
13         %c = cast uint* %y to sbyte*
14         %z = getelementptr [4 x sbyte]* %bytes, int 0, int 0
15         call void %llvm.memcpy.i32( sbyte* %c, sbyte* %z, uint 4, uint 1 )
16         %r = load uint* %y
17         %t = cast [4 x sbyte]* %fmt to sbyte*
18         %tmp = call int (sbyte*, ...)* %printf( sbyte* %t, uint %r )
19         ret int 0
20 }
21
22 void %test2() {
23         %y = alloca uint
24         %c = cast uint* %y to sbyte*
25         %z = getelementptr [4 x sbyte]* %bytes2, int 0, int 0
26         call void %llvm.memcpy.i32( sbyte* %c, sbyte* %z, uint 4, uint 1 )
27         %r = load uint* %y
28         %t = cast [4 x sbyte]* %fmt to sbyte*
29         %tmp = call int (sbyte*, ...)* %printf( sbyte* %t, uint %r )
30         ret void
31 }
32
33 declare void %llvm.memcpy.i32(sbyte*, sbyte*, uint, uint)
34 declare int %printf(sbyte*, ...)