Chris Lattner | 41f6259 | 2008-04-29 04:29:54 +0000 | [diff] [blame] | 1 | ; PR2094 |
| 2 | ; RUN: llvm-as < %s | llc -march=x86-64 | grep movslq |
Chris Lattner | 3fb2968 | 2008-04-29 04:48:56 +0000 | [diff] [blame] | 3 | ; RUN: llvm-as < %s | llc -march=x86-64 | grep addps |
| 4 | ; RUN: llvm-as < %s | llc -march=x86-64 | grep paddd |
Chris Lattner | 41f6259 | 2008-04-29 04:29:54 +0000 | [diff] [blame] | 5 | ; RUN: llvm-as < %s | llc -march=x86-64 | not grep movq |
| 6 | |
| 7 | target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128" |
| 8 | target triple = "x86_64-apple-darwin8" |
| 9 | |
Chris Lattner | 3fb2968 | 2008-04-29 04:48:56 +0000 | [diff] [blame] | 10 | define i32 @test1(i8* %v, i8* %blk2, i8* %blk1, i32 %stride, i32 %h) nounwind { |
Chris Lattner | 41f6259 | 2008-04-29 04:29:54 +0000 | [diff] [blame] | 11 | %tmp12 = sext i32 %stride to i64 ; <i64> [#uses=1] |
| 12 | %mrv = call {i32, i8*, i8*} asm sideeffect "$0 $1 $2 $3 $4 $5 $6", |
| 13 | "=r,=r,=r,r,r,r,r"( i64 %tmp12, i32 %h, i8* %blk1, i8* %blk2 ) nounwind |
| 14 | %tmp6 = getresult {i32, i8*, i8*} %mrv, 0 |
| 15 | %tmp7 = call i32 asm sideeffect "set $0", |
| 16 | "=r,~{dirflag},~{fpsr},~{flags}"( ) nounwind |
| 17 | ret i32 %tmp7 |
| 18 | } |
Chris Lattner | 3fb2968 | 2008-04-29 04:48:56 +0000 | [diff] [blame] | 19 | |
| 20 | define <4 x float> @test2() nounwind { |
| 21 | %mrv = call {<4 x float>, <4 x float>} asm "set $0, $1", "=x,=x"() |
| 22 | %a = getresult {<4 x float>, <4 x float>} %mrv, 0 |
| 23 | %b = getresult {<4 x float>, <4 x float>} %mrv, 1 |
| 24 | %c = add <4 x float> %a, %b |
| 25 | ret <4 x float> %c |
| 26 | } |
| 27 | |
| 28 | define <4 x i32> @test3() nounwind { |
| 29 | %mrv = call {<4 x i32>, <4 x i32>} asm "set $0, $1", "=x,=x"() |
| 30 | %a = getresult {<4 x i32>, <4 x i32>} %mrv, 0 |
| 31 | %b = getresult {<4 x i32>, <4 x i32>} %mrv, 1 |
| 32 | %c = add <4 x i32> %a, %b |
| 33 | ret <4 x i32> %c |
| 34 | } |
| 35 | |