X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Favr%2Fmain.c;h=efde4d2beaef53048b1dd4eb7b1471ae7c74d8be;hb=499345cf384044caa607bf6cb0f7689fe3863ad7;hp=e09ba53a0c23f5d2c7a7a88a5f9b5166d820ff05;hpb=b0528af48546cdfe3f2be3c126732eaff8933fe2;p=fw%2Fsdcc diff --git a/src/avr/main.c b/src/avr/main.c index e09ba53a..efde4d2b 100644 --- a/src/avr/main.c +++ b/src/avr/main.c @@ -42,13 +42,13 @@ _avr_init (void) } static void -_avr_reset_regparm () +_avr_reset_regparm (void) { regParmFlg = 0; } 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,12 +201,17 @@ 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", "CSEG", "DSEG", "ISEG", + NULL, //PSEG "XSEG", "BSEG", "RSEG", @@ -216,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,