X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Favr%2Fmain.c;h=efde4d2beaef53048b1dd4eb7b1471ae7c74d8be;hb=5a1d5e778e85664f4e6657019348b4756b16eacb;hp=c5ff36229b5b4dc900abe1f9161e571e370fee43;hpb=d2da99feec099aa224e1db53bc5a1ed42ed51ec9;p=fw%2Fsdcc diff --git a/src/avr/main.c b/src/avr/main.c index c5ff3622..efde4d2b 100644 --- a/src/avr/main.c +++ b/src/avr/main.c @@ -48,7 +48,7 @@ _avr_reset_regparm (void) } static int -_avr_regparm (sym_link * l) +_avr_regparm (sym_link * l, bool reentrant) { /* the first eight bytes will be passed in registers r16-r23. but we won't split variables @@ -69,7 +69,7 @@ _avr_regparm (sym_link * l) return 0; } -void avr_assignRegisters (eBBlock ** ebbs, int count); +void avr_assignRegisters (ebbIndex *); static bool _avr_parseOptions (int *pargc, char **argv, int *i) @@ -126,9 +126,9 @@ _avr_genAssemblerPreamble (FILE * of) /* Generate interrupt vector table. */ static int -_avr_genIVT (FILE * of, symbol ** interrupts, int maxInterrupts) +_avr_genIVT (struct dbuf_s * oBuf, symbol ** interrupts, int maxInterrupts) { - return TRUE; + return TRUE; } /* Indicate which extended bit operations this port supports */ @@ -201,6 +201,10 @@ PORT avr_port = { { /* Sizes: char, short, int, long, ptr, fptr, gptr, bit, float, max */ 1, 2, 2, 4, 2, 2, 3, 1, 4, 4}, + + /* tags for generic pointers */ + { 0x00, 0x40, 0x60, 0x80 }, /* far, near, xstack, code */ + { "XSEG", "STACK", @@ -217,6 +221,10 @@ PORT avr_port = { "HOME", NULL, // initialized xdata NULL, // a code copy of xiseg + "CONST (CODE)", // const_name - const data (code or not) + "CABS (ABS,CODE)", // cabs_name - const absolute data (code or not) + "XABS (ABS,XDATA)", // xabs_name - absolute xdata/pdata + "IABS (ABS,DATA)", // iabs_name - absolute idata/data NULL, NULL, 0,