diff options
author | Russ Cox <rsc@golang.org> | 2010-03-04 15:34:25 -0800 |
---|---|---|
committer | Russ Cox <rsc@golang.org> | 2010-03-04 15:34:25 -0800 |
commit | ced760b64147d6c9e41619dd1c51626ff770d9ad (patch) | |
tree | 727ed97d2f2b8ca6628785f51b8bd79220ceeb8d /src/cmd | |
parent | fbed511d5c2a061457f2a652ce75baba05bd035e (diff) | |
download | golang-ced760b64147d6c9e41619dd1c51626ff770d9ad.tar.gz |
cc: disallow ... argument unless NOSPLIT is set.
check that NOSPLIT functions don't use too much stack.
correct some missing NOSPLITs in the runtime library.
Fixes bug reported in
https://groups.google.com/group/golang-nuts/t/efff68b73941eccf
R=ken2
CC=golang-dev
http://codereview.appspot.com/236041
Diffstat (limited to 'src/cmd')
-rw-r--r-- | src/cmd/5c/sgen.c | 10 | ||||
-rw-r--r-- | src/cmd/6c/sgen.c | 8 | ||||
-rw-r--r-- | src/cmd/8c/sgen.c | 10 | ||||
-rw-r--r-- | src/cmd/cc/pgen.c | 1 |
4 files changed, 25 insertions, 4 deletions
diff --git a/src/cmd/5c/sgen.c b/src/cmd/5c/sgen.c index 1584ecff3..92a0f64f8 100644 --- a/src/cmd/5c/sgen.c +++ b/src/cmd/5c/sgen.c @@ -34,9 +34,17 @@ Prog* gtext(Sym *s, int32 stkoff) { + int32 a; + + a = 0; + if(!(textflag & NOSPLIT)) + a = argsize(); + else if(stkoff >= 128) + yyerror("stack frame too large for NOSPLIT function"); + gpseudo(ATEXT, s, nodconst(stkoff)); p->to.type = D_CONST2; - p->to.offset2 = argsize(); + p->to.offset2 = a; return p; } diff --git a/src/cmd/6c/sgen.c b/src/cmd/6c/sgen.c index 1a5987f09..b8247a1b7 100644 --- a/src/cmd/6c/sgen.c +++ b/src/cmd/6c/sgen.c @@ -34,9 +34,13 @@ Prog* gtext(Sym *s, int32 stkoff) { vlong v; - - v = argsize() << 32; + + v = 0; + if(!(textflag & NOSPLIT)) + v |= argsize() << 32; v |= stkoff & 0xffffffff; + if((textflag & NOSPLIT) && stkoff >= 128) + yyerror("stack frame too large for NOSPLIT function"); gpseudo(ATEXT, s, nodgconst(v, types[TVLONG])); return p; diff --git a/src/cmd/8c/sgen.c b/src/cmd/8c/sgen.c index c4f91987c..b0f2bc544 100644 --- a/src/cmd/8c/sgen.c +++ b/src/cmd/8c/sgen.c @@ -33,9 +33,17 @@ Prog* gtext(Sym *s, int32 stkoff) { + int32 a; + + a = 0; + if(!(textflag & NOSPLIT)) + a = argsize(); + else if(stkoff >= 128) + yyerror("stack frame too large for NOSPLIT function"); + gpseudo(ATEXT, s, nodconst(stkoff)); p->to.type = D_CONST2; - p->to.offset2 = argsize(); + p->to.offset2 = a; return p; } diff --git a/src/cmd/cc/pgen.c b/src/cmd/cc/pgen.c index d430ec91b..cd6fffc57 100644 --- a/src/cmd/cc/pgen.c +++ b/src/cmd/cc/pgen.c @@ -43,6 +43,7 @@ argsize(void) case TVOID: break; case TDOT: + yyerror("function takes ... without textflag NOSPLIT"); s += 64; break; default: |