aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-08-04 02:11:05 +0000
committerChris Lattner <sabre@nondot.org>2003-08-04 02:11:05 +0000
commit1913c112f51ae78cf3ec69d81e3a3a9f6f4c014b (patch)
treeec77a3a274e2f39162c658e5c9260ab44410763b
parent72feb155632c5af1b2e7a28b38d4840916043cdb (diff)
New testcase
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7557 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--test/CodeGen/X86/2003-08-03-CallArgLiveRanges.llx15
1 files changed, 15 insertions, 0 deletions
diff --git a/test/CodeGen/X86/2003-08-03-CallArgLiveRanges.llx b/test/CodeGen/X86/2003-08-03-CallArgLiveRanges.llx
new file mode 100644
index 0000000000..c3f4635236
--- /dev/null
+++ b/test/CodeGen/X86/2003-08-03-CallArgLiveRanges.llx
@@ -0,0 +1,15 @@
+; The old instruction selector used to load all arguments to a call up in
+; registers, then start pushing them all onto the stack. This is bad news as
+; it makes a ton of annoying overlapping live ranges. This code should not
+; cause spills!
+;
+; RUN: as < %s | lli -stats 2>&1 | not grep spilled
+
+target endian = little
+target pointersize = 32
+
+int %test(int, int, int, int, int, int, int, int, int, int) { ret int 0 }
+int %main() {
+ %X = call int %test(int 1, int 2, int 3, int 4, int 5, int 6, int 7, int 8, int 9, int 10)
+ ret int %X
+}