| Jan Wen Voung | 6dc3076 | 2013-03-12 16:27:52 +0000 | [diff] [blame^] | 1 | ; REQUIRES: asserts | 
| Chris Lattner | bd81d11 | 2003-08-04 02:11:05 +0000 | [diff] [blame] | 2 | ; The old instruction selector used to load all arguments to a call up in | 
|  | 3 | ; registers, then start pushing them all onto the stack.  This is bad news as | 
|  | 4 | ; it makes a ton of annoying overlapping live ranges.  This code should not | 
|  | 5 | ; cause spills! | 
|  | 6 | ; | 
| Chandler Carruth | 5da5343 | 2012-07-02 18:37:59 +0000 | [diff] [blame] | 7 | ; RUN: llc < %s -march=x86 -stats 2>&1 | not grep spilled | 
| Chris Lattner | bd81d11 | 2003-08-04 02:11:05 +0000 | [diff] [blame] | 8 |  | 
| Tanya Lattner | 8bf97c2 | 2008-03-25 04:26:08 +0000 | [diff] [blame] | 9 | target datalayout = "e-p:32:32" | 
| Chris Lattner | bd81d11 | 2003-08-04 02:11:05 +0000 | [diff] [blame] | 10 |  | 
| Tanya Lattner | 8bf97c2 | 2008-03-25 04:26:08 +0000 | [diff] [blame] | 11 | define i32 @test(i32, i32, i32, i32, i32, i32, i32, i32, i32, i32) { | 
|  | 12 | ret i32 0 | 
| Chris Lattner | bd81d11 | 2003-08-04 02:11:05 +0000 | [diff] [blame] | 13 | } | 
| Tanya Lattner | 8bf97c2 | 2008-03-25 04:26:08 +0000 | [diff] [blame] | 14 |  | 
|  | 15 | define i32 @main() { | 
|  | 16 | %X = call i32 @test( i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10 )            ; <i32> [#uses=1] | 
|  | 17 | ret i32 %X | 
|  | 18 | } | 
|  | 19 |  |