Shrink Thumb2 movcc instructions.
[llvm/avr.git] / test / CodeGen / X86 / byval2.ll
blobf85c8ffbe4fe7352149b68aa96fa8135b974bf84
1 ; RUN: llvm-as < %s | llc -march=x86-64 | grep rep.movsq | count 2
2 ; RUN: llvm-as < %s | llc -march=x86    | grep rep.movsl | count 2
4 %struct.s = type { i64, i64, i64, i64, i64, i64, i64, i64,
5                    i64, i64, i64, i64, i64, i64, i64, i64,
6                    i64 }
8 define void @g(i64 %a, i64 %b, i64 %c) {
9 entry:
10         %d = alloca %struct.s, align 16
11         %tmp = getelementptr %struct.s* %d, i32 0, i32 0
12         store i64 %a, i64* %tmp, align 16
13         %tmp2 = getelementptr %struct.s* %d, i32 0, i32 1
14         store i64 %b, i64* %tmp2, align 16
15         %tmp4 = getelementptr %struct.s* %d, i32 0, i32 2
16         store i64 %c, i64* %tmp4, align 16
17         call void @f( %struct.s* %d byval)
18         call void @f( %struct.s* %d byval)
19         ret void
22 declare void @f(%struct.s* byval)