diff options
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/pcc/nova/code.c | 12 | ||||
-rw-r--r-- | usr.bin/pcc/nova/local2.c | 17 | ||||
-rw-r--r-- | usr.bin/pcc/nova/macdefs.h | 8 | ||||
-rw-r--r-- | usr.bin/pcc/nova/order.c | 10 | ||||
-rw-r--r-- | usr.bin/pcc/pdp10/README | 20 | ||||
-rw-r--r-- | usr.bin/pcc/pdp10/code.c | 11 | ||||
-rw-r--r-- | usr.bin/pcc/pdp10/local.c | 4 | ||||
-rw-r--r-- | usr.bin/pcc/pdp10/local2.c | 14 | ||||
-rw-r--r-- | usr.bin/pcc/pdp10/macdefs.h | 144 | ||||
-rw-r--r-- | usr.bin/pcc/pdp10/order.c | 23 |
10 files changed, 185 insertions, 78 deletions
diff --git a/usr.bin/pcc/nova/code.c b/usr.bin/pcc/nova/code.c index ee390ac99a2..1ffa242c0ad 100644 --- a/usr.bin/pcc/nova/code.c +++ b/usr.bin/pcc/nova/code.c @@ -1,4 +1,4 @@ -/* $OpenBSD: code.c,v 1.3 2007/11/22 15:06:43 stefan Exp $ */ +/* $OpenBSD: code.c,v 1.4 2007/12/22 13:13:27 stefan Exp $ */ /* * Copyright (c) 2006 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -162,16 +162,6 @@ bycode(int t, int i) } /* - * n integer words of zeros - */ -void -zecode(int n) -{ - printf(" .zero %d\n", n * (SZINT/SZCHAR)); - inoff += n * SZINT; -} - -/* * return the alignment of field of type t */ int diff --git a/usr.bin/pcc/nova/local2.c b/usr.bin/pcc/nova/local2.c index 00b90e878f9..8ac79c09c29 100644 --- a/usr.bin/pcc/nova/local2.c +++ b/usr.bin/pcc/nova/local2.c @@ -1,4 +1,4 @@ -/* $OpenBSD: local2.c,v 1.1 2007/10/07 17:58:51 otto Exp $ */ +/* $OpenBSD: local2.c,v 1.2 2007/12/22 13:13:27 stefan Exp $ */ /* * Copyright (c) 2006 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -35,13 +35,6 @@ void acon(NODE *p); int argsize(NODE *p); void -lineid(int l, char *fn) -{ - /* identify line l and file fn */ - printf("# line %d, file %s\n", l, fn); -} - -void deflab(int label) { printf(LABFMT ":\n", label); @@ -561,3 +554,11 @@ special(NODE *p, int shape) { return SRNOPE; } + +/* + * Target-dependent command-line options. + */ +void +mflags(char *str) +{ +} diff --git a/usr.bin/pcc/nova/macdefs.h b/usr.bin/pcc/nova/macdefs.h index 75c41f908d8..72798f3e18a 100644 --- a/usr.bin/pcc/nova/macdefs.h +++ b/usr.bin/pcc/nova/macdefs.h @@ -1,4 +1,4 @@ -/* $OpenBSD: macdefs.h,v 1.1 2007/10/07 17:58:51 otto Exp $ */ +/* $OpenBSD: macdefs.h,v 1.2 2007/12/22 13:13:27 stefan Exp $ */ /* * Copyright (c) 2006 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -119,8 +119,6 @@ typedef long OFFSZ; #define BACKAUTO /* stack grows negatively for automatics */ #define BACKTEMP /* stack grows negatively for temporaries */ -#define MYP2TREE(p) myp2tree(p); - #undef FIELDOPS /* no bit-field instructions */ #define RTOLBYTES /* bytes are numbered right to left */ @@ -189,7 +187,3 @@ int COLORMAP(int c, int *r); /* XXX - to die */ #define FPREG 28 /* frame pointer */ #define STKREG 29 /* stack pointer */ - -#define MYREADER(p) myreader(p) -#define MYCANON(p) mycanon(p) -#define MYOPTIM diff --git a/usr.bin/pcc/nova/order.c b/usr.bin/pcc/nova/order.c index 0d79e82ca9c..6eae2c871c9 100644 --- a/usr.bin/pcc/nova/order.c +++ b/usr.bin/pcc/nova/order.c @@ -1,4 +1,4 @@ -/* $OpenBSD: order.c,v 1.2 2007/11/16 09:00:13 otto Exp $ */ +/* $OpenBSD: order.c,v 1.3 2007/12/22 13:13:27 stefan Exp $ */ /* * Copyright (c) 2006 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -174,3 +174,11 @@ livecall(NODE *p) return &r[0]; } +/* + * Signal whether the instruction is acceptable for this target. + */ +int +acceptable(struct optab *op) +{ + return 1; +} diff --git a/usr.bin/pcc/pdp10/README b/usr.bin/pcc/pdp10/README new file mode 100644 index 00000000000..176eca77d44 --- /dev/null +++ b/usr.bin/pcc/pdp10/README @@ -0,0 +1,20 @@ + + +PDP10 C calling convention +-------------------------- +Register 1-7 are argument registers. Types of sizes up to 36 bits are +given in one register, two otherwise. CHAR and SHORT are given as INTs. + +If the argument that would end up in register 7 requires two registers, +it is saved on the stack instead and no more registers would end up +on the stack. + +struct return: a hidden argument containing the address of the struct +is stored as the first argument _on_the_stack_, never in register. + +struct argument: always saved on stack, and terminates the list +of arguments that are kept in registers. + +In case of debugging all arguments are saved on stack in the function. + +All variadic arguments are always saved on the stack. diff --git a/usr.bin/pcc/pdp10/code.c b/usr.bin/pcc/pdp10/code.c index f52f41d48f7..eb8ac58e2d5 100644 --- a/usr.bin/pcc/pdp10/code.c +++ b/usr.bin/pcc/pdp10/code.c @@ -1,4 +1,4 @@ -/* $OpenBSD: code.c,v 1.3 2007/11/22 15:06:43 stefan Exp $ */ +/* $OpenBSD: code.c,v 1.4 2007/12/22 13:13:06 stefan Exp $ */ /* * Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -226,15 +226,6 @@ bycode(int t, int i) } /* - * n integer words of zeros - */ -void -zecode(int n) -{ - printf(" .block %d\n", n); -} - -/* * return the alignment of field of type t */ int diff --git a/usr.bin/pcc/pdp10/local.c b/usr.bin/pcc/pdp10/local.c index cf95e0f7a8d..2b21bbc654b 100644 --- a/usr.bin/pcc/pdp10/local.c +++ b/usr.bin/pcc/pdp10/local.c @@ -1,4 +1,4 @@ -/* $OpenBSD: local.c,v 1.3 2007/11/18 17:39:55 ragge Exp $ */ +/* $OpenBSD: local.c,v 1.4 2007/12/22 13:13:06 stefan Exp $ */ /* * Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -484,7 +484,6 @@ xptype(TWORD t) case DOUBLE: case STRTY: case UNIONTY: - case ENUMTY: case UNSIGNED: case ULONG: case ULONGLONG: @@ -556,7 +555,6 @@ offcon(OFFSZ off, TWORD t, union dimfun *d, struct suedef *sue) case ULONG: case STRTY: case UNIONTY: - case ENUMTY: case LONGLONG: case ULONGLONG: case FLOAT: diff --git a/usr.bin/pcc/pdp10/local2.c b/usr.bin/pcc/pdp10/local2.c index 66f20913c19..b10ccc08ce4 100644 --- a/usr.bin/pcc/pdp10/local2.c +++ b/usr.bin/pcc/pdp10/local2.c @@ -1,4 +1,4 @@ -/* $OpenBSD: local2.c,v 1.2 2007/11/16 09:00:13 otto Exp $ */ +/* $OpenBSD: local2.c,v 1.3 2007/12/22 13:13:06 stefan Exp $ */ /* * Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -1101,11 +1101,11 @@ optim2(NODE *p) m = BTYPE(p->n_type); ml = BTYPE(l->n_type); if ((m == INT || m == LONG || m == LONGLONG || m == FLOAT || - m == DOUBLE || m == STRTY || m == UNIONTY || m == ENUMTY || + m == DOUBLE || m == STRTY || m == UNIONTY || m == UNSIGNED || m == ULONG || m == ULONGLONG) && (ml == INT || ml == LONG || ml == LONGLONG || ml == FLOAT || ml == DOUBLE || ml == STRTY || ml == UNIONTY || - ml == ENUMTY || ml == UNSIGNED || ml == ULONG || + ml == UNSIGNED || ml == ULONG || ml == ULONGLONG) && ISPTR(l->n_type)) { *p = *l; nfree(l); @@ -1299,3 +1299,11 @@ COLORMAP(int c, int *r) comperr("COLORMAP"); return 0; /* XXX gcc */ } + +/* + * Target-dependent command-line options. + */ +void +mflags(char *str) +{ +} diff --git a/usr.bin/pcc/pdp10/macdefs.h b/usr.bin/pcc/pdp10/macdefs.h index 356c94dcd53..5017ae7b23b 100644 --- a/usr.bin/pcc/pdp10/macdefs.h +++ b/usr.bin/pcc/pdp10/macdefs.h @@ -1,4 +1,4 @@ -/* $OpenBSD: macdefs.h,v 1.1 2007/10/07 17:58:52 otto Exp $ */ +/* $OpenBSD: macdefs.h,v 1.2 2007/12/22 13:13:06 stefan Exp $ */ /* * Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -47,21 +47,25 @@ * Storage space requirements */ #define SZCHAR 9 +#define SZBOOL 36 #define SZINT 36 #define SZFLOAT 36 #define SZDOUBLE 72 +#define SZLDOUBLE 72 #define SZLONG 36 #define SZSHORT 18 -#define SZPOINT 36 +#define SZPOINT(x) 36 #define SZLONGLONG 72 /* * Alignment constraints */ #define ALCHAR 9 +#define ALBOOL 36 #define ALINT 36 #define ALFLOAT 36 #define ALDOUBLE 36 +#define ALLDOUBLE 36 #define ALLONG 36 #define ALLONGLONG 36 #define ALSHORT 18 @@ -72,15 +76,27 @@ /* * Max values. */ +#define MIN_CHAR -256 +#define MAX_CHAR 255 +#define MAX_UCHAR 511 +#define MIN_SHORT -131072 +#define MAX_SHORT 131071 +#define MAX_USHORT 262143 +#define MIN_INT (-0377777777777LL-1) #define MAX_INT 0377777777777LL #define MAX_UNSIGNED 0777777777777ULL +#define MIN_LONG (-0377777777777LL-1) #define MAX_LONG 0377777777777LL #define MAX_ULONG 0777777777777ULL +#define MIN_LONGLONG (000777777777777777777777LL-1) /* XXX cross */ #define MAX_LONGLONG 000777777777777777777777LL /* XXX cross */ #define MAX_ULONGLONG 001777777777777777777777ULL /* XXX cross */ /* Default char is unsigned */ +#define TARGET_STDARGS #define CHAR_UNSIGNED +#define WCHAR_TYPE INT /* what used to store wchar_t */ +#define BOOL_TYPE INT /* * Use large-enough types. @@ -90,23 +106,12 @@ typedef unsigned long long U_CONSZ; typedef long long OFFSZ; #define CONFMT "0%llo" /* format for printing constants */ -#define LABFMT "L%d" /* format for printing labels */ +#define LABFMT ".L%d" /* format for printing labels */ +#define STABLBL ".LL%d" /* format for stab (debugging) labels */ -#define FPREG 016 /* frame pointer */ -#define STKREG 017 /* stack pointer */ - -/* - * Maximum and minimum register variables - */ -#define MINRVAR 010 /* use 10 thru ... */ -#define MAXRVAR 015 /* ... 15 */ - -#define PARAMS_UPWARD /* stack grows upwards for parameters */ #undef BACKAUTO /* stack grows negatively for automatics */ #undef BACKTEMP /* stack grows negatively for temporaries */ -#define MYP2TREE(p) myp2tree(p); - #undef FIELDOPS /* no bit-field instructions */ #undef RTOLBYTES /* bytes are numbered left to right */ @@ -114,9 +119,6 @@ typedef long long OFFSZ; /* Definitions mostly used in pass2 */ -#define REGSZ 020 -#define TMPREG 016 - #define BYTEOFF(x) ((x)&03) #define wdal(k) (BYTEOFF(k)==0) #define BITOOR(x) ((x)/36) /* bit offset to oreg offset */ @@ -133,10 +135,6 @@ typedef long long OFFSZ; ((o) == REG || (o) == NAME || (o) == ICON || \ (o) == OREG || ((o) == UMUL && shumul((p)->n_left))) -#define MYREADER(p) myreader(p) -#define MYCANON(p) mycanon(p) -#define MYOPTIM - #undef SPECIAL_INTEGERS /* @@ -146,3 +144,105 @@ typedef long long OFFSZ; #define SNSHCON (SPECIAL|7) /* negative short constant */ #define SILDB (SPECIAL|8) /* use ildb here */ +/* + * Register allocator definitions. + * + * The pdp10 has 16 general-purpose registers, but the two + * highest are used as sp and fp. Register 0 has special + * constraints in its possible use as index register. + * All regs can be used as pairs, named by the lowest number. + * In here we call the registers Rn and the pairs XRn, in assembler + * just its number prefixed with %. + * + * R1/XR1 are return registers. + * + * R0 is currently not used. + */ + +#define MAXREGS 29 /* 16 + 13 regs */ +#define NUMCLASS 2 + +#define R0 00 +#define R1 01 +#define R2 02 +#define R3 03 +#define R4 04 +#define R5 05 +#define R6 06 +#define R7 07 +#define R10 010 +#define R11 011 +#define R12 012 +#define R13 013 +#define R14 014 +#define R15 015 +#define R16 016 +#define R17 017 +#define FPREG R16 /* frame pointer */ +#define STKREG R17 /* stack pointer */ + + +#define XR0 020 +#define XR1 021 +#define XR2 022 +#define XR3 023 +#define XR4 024 +#define XR5 025 +#define XR6 026 +#define XR7 027 +#define XR10 030 +#define XR11 031 +#define XR12 032 +#define XR13 033 +#define XR14 034 + + +#define RSTATUS \ + 0, SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, \ + SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, \ + SAREG|PERMREG, SAREG|PERMREG, SAREG|PERMREG, SAREG|PERMREG, \ + SAREG|PERMREG, SAREG|PERMREG, 0, 0, \ + SBREG, SBREG, SBREG, SBREG, SBREG, SBREG, SBREG, SBREG, \ + SBREG, SBREG, SBREG, SBREG, SBREG, + +#define ROVERLAP \ + { XR0, -1 }, \ + { XR0, XR1, -1 }, \ + { XR1, XR2, -1 }, \ + { XR2, XR3, -1 }, \ + { XR3, XR4, -1 }, \ + { XR4, XR5, -1 }, \ + { XR5, XR6, -1 }, \ + { XR6, XR7, -1 }, \ + { XR7, XR10, -1 }, \ + { XR10, XR11, -1 }, \ + { XR11, XR12, -1 }, \ + { XR12, XR13, -1 }, \ + { XR13, XR14, -1 }, \ + { XR14, -1 }, \ + { -1 }, \ + { -1 }, \ + { R0, R1, XR1, -1 }, \ + { R1, R2, XR0, XR2, -1 }, \ + { R2, R3, XR1, XR3, -1 }, \ + { R3, R4, XR2, XR4, -1 }, \ + { R4, R5, XR3, XR5, -1 }, \ + { R5, R6, XR4, XR6, -1 }, \ + { R6, R7, XR5, XR7, -1 }, \ + { R7, R10, XR6, XR10, -1 }, \ + { R10, R11, XR7, XR11, -1 }, \ + { R11, R12, XR10, XR12, -1 }, \ + { R12, R13, XR11, XR13, -1 }, \ + { R13, R14, XR12, XR14, -1 }, \ + { R14, R15, XR13, -1 }, + +/* Return a register class based on the type of the node */ +#define PCLASS(p) (szty(p->n_type) == 2 ? SBREG : SAREG) +#define RETREG(x) (szty(x) == 2 ? XR1 : R1) +#define DECRA(x,y) (((x) >> (y*6)) & 63) /* decode encoded regs */ +#define ENCRD(x) (x) /* Encode dest reg in n_reg */ +#define ENCRA1(x) ((x) << 6) /* A1 */ +#define ENCRA2(x) ((x) << 12) /* A2 */ +#define ENCRA(x,y) ((x) << (6+y*6)) /* encode regs in int */ +#define GCLASS(x) (x < 16 ? CLASSA : CLASSB) +int COLORMAP(int c, int *r); diff --git a/usr.bin/pcc/pdp10/order.c b/usr.bin/pcc/pdp10/order.c index becaa5caeba..d56f295121c 100644 --- a/usr.bin/pcc/pdp10/order.c +++ b/usr.bin/pcc/pdp10/order.c @@ -1,4 +1,4 @@ -/* $OpenBSD: order.c,v 1.2 2007/11/16 09:00:13 otto Exp $ */ +/* $OpenBSD: order.c,v 1.3 2007/12/22 13:13:06 stefan Exp $ */ /* * Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se). * All rights reserved. @@ -82,18 +82,6 @@ offstar(NODE *p, int shape) } /* - * Rewrite increment/decrement operation. - */ -int -setincr(NODE *p) -{ - if (x2debug) - printf("setincr(%p)\n", p); - - return(0); -} - -/* * findops() failed, see if we can rewrite it to match. */ int @@ -223,3 +211,12 @@ livecall(NODE *p) *s = -1; return s; } + +/* + * Signal whether the instruction is acceptable for this target. + */ +int +acceptable(struct optab *op) +{ + return 1; +} |