X-Git-Url: https://git.gag.com/?a=blobdiff_plain;ds=sidebyside;f=as%2Fmcs51%2Fasmain.c;h=0f40fe8461ebac26dbdbb0318c40cf5da7fb5220;hb=fe9b00fb61dc71f48cb6416e608b5b6882bbc35f;hp=ef6534afef8304862812bf10800e3dc75f5b2deb;hpb=66620996198afa99bdc85771e8466b83df014612;p=fw%2Fsdcc diff --git a/as/mcs51/asmain.c b/as/mcs51/asmain.c index ef6534af..0f40fe84 100644 --- a/as/mcs51/asmain.c +++ b/as/mcs51/asmain.c @@ -17,6 +17,7 @@ #include #include "asm.h" +#include "strcmpi.h" /*)Module asmain.c * @@ -129,7 +130,7 @@ * VOID diag() assubr.c * VOID err() assubr.c * int fprintf() c-library - * int getline() aslex.c + * int as_getline() aslex.c * VOID list() aslist.c * VOID lstsym() aslist.c * VOID minit() ___mch.c @@ -288,7 +289,7 @@ char *argv[]; dot.s_area = &dca; symp = ˙ minit(); - while (getline()) { + while (as_getline()) { cp = cb; cpt = cbt; ep = eb; @@ -374,7 +375,7 @@ int i; if (i) { // remove output file printf ("removing %s\n", relFile); - unlink(relFile); + remove(relFile); } exit(i); } @@ -479,7 +480,7 @@ asmbl() struct expr e1; char id[NCPS]; char opt[NCPS]; - char fn[FILSPC]; + char fn[PATH_MAX]; char *p; int d, n, uaf, uf; @@ -555,7 +556,7 @@ loop: goto loop; } /* - * If the first character is a letter then assume a lable, + * If the first character is a letter then assume a label, * symbol, assembler directive, or assembler mnemonic is * being processed. */ @@ -799,7 +800,7 @@ loop: break; case S_MODUL: - getst(id, -1); + getst(id, getnb()); // a module can start with a digit if (pass == 0) { if (module[0]) { err('m'); @@ -810,6 +811,20 @@ loop: lmode = SLIST; break; + case S_OPTSDCC: + p = optsdcc; + if ((c = getnb()) != 0) { + do { + if (p < &optsdcc[NINPUT-1]) + *p++ = c; + } while ((c = get()) != 0); + } + *p = 0; + unget(c); + lmode = SLIST; + /*if (pass == 0) printf("optsdcc=%s\n", optsdcc);*/ + break; + case S_GLOBL: do { getid(id, -1); @@ -843,10 +858,6 @@ loop: if ((ap = alookup(id)) != NULL) { if (uaf && uf != ap->a_flag) err('m'); - if (ap->a_flag & A_OVR) { - ap->a_size = 0; - ap->a_fuzz=0; - } } else { ap = (struct area *) new (sizeof(struct area)); ap->a_ap = areap; @@ -864,7 +875,7 @@ loop: case S_ORG: if (dot.s_area->a_flag & A_ABS) { outall(); - laddr = dot.s_addr = absexpr(); + laddr = dot.s_addr = dot.s_org = absexpr(); } else { err('o'); } @@ -911,7 +922,7 @@ loop: d = getnb(); p = fn; while ((c = get()) != d) { - if (p < &fn[FILSPC-1]) { + if (p < &fn[PATH_MAX-1]) { *p++ = c; } else { break; @@ -935,7 +946,7 @@ loop: { getst(id, -1); - if (!strcmpi(id, "on")) + if (!as_strcmpi(id, "on")) { /* Quick sanity check: size of * Addr_T must be at least 24 bits. @@ -953,7 +964,7 @@ loop: flat24Mode = 1; } } - else if (!strcmpi(id, "off")) + else if (!as_strcmpi(id, "off")) { flat24Mode = 0; } @@ -1053,8 +1064,8 @@ int wf; p2 = strrchr (afn, FSEPX); // search last '.' if (!p2) p2 = afn + strlen (afn); - if (p2 > &afn[FILSPC-4]) // truncate filename, if it's too long - p2 = &afn[FILSPC-4]; + if (p2 > &afn[PATH_MAX-4]) // truncate filename, if it's too long + p2 = &afn[PATH_MAX-4]; *p2++ = FSEPX; // choose a file-extension @@ -1067,7 +1078,7 @@ int wf; } while ((c = *p3++) != 0) { // strncpy - if (p2 < &afn[FILSPC-1]) + if (p2 < &afn[PATH_MAX-1]) *p2++ = c; } *p2++ = 0; @@ -1114,11 +1125,30 @@ register struct area *nap; register struct area *oap; oap = dot.s_area; + /* fprintf (stderr, "%s dot.s_area->a_size: %d dot.s_addr: %d\n", + oap->a_id, dot.s_area->a_size, dot.s_addr); */ oap->a_fuzz = fuzz; - oap->a_size = dot.s_addr; - fuzz = nap->a_fuzz; + if (oap->a_flag & A_OVR) { + // the size of an overlay is the biggest size encountered + if (oap->a_size < dot.s_addr) { + oap->a_size = dot.s_addr; + } + } else if (oap->a_flag & A_ABS) { + oap->a_addr = dot.s_org; + oap->a_size = dot.s_addr - dot.s_org; + } else { + oap->a_addr = 0; + oap->a_size = dot.s_addr; + } + if (nap->a_flag & A_OVR) { + // a new overlay starts at 0, no fuzz + dot.s_addr = 0; + fuzz = 0; + } else { + dot.s_addr = nap->a_size; + fuzz = nap->a_fuzz; + } dot.s_area = nap; - dot.s_addr = nap->a_size; outall(); }