X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?p=rmac;a=blobdiff_plain;f=debug.c;h=4f64eb40bd9d01c69059b59f6dabf45204d529ce;hp=28784bfe5b4cbae1d5fe36da3e0eb71207bd7061;hb=c38505ee4b2a0de59926107e52fb8bb84041a0e4;hpb=eace4e1b294ccec54a5c476619f616f5da0bf8a9 diff --git a/debug.c b/debug.c index 28784bf..4f64eb4 100644 --- a/debug.c +++ b/debug.c @@ -1,14 +1,16 @@ // // RMAC - Reboot's Macro Assembler for all Atari computers // DEBUG.C - Debugging Messages -// Copyright (C) 199x Landon Dyer, 2011-2017 Reboot and Friends +// Copyright (C) 199x Landon Dyer, 2011-2020 Reboot and Friends // RMAC derived from MADMAC v1.07 Written by Landon Dyer, 1986 // Source utilised with the kind permission of Landon Dyer // #include "debug.h" +#include "6502.h" #include "amode.h" #include "direct.h" +#include "expr.h" #include "mark.h" #include "sect.h" #include "token.h" @@ -86,46 +88,32 @@ int chdump(CHUNK * ch, int format) // // Dump fixup records in printable format // -int fudump(CHUNK * ch) +int fudump(FIXUP * fup) { - PTR p; - - for(; ch!=NULL;) + for(; fup!=NULL;) { - p.cp = ch->chptr; - uint8_t * ep = ch->chptr + ch->ch_size; + uint32_t attr = fup->attr; + uint32_t loc = fup->loc; + uint16_t file = fup->fileno; + uint16_t line = fup->lineno; - while (p.cp < ep) - { - uint16_t attr = *p.wp++; - uint32_t loc = *p.lp++; - uint16_t file = *p.wp++; - uint16_t line = *p.wp++; + printf("$%08X $%08X %d.%d: ", attr, loc, (int)file, (int)line); - printf("$%04X $%08X %d.%d: ", (int)attr, loc, (int)file, (int)line); - - if (attr & FU_EXPR) - { - uint16_t esiz = *p.wp++; - printf("(%d long) ", (int)esiz); - p.tk = printexpr(p.tk); - } - else - { - printf("`%s' ;", (*p.sy)->sname); - p.sy++; - } + if (attr & FU_EXPR) + { + uint16_t esiz = ExpressionLength(fup->expr); + printf("(%d long) ", (int)esiz); + printexpr(fup->expr); + } + else + printf("`%s' ;", fup->symbol->sname); - if ((attr & 0x0F00) == FU_JR) - { - printf(" *=$%X", *p.lp); - p.lp++; - } + if ((attr & FUMASKRISC) == FU_JR) + printf(" *=$%X", fup->orgaddr); - printf("\n"); - } + printf("\n"); - ch = ch->chnext; + fup = fup->next; } return 0; @@ -233,8 +221,6 @@ int mdump(char * start, LONG count, int flg, LONG base) start[i+2] & 0xFF, start[i+3] & 0xFF); i += 4; break; - case 3: - break; } if (base != -1) @@ -397,6 +383,8 @@ void DumpTokens(TOKEN * tokenBuffer) printf("[ENDEXPR]"); else if (*t == CR_ABSCOUNT) printf("[CR_ABSCOUNT]"); + else if (*t == CR_FILESIZE) + printf("[CR_FILESIZE]"); else if (*t == CR_DEFINED) printf("[CR_DEFINED]"); else if (*t == CR_REFERENCED) @@ -430,6 +418,10 @@ void DumpTokens(TOKEN * tokenBuffer) // int dump_everything(void) { + // FFS + if ((currentorg[1] - currentorg[0]) == 0) + sect[M6502].sfcode = NULL; + for(int i=1; i