diff options
author | Otto Moerbeek <otto@cvs.openbsd.org> | 2007-10-12 17:03:15 +0000 |
---|---|---|
committer | Otto Moerbeek <otto@cvs.openbsd.org> | 2007-10-12 17:03:15 +0000 |
commit | f5ce27c4f4636e3e219a50464b29e5dcaa32e5f6 (patch) | |
tree | f638e88b52b848a8b9b987dffedc690543cdff58 /usr.bin | |
parent | 9a4cf8c7573bdb9fcde8278947550bab257493c7 (diff) |
fix va_arg in conditional expressions; from ragge@
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/pcc/ccom/pftn.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/usr.bin/pcc/ccom/pftn.c b/usr.bin/pcc/ccom/pftn.c index 9d2ddef2a2c..7e62929917d 100644 --- a/usr.bin/pcc/ccom/pftn.c +++ b/usr.bin/pcc/ccom/pftn.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pftn.c,v 1.2 2007/10/07 18:34:41 otto Exp $ */ +/* $OpenBSD: pftn.c,v 1.3 2007/10/12 17:03:14 otto Exp $ */ /* * Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -2046,7 +2046,7 @@ bad: static NODE * builtin_va_arg(NODE *f, NODE *a) { - NODE *p, *q, *r; + NODE *p, *q, *r, *rv; int sz, nodnum; /* check num args and type */ @@ -2058,15 +2058,15 @@ builtin_va_arg(NODE *f, NODE *a) p = tcopy(a->n_left); q = tempnode(0, p->n_type, p->n_df, p->n_sue); nodnum = q->n_lval; - ecomp(buildtree(ASSIGN, q, p)); /* done! */ + rv = buildtree(ASSIGN, q, p); r = a->n_right; sz = tsize(r->n_type, r->n_df, r->n_sue)/SZCHAR; /* add one to ap */ #ifdef BACKAUTO - ecomp(buildtree(PLUSEQ, a->n_left, bcon(sz))); + rv = buildtree(COMOP, rv , buildtree(PLUSEQ, a->n_left, bcon(sz))); #else - /* XXX fix this; wrong order */ +#error fix wrong eval order in builtin_va_arg ecomp(buildtree(MINUSEQ, a->n_left, bcon(sz))); #endif @@ -2074,7 +2074,7 @@ builtin_va_arg(NODE *f, NODE *a) nfree(a); nfree(f); r = tempnode(nodnum, INCREF(r->n_type), r->n_df, r->n_sue); - return buildtree(UMUL, r, NIL); + return buildtree(COMOP, rv, buildtree(UMUL, r, NIL)); bad: uerror("bad argument to __builtin_va_arg"); return bcon(0); |