summaryrefslogtreecommitdiff
path: root/usr.bin/pcc/ccom/pftn.c
diff options
context:
space:
mode:
authorOtto Moerbeek <otto@cvs.openbsd.org>2007-10-20 09:58:01 +0000
committerOtto Moerbeek <otto@cvs.openbsd.org>2007-10-20 09:58:01 +0000
commit37e9c6566685d49ea05d3a52174f820450d5e06b (patch)
tree08485b5b0f320fa8a85e26a6a1702a76de614fb5 /usr.bin/pcc/ccom/pftn.c
parent048eb9c886bddbf730bd790d929e242b218b1bfd (diff)
Pull from master repo; commit by gmcgarry
>Fix -Xp (prototype debug) which was interpretting structs/unions/enums >as arrays. Fix compile with TARGET_STDARGS.
Diffstat (limited to 'usr.bin/pcc/ccom/pftn.c')
-rw-r--r--usr.bin/pcc/ccom/pftn.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/usr.bin/pcc/ccom/pftn.c b/usr.bin/pcc/ccom/pftn.c
index baab75fcdbf..88ae5dac63e 100644
--- a/usr.bin/pcc/ccom/pftn.c
+++ b/usr.bin/pcc/ccom/pftn.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pftn.c,v 1.4 2007/10/18 17:02:11 otto Exp $ */
+/* $OpenBSD: pftn.c,v 1.5 2007/10/20 09:58:00 otto Exp $ */
/*
* Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se).
* All rights reserved.
@@ -1890,8 +1890,10 @@ arglist(NODE *n)
if (k > num)
cerror("arglist: k%d > num%d", k, num);
tfree(n);
+#ifdef PCC_DEBUG
if (pdebug)
alprint(al, 0);
+#endif
return al;
}
@@ -2110,10 +2112,12 @@ static struct bitable {
NODE *(*fun)(NODE *f, NODE *a);
} bitable[] = {
{ "__builtin_alloca", builtin_alloca },
+#ifndef TARGET_STDARGS
{ "__builtin_stdarg_start", builtin_stdarg_start },
{ "__builtin_va_arg", builtin_va_arg },
{ "__builtin_va_end", builtin_va_end },
{ "__builtin_va_copy", builtin_va_copy },
+#endif
#ifdef TARGET_BUILTINS
TARGET_BUILTINS
#endif
@@ -2134,16 +2138,18 @@ alprint(union arglist *al, int in)
printf(" ");
printf("arg %d: ", i++);
tprint(stdout, al->type, 0);
- if (BTYPE(al->type) == STRTY ||
+ if (ISARY(al->type)) {
+ printf(" dim %d\n", al->df->ddim);
+ } else if (BTYPE(al->type) == STRTY ||
BTYPE(al->type) == UNIONTY || BTYPE(al->type) == ENUMTY) {
al++;
- printf("dim %d\n", al->df->ddim);
- }
- printf("\n");
- if (ISFTN(DECREF(al->type))) {
+ printf(" (size %d align %d)", al->sue->suesize,
+ al->sue->suealign);
+ } else if (ISFTN(DECREF(al->type))) {
al++;
alprint(al->df->dfun, in+1);
}
+ printf("\n");
}
if (in == 0)
printf("end arglist\n");