blob: ad929849ae83d5cecb0c603b7618ebfd8a327f1f [file] [log] [blame]
Venkatraman Govindaraju0510db02013-11-24 17:41:41 +00001; RUN: llc -march=sparc < %s | FileCheck %s --check-prefix=V8
2; RUN: llc -march=sparcv9 < %s | FileCheck %s --check-prefix=SPARC64
Venkatraman Govindaraju641b0b52013-05-17 15:14:34 +00003
Venkatraman Govindaraju0510db02013-11-24 17:41:41 +00004; V8-LABEL: variable_alloca_with_adj_call_stack
5; V8: save %sp, -96, %sp
James Y Knight2e64b8b2016-10-25 22:13:28 +00006; (this should ideally be doing "add 4+7; and -8", instead of
7; "add 7; and -8; add 8"; see comments in LowerDYNAMIC_STACKALLOC)
8; V8: add %i0, 7, %i0
9; V8-NEXT: and %i0, -8, %i0
10; V8-NEXT: add %i0, 8, %i0
11; V8-NEXT: sub %sp, %i0, %i0
12; V8-NEXT: add %i0, 96, %o0
Venkatraman Govindaraju0510db02013-11-24 17:41:41 +000013; V8: add %sp, -16, %sp
14; V8: call foo
15; V8: add %sp, 16, %sp
16
17; SPARC64-LABEL: variable_alloca_with_adj_call_stack
18; SPARC64: save %sp, -128, %sp
Venkatraman Govindaraju61116e72013-12-09 05:13:25 +000019; SPARC64: add {{.+}}, 2175, %o0
Venkatraman Govindaraju0510db02013-11-24 17:41:41 +000020; SPARC64: add %sp, -80, %sp
21; SPARC64: call foo
22; SPARC64: add %sp, 80, %sp
23
Venkatraman Govindaraju641b0b52013-05-17 15:14:34 +000024define void @variable_alloca_with_adj_call_stack(i32 %num) {
25entry:
26 %0 = alloca i8, i32 %num, align 8
27 call void @foo(i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0)
28 ret void
29}
30
James Y Knight2e64b8b2016-10-25 22:13:28 +000031declare void @foo(i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*);