--- np2/statsave.c 2003/10/20 12:08:01 1.8 +++ np2/statsave.c 2003/12/19 23:16:06 1.21 @@ -4,22 +4,22 @@ #include "scrnmng.h" #include "soundmng.h" #include "timemng.h" -#include "i286.h" -#include "memory.h" +#include "cpucore.h" #include "pccore.h" #include "iocore.h" #include "cbuscore.h" #include "pc9861k.h" #include "mpu98ii.h" #include "board14.h" +#include "amd98.h" +#include "bios.h" #include "vram.h" -#include "maketext.h" #include "palettes.h" -#include "font.h" +#include "maketext.h" #include "sound.h" -#include "bios.h" #include "fmboard.h" #include "beep.h" +#include "font.h" #include "fddfile.h" #include "fdd_mtr.h" #include "sxsi.h" @@ -28,6 +28,18 @@ #include "keydisp.h" +#if defined(MACOS) +#define CRLITERAL "\r" +#define CRCONST str_cr +#elif defined(WIN32) || defined(X11) || defined(SLZAURUS) +#define CRLITERAL "\n" +#define CRCONST str_lf +#else +#define CRLITERAL "\r\n" +#define CRCONST str_crlf +#endif + + typedef struct { char name[16]; char vername[28]; @@ -38,20 +50,21 @@ typedef struct { char index[10]; UINT16 ver; UINT32 size; -} NP2FLAGPART_T; +} NP2FENT; enum { NP2FLAG_BIN = 0, NP2FLAG_TERM, NP2FLAG_CLOCK, + NP2FLAG_COM, + NP2FLAG_DISK, NP2FLAG_DMA, NP2FLAG_EGC, - NP2FLAG_EXT, NP2FLAG_EVT, - NP2FLAG_GIJ, + NP2FLAG_EXT, NP2FLAG_FM, - NP2FLAG_MIDI, - NP2FLAG_DISK + NP2FLAG_GIJ, + NP2FLAG_MEM }; typedef struct { @@ -72,9 +85,9 @@ typedef struct { int num; } ENUMTBL; -#define PROCID(a, b, c, d) (((d) << 24) | ((c) << 16) | ((b) << 8) | (a)) -#define PROC2NUM(a, b) proc2num(&(a), b, sizeof(b)/sizeof(PROCTBL)) -#define NUM2PROC(a, b) num2proc(&(a), b, sizeof(b)/sizeof(PROCTBL)) +#define PROCID(a, b, c, d) (((d) << 24) + ((c) << 16) + ((b) << 8) + (a)) +#define PROC2NUM(a, b) proc2num(&(a), (b), sizeof(b)/sizeof(PROCTBL)) +#define NUM2PROC(a, b) num2proc(&(a), (b), sizeof(b)/sizeof(PROCTBL)) #include "statsave.tbl" @@ -89,9 +102,10 @@ typedef struct { static void err_append(ERR_BUF *e, char *buf) { + int len; + if ((e) && (buf)) { if (e->buf) { - int len; len = strlen(buf); if (e->remain >= len) { CopyMemory(e->buf, buf, len); @@ -138,15 +152,15 @@ static BOOL num2proc(void *func, const P // ---- typedef struct { - FILEH fh; - long pos; - long bak; - long next; - NP2FHDR f; - NP2FLAGPART_T p; -} NP2FFILE; + FILEH fh; + long pos; + long bak; + long next; + NP2FHDR f; + NP2FENT p; +} _NP2FFILE, *NP2FFILE; -static int flagopen(NP2FFILE *f, const char *filename, ERR_BUF *e) { +static int flagopen(NP2FFILE f, const char *filename, ERR_BUF *e) { if (f) { f->fh = file_open(filename); @@ -185,7 +199,7 @@ static int flagopen(NP2FFILE *f, const c return(NP2FLAG_FAILURE); } -static int flagcreate(NP2FFILE *f, const char *filename) { +static int flagcreate(NP2FFILE f, const char *filename) { if (f) { f->fh = file_create(filename); @@ -203,10 +217,10 @@ static int flagcreate(NP2FFILE *f, const return(NP2FLAG_FAILURE); } -static int flagload_create(NP2FFILE *f) { +static int flagload_create(NP2FFILE f) { if (f) { - ZeroMemory(&f->p, sizeof(NP2FLAGPART_T)); + ZeroMemory(&f->p, sizeof(NP2FENT)); if (f->pos & 15) { f->pos += 15; f->pos &= ~0xf; @@ -214,18 +228,17 @@ static int flagload_create(NP2FFILE *f) return(NP2FLAG_FAILURE); } } - if (file_read(f->fh, &f->p, sizeof(NP2FLAGPART_T)) - != sizeof(NP2FLAGPART_T)) { + if (file_read(f->fh, &f->p, sizeof(NP2FENT)) != sizeof(NP2FENT)) { return(NP2FLAG_FAILURE); } - f->pos += sizeof(NP2FLAGPART_T); + f->pos += sizeof(NP2FENT); f->next = f->pos + f->p.size; return(NP2FLAG_SUCCESS); } return(NP2FLAG_FAILURE); } -static int flagload_load(NP2FFILE *f, void *buf, UINT size) { +static int flagload_load(NP2FFILE f, void *buf, UINT size) { if (f && buf && size && (file_read(f->fh, buf, size) == size)) { f->pos += size; @@ -234,7 +247,7 @@ static int flagload_load(NP2FFILE *f, vo return(NP2FLAG_FAILURE); } -static int flagload_close(NP2FFILE *f) { +static int flagload_close(NP2FFILE f) { if (file_seek(f->fh, f->next, 0) != f->next) { return(NP2FLAG_FAILURE); @@ -243,11 +256,11 @@ static int flagload_close(NP2FFILE *f) { return(NP2FLAG_SUCCESS); } -static int flagsave_create(NP2FFILE *f, const STENTRY *t) { +static int flagsave_create(NP2FFILE f, const STENTRY *t) { if (f && t) { int len; - ZeroMemory(&f->p, sizeof(NP2FLAGPART_T)); + ZeroMemory(&f->p, sizeof(NP2FENT)); if (f->pos & 15) { UINT rem; rem = 16 - (f->pos & 15); @@ -266,17 +279,16 @@ static int flagsave_create(NP2FFILE *f, CopyMemory(f->p.index, t->index, len); } f->p.ver = t->ver; - if (file_write(f->fh, &f->p, sizeof(NP2FLAGPART_T)) - != sizeof(NP2FLAGPART_T)) { + if (file_write(f->fh, &f->p, sizeof(NP2FENT)) != sizeof(NP2FENT)) { return(NP2FLAG_FAILURE); } - f->pos += sizeof(NP2FLAGPART_T); + f->pos += sizeof(NP2FENT); return(NP2FLAG_SUCCESS); } return(NP2FLAG_FAILURE); } -static int flagsave_save(NP2FFILE *f, void *buf, UINT size) { +static int flagsave_save(NP2FFILE f, void *buf, UINT size) { if (f && buf && size && (file_write(f->fh, buf, size) == size)) { f->pos += size; @@ -286,7 +298,7 @@ static int flagsave_save(NP2FFILE *f, vo return(NP2FLAG_FAILURE); } -static int flagsave_close(NP2FFILE *f) { +static int flagsave_close(NP2FFILE f) { if (!f) { goto fs_closeerr; @@ -294,8 +306,7 @@ static int flagsave_close(NP2FFILE *f) { if (file_seek(f->fh, f->bak, 0) != f->bak) { goto fs_closeerr; } - if (file_write(f->fh, &f->p, sizeof(NP2FLAGPART_T)) - != sizeof(NP2FLAGPART_T)) { + if (file_write(f->fh, &f->p, sizeof(NP2FENT)) != sizeof(NP2FENT)) { goto fs_closeerr; } if (file_seek(f->fh, f->pos, 0) == f->pos) { @@ -306,7 +317,7 @@ fs_closeerr: return(NP2FLAG_FAILURE); } -static void flagclose(NP2FFILE *f) { +static void flagclose(NP2FFILE f) { if (f) { file_close(f->fh); @@ -316,7 +327,7 @@ static void flagclose(NP2FFILE *f) { // ---- -static int flagsave_term(NP2FFILE *f, const STENTRY *t) { +static int flagsave_term(NP2FFILE f, const STENTRY *t) { int ret; @@ -326,9 +337,9 @@ static int flagsave_term(NP2FFILE *f, co } -// ---- +// ---- common -static int flagsave_common(NP2FFILE *f, const STENTRY *t) { +static int flagsave_common(NP2FFILE f, const STENTRY *t) { int ret; @@ -340,15 +351,15 @@ static int flagsave_common(NP2FFILE *f, return(ret); } -static int flagload_common(NP2FFILE *f, const STENTRY *t) { +static int flagload_common(NP2FFILE f, const STENTRY *t) { return(flagload_load(f, t->arg1, t->arg2)); } -// ----- +// ----- clock -static int flagload_clock(NP2FFILE *f, const STENTRY *t) { +static int flagload_clock(NP2FFILE f, const STENTRY *t) { int ret; @@ -359,9 +370,88 @@ static int flagload_clock(NP2FFILE *f, c } -// ----- +// ---- memory + +static int flagsave_mem(NP2FFILE f, const STENTRY *t) { + + int ret; + + ret = flagsave_create(f, t); + if (ret != NP2FLAG_FAILURE) { + ret |= flagsave_save(f, mem, 0x110000); + ret |= flagsave_save(f, mem + VRAM1_B, 0x18000); + ret |= flagsave_save(f, mem + VRAM1_E, 0x8000); + ret |= flagsave_close(f); + } + return(ret); +} + +static int flagload_mem(NP2FFILE f, const STENTRY *t) { + + int ret; -static int flagsave_dma(NP2FFILE *f, const STENTRY *t) { + ret = flagload_load(f, mem, 0x110000); + ret |= flagload_load(f, mem + VRAM1_B, 0x18000); + ret |= flagload_load(f, mem + VRAM1_E, 0x8000); + (void)t; + return(ret); +} + + +// ---- ext memory + +static int flagsave_ext(NP2FFILE f, const STENTRY *t) { + + int ret; + + ret = flagsave_create(f, t); + if (ret != NP2FLAG_FAILURE) { + ret |= flagsave_save(f, &extmem, sizeof(extmem)); + if (CPU_EXTMEM) { + ret |= flagsave_save(f, CPU_EXTMEM, CPU_EXTMEMSIZE); + } + ret |= flagsave_close(f); + } + return(ret); +} + +static int flagload_ext(NP2FFILE f, const STENTRY *t) { + + int ret; + int i; + UINT pagemax = 0; + + ret = flagload_load(f, &extmem, sizeof(extmem)); + if (extmem.maxmem) { + if (extmem.maxmem > (13+1)) { + extmem.maxmem = (13+1); + } + if (!extmemmng_realloc(extmem.maxmem - 1)) { + pagemax = (extmem.maxmem - 1) << 8; + if (CPU_EXTMEM) { + ret |= flagload_load(f, CPU_EXTMEM, CPU_EXTMEMSIZE); + } + } + else { + extmem.maxmem = 0; + } + } + for (i=0; i<4; i++) { + if (extmem.page[i] < pagemax) { + extmem.pageptr[i] = CPU_EXTMEM + (extmem.page[i] << 12); + } + else { + extmem.pageptr[i] = mem + 0xc0000 + (i << 14); + } + } + (void)t; + return(ret); +} + + +// ---- dma + +static int flagsave_dma(NP2FFILE f, const STENTRY *t) { int ret; int i; @@ -383,7 +473,7 @@ static int flagsave_dma(NP2FFILE *f, con return(ret); } -static int flagload_dma(NP2FFILE *f, const STENTRY *t) { +static int flagload_dma(NP2FFILE f, const STENTRY *t) { int ret; int i; @@ -409,9 +499,9 @@ static int flagload_dma(NP2FFILE *f, con } -// ----- +// ---- egc -static int flagsave_egc(NP2FFILE *f, const STENTRY *t) { +static int flagsave_egc(NP2FFILE f, const STENTRY *t) { int ret; _EGC egcbak; @@ -428,7 +518,7 @@ static int flagsave_egc(NP2FFILE *f, con return(ret); } -static int flagload_egc(NP2FFILE *f, const STENTRY *t) { +static int flagload_egc(NP2FFILE f, const STENTRY *t) { int ret; @@ -440,58 +530,7 @@ static int flagload_egc(NP2FFILE *f, con } -// ----- - -static int flagsave_ext(NP2FFILE *f, const STENTRY *t) { - - int ret; - - ret = flagsave_create(f, t); - if (ret != NP2FLAG_FAILURE) { - ret |= flagsave_save(f, &extmem, sizeof(extmem)); - if (extmemmng_size) { - ret |= flagsave_save(f, extmemmng_ptr, extmemmng_size); - } - ret |= flagsave_close(f); - } - return(ret); -} - -static int flagload_ext(NP2FFILE *f, const STENTRY *t) { - - int ret; - int i; - UINT pagemax = 0; - - ret = flagload_load(f, &extmem, sizeof(extmem)); - if (extmem.maxmem) { - if (extmem.maxmem > (13+1)) { - extmem.maxmem = (13+1); - } - if (!extmemmng_realloc(extmem.maxmem - 1)) { - pagemax = (extmem.maxmem - 1) << 8; - if (extmemmng_size) { - ret |= flagload_load(f, extmemmng_ptr, extmemmng_size); - } - } - else { - extmem.maxmem = 0; - } - } - for (i=0; i<4; i++) { - if (extmem.page[i] < pagemax) { - extmem.pageptr[i] = extmemmng_ptr + (extmem.page[i] << 12); - } - else { - extmem.pageptr[i] = mem + 0xc0000 + (i << 14); - } - } - (void)t; - return(ret); -} - - -// ----- +// ---- event typedef struct { UINT readyevents; @@ -505,7 +544,7 @@ typedef struct { NEVENTCB proc; } NEVTITEM; -static int nevent_save(NP2FFILE *f, int num) { +static int nevent_save(NP2FFILE f, int num) { NEVTITEM nit; UINT i; @@ -526,7 +565,7 @@ static int nevent_save(NP2FFILE *f, int return(flagsave_save(f, &nit, sizeof(nit))); } -static int flagsave_evt(NP2FFILE *f, const STENTRY *t) { +static int flagsave_evt(NP2FFILE f, const STENTRY *t) { NEVTSAVE nevt; int ret; @@ -549,7 +588,7 @@ static int flagsave_evt(NP2FFILE *f, con return(ret); } -static int nevent_load(NP2FFILE *f, UINT *tbl, UINT *pos) { +static int nevent_load(NP2FFILE f, UINT *tbl, UINT *pos) { int ret; NEVTITEM nit; @@ -582,7 +621,7 @@ static int nevent_load(NP2FFILE *f, UINT return(ret); } -static int flagload_evt(NP2FFILE *f, const STENTRY *t) { +static int flagload_evt(NP2FFILE f, const STENTRY *t) { int ret; NEVTSAVE nevt; @@ -604,9 +643,9 @@ static int flagload_evt(NP2FFILE *f, con } -// ---- +// ---- gaiji -static int flagsave_gij(NP2FFILE *f, const STENTRY *t) { +static int flagsave_gij(NP2FFILE f, const STENTRY *t) { int ret; int i; @@ -616,7 +655,7 @@ static int flagsave_gij(NP2FFILE *f, con ret = flagsave_create(f, t); if (ret != NP2FLAG_FAILURE) { for (i=0; i<2; i++) { - fnt = font + ((0x56 + (i << 7)) << 4); + fnt = fontrom + ((0x56 + (i << 7)) << 4); for (j=0; j<0x80; j++) { ret |= flagsave_save(f, fnt, 32); fnt += 0x1000; @@ -627,7 +666,7 @@ static int flagsave_gij(NP2FFILE *f, con return(ret); } -static int flagload_gij(NP2FFILE *f, const STENTRY *t) { +static int flagload_gij(NP2FFILE f, const STENTRY *t) { int ret; int i; @@ -636,7 +675,7 @@ static int flagload_gij(NP2FFILE *f, con ret = 0; for (i=0; i<2; i++) { - fnt = font + ((0x56 + (i << 7)) << 4); + fnt = fontrom + ((0x56 + (i << 7)) << 4); for (j=0; j<0x80; j++) { ret |= flagload_load(f, fnt, 32); fnt += 0x1000; @@ -647,7 +686,7 @@ static int flagload_gij(NP2FFILE *f, con } -// ----- +// ---- FM enum { FLAG_MG = 0x0001, @@ -657,10 +696,11 @@ enum { FLAG_FM2B = 0x0010, FLAG_PSG1 = 0x0020, FLAG_PSG2 = 0x0040, - FLAG_RHYTHM = 0x0080, - FLAG_ADPCM = 0x0100, - FLAG_PCM86 = 0x0200, - FLAG_CS4231 = 0x0400 + FLAG_PSG3 = 0x0080, + FLAG_RHYTHM = 0x0100, + FLAG_ADPCM = 0x0200, + FLAG_PCM86 = 0x0400, + FLAG_CS4231 = 0x0800 }; typedef struct { @@ -668,7 +708,7 @@ typedef struct { BYTE extop[4]; } OPNKEY; -static int flagsave_fm(NP2FFILE *f, const STENTRY *t) { +static int flagsave_fm(NP2FFILE f, const STENTRY *t) { int ret; UINT saveflg; @@ -713,6 +753,10 @@ static int flagsave_fm(NP2FFILE *f, cons FLAG_PSG1 | FLAG_RHYTHM | FLAG_ADPCM; break; + case 0x80: + saveflg = FLAG_PSG1 | FLAG_PSG2 | FLAG_PSG3; + break; + default: saveflg = 0; break; @@ -741,6 +785,9 @@ static int flagsave_fm(NP2FFILE *f, cons if (saveflg & FLAG_PSG2) { ret |= flagsave_save(f, &psg2.reg, sizeof(PSGREG)); } + if (saveflg & FLAG_PSG3) { + ret |= flagsave_save(f, &psg3.reg, sizeof(PSGREG)); + } if (saveflg & FLAG_ADPCM) { ret |= flagsave_save(f, &adpcm, sizeof(adpcm)); } @@ -755,14 +802,12 @@ static int flagsave_fm(NP2FFILE *f, cons return(ret); } -static void play_fmreg(BYTE num) { +static void play_fmreg(BYTE num, UINT reg) { UINT chbase; - UINT reg; UINT i; chbase = num * 3; - reg = num * 0x100; for (i=0x30; i<0xa0; i++) { opngen_setreg((BYTE)chbase, (BYTE)i, opn.reg[reg + i]); } @@ -783,11 +828,15 @@ static void play_psgreg(PSGGEN psg) { } } -static int flagload_fm(NP2FFILE *f, const STENTRY *t) { +static int flagload_fm(NP2FFILE f, const STENTRY *t) { int ret; UINT saveflg; OPNKEY opnkey; + UINT fmreg1a; + UINT fmreg1b; + UINT fmreg2a; + UINT fmreg2b; opngen_reset(); psggen_reset(&psg1); @@ -801,6 +850,10 @@ static int flagload_fm(NP2FFILE *f, cons ret = flagload_load(f, &usesound, sizeof(usesound)); fmboard_reset((BYTE)usesound); + fmreg1a = 0x000; + fmreg1b = 0x100; + fmreg2a = 0x200; + fmreg2b = 0x300; switch(usesound) { case 0x01: saveflg = FLAG_MG; @@ -818,6 +871,9 @@ static int flagload_fm(NP2FFILE *f, cons case 0x06: saveflg = FLAG_FM1A | FLAG_FM1B | FLAG_FM2A | FLAG_PSG1 | FLAG_PSG2 | FLAG_RHYTHM | FLAG_PCM86; + fmreg1a = 0x200; // 逆転してるのん… + fmreg1b = 0x000; + fmreg2a = 0x100; break; case 0x08: @@ -840,7 +896,12 @@ static int flagload_fm(NP2FFILE *f, cons FLAG_PSG1 | FLAG_RHYTHM | FLAG_ADPCM; break; + case 0x80: + saveflg = FLAG_PSG1 | FLAG_PSG2 | FLAG_PSG3; + break; + default: + saveflg = 0; break; } @@ -865,6 +926,9 @@ static int flagload_fm(NP2FFILE *f, cons if (saveflg & FLAG_PSG2) { ret |= flagload_load(f, &psg2.reg, sizeof(PSGREG)); } + if (saveflg & FLAG_PSG3) { + ret |= flagload_load(f, &psg3.reg, sizeof(PSGREG)); + } if (saveflg & FLAG_ADPCM) { ret |= flagload_load(f, &adpcm, sizeof(adpcm)); } @@ -888,16 +952,16 @@ static int flagload_fm(NP2FFILE *f, cons } if (saveflg & FLAG_FM1A) { - play_fmreg(0); + play_fmreg(0, fmreg1a); } if (saveflg & FLAG_FM1B) { - play_fmreg(1); + play_fmreg(1, fmreg1b); } if (saveflg & FLAG_FM2A) { - play_fmreg(2); + play_fmreg(2, fmreg2a); } if (saveflg & FLAG_FM2B) { - play_fmreg(3); + play_fmreg(3, fmreg2b); } if (saveflg & FLAG_PSG1) { play_psgreg(&psg1); @@ -905,6 +969,9 @@ static int flagload_fm(NP2FFILE *f, cons if (saveflg & FLAG_PSG2) { play_psgreg(&psg2); } + if (saveflg & FLAG_PSG3) { + play_psgreg(&psg3); + } (void)t; return(ret); } @@ -919,7 +986,13 @@ typedef struct { DOSTIME time; } STATDISK; -static int disksave(NP2FFILE *f, const char *path, int readonly) { +static const char str_fddx[] = "FDD%u"; +static const char str_sasix[] = "SASI%u"; +static const char str_scsix[] = "SCSI%u"; +static const char str_updated[] = "%s: updated" CRLITERAL; +static const char str_notfound[] = "%s: not found" CRLITERAL; + +static int disksave(NP2FFILE f, const char *path, int readonly) { STATDISK st; FILEH fh; @@ -937,7 +1010,7 @@ static int disksave(NP2FFILE *f, const c return(flagsave_save(f, &st, sizeof(st))); } -static int flagsave_disk(NP2FFILE *f, const STENTRY *t) { +static int flagsave_disk(NP2FFILE f, const STENTRY *t) { int ret; BYTE i; @@ -959,7 +1032,7 @@ static int flagsave_disk(NP2FFILE *f, co return(ret); } -static int diskcheck(NP2FFILE *f, const char *name, ERR_BUF *e) { +static int diskcheck(NP2FFILE f, const char *name, ERR_BUF *e) { int ret; FILEH fh; @@ -977,20 +1050,20 @@ static int diskcheck(NP2FFILE *f, const if ((memcmp(&st.date, &date, sizeof(date))) || (memcmp(&st.time, &time, sizeof(time)))) { ret |= NP2FLAG_DISKCHG; - SPRINTF(buf, "%s: updated\n", name); + SPRINTF(buf, str_updated, name); err_append(e, buf); } } else { ret |= NP2FLAG_DISKCHG; - SPRINTF(buf, "%s: not found\n", name); + SPRINTF(buf, str_notfound, name); err_append(e, buf); } } return(ret); } -static int flagcheck_disk(NP2FFILE *f, const STENTRY *t, ERR_BUF *e) { +static int flagcheck_disk(NP2FFILE f, const STENTRY *t, ERR_BUF *e) { int ret; int i; @@ -998,23 +1071,23 @@ static int flagcheck_disk(NP2FFILE *f, c ret = 0; for (i=0; i<4; i++) { - SPRINTF(buf, "FDD%d", i+1); + SPRINTF(buf, str_fddx, i+1); ret |= diskcheck(f, buf, e); } sxsi_flash(); for (i=0; i<2; i++) { - SPRINTF(buf, "SASI%u", i+1); + SPRINTF(buf, str_sasix, i+1); ret |= diskcheck(f, buf, e); } for (i=0; i<2; i++) { - SPRINTF(buf, "SCSI%d", i+1); + SPRINTF(buf, str_scsix, i+1); ret |= diskcheck(f, buf, e); } (void)t; return(ret); } -static int flagload_disk(NP2FFILE *f, const STENTRY *t) { +static int flagload_disk(NP2FFILE f, const STENTRY *t) { int ret; BYTE i; @@ -1047,15 +1120,14 @@ static int flagload_disk(NP2FFILE *f, co } -// ----- +// ---- com -#ifdef _MIDICH -static int flagsave_midi(NP2FFILE *f, const STENTRY *t) { +static int flagsave_com(NP2FFILE f, const STENTRY *t) { UINT device; COMMNG cm; int ret; - _MIDICH mch[16]; + COMFLAG flag; device = (UINT)t->arg1; switch(device) { @@ -1072,55 +1144,78 @@ static int flagsave_midi(NP2FFILE *f, co break; } ret = NP2FLAG_SUCCESS; - if ((cm != NULL) && (cm->msg(cm, COMMSG_MIDISTATGET, (long)mch))) { - ret = flagsave_create(f, t); - if (ret != NP2FLAG_FAILURE) { - ret |= flagsave_save(f, mch, sizeof(mch)); - ret |= flagsave_close(f); + if (cm) { + flag = (COMFLAG)cm->msg(cm, COMMSG_GETFLAG, 0); + if (flag) { + ret = flagsave_create(f, t); + if (ret != NP2FLAG_FAILURE) { + ret |= flagsave_save(f, flag, flag->size); + ret |= flagsave_close(f); + } + _MFREE(flag); } } return(ret); } -static int flagload_midi(NP2FFILE *f, const STENTRY *t) { +static int flagload_com(NP2FFILE f, const STENTRY *t) { - _MIDICH mch[16]; - UINT device; - COMMNG cm; - int ret; + UINT device; + COMMNG cm; + int ret; + _COMFLAG fhdr; + COMFLAG flag; - ret = flagload_load(f, mch, sizeof(mch)); - if (ret != NP2FLAG_FAILURE) { - device = (UINT)t->arg1; - switch(device) { - case 0: - commng_destroy(cm_mpu98); - cm = commng_create(COMCREATE_MPU98II); - cm_mpu98 = cm; - break; + ret = flagload_load(f, &fhdr, sizeof(fhdr)); + if (ret != NP2FLAG_SUCCESS) { + goto flcom_err1; + } + if (fhdr.size < sizeof(fhdr)) { + goto flcom_err1; + } + flag = (COMFLAG)_MALLOC(fhdr.size, "com stat flag"); + if (flag == NULL) { + goto flcom_err1; + } + CopyMemory(flag, &fhdr, sizeof(fhdr)); + ret |= flagload_load(f, flag + 1, fhdr.size - sizeof(fhdr)); + if (ret != NP2FLAG_SUCCESS) { + goto flcom_err2; + } - case 1: - commng_destroy(cm_rs232c); - cm = commng_create(COMCREATE_SERIAL); - cm_rs232c = cm; - break; + device = (UINT)t->arg1; + switch(device) { + case 0: + commng_destroy(cm_mpu98); + cm = commng_create(COMCREATE_MPU98II); + cm_mpu98 = cm; + break; - default: - cm = NULL; - break; - } - if (cm) { - cm->msg(cm, COMMSG_MIDISTATSET, (long)mch); - } + case 1: + commng_destroy(cm_rs232c); + cm = commng_create(COMCREATE_SERIAL); + cm_rs232c = cm; + break; + + default: + cm = NULL; + break; + } + if (cm) { + cm->msg(cm, COMMSG_SETFLAG, (long)flag); } + +flcom_err2: + _MFREE(flag); + +flcom_err1: return(ret); } -#endif // ---- -static int flagcheck_versize(NP2FFILE *f, const STENTRY *t, ERR_BUF *e) { +static int flagcheck_versize(NP2FFILE f, const STENTRY *t, ERR_BUF *e) { if ((f) && (t)) { if ((f->p.ver == t->ver) && (f->p.size == t->arg2)) { @@ -1132,7 +1227,7 @@ static int flagcheck_versize(NP2FFILE *f return(NP2FLAG_FAILURE); } -static int flagcheck_veronly(NP2FFILE *f, const STENTRY *t, ERR_BUF *e) { +static int flagcheck_veronly(NP2FFILE f, const STENTRY *t, ERR_BUF *e) { if ((f) && (t)) { if (f->p.ver == t->ver) { @@ -1149,59 +1244,65 @@ static int flagcheck_veronly(NP2FFILE *f int statsave_save(const char *filename) { - NP2FFILE f; + _NP2FFILE f; int ret; - UINT i; +const STENTRY *tbl; +const STENTRY *tblterm; ret = flagcreate(&f, filename); if (ret == NP2FLAG_FAILURE) { return(ret); } - for (i=0; itype) { case NP2FLAG_BIN: case NP2FLAG_CLOCK: - ret |= flagsave_common(&f, &np2tbl[i]); + ret |= flagsave_common(&f, tbl); break; case NP2FLAG_TERM: - ret |= flagsave_term(&f, &np2tbl[i]); + ret |= flagsave_term(&f, tbl); break; - case NP2FLAG_DMA: - ret |= flagsave_dma(&f, &np2tbl[i]); + case NP2FLAG_COM: + ret |= flagsave_com(&f, tbl); break; - case NP2FLAG_EGC: - ret |= flagsave_egc(&f, &np2tbl[i]); + case NP2FLAG_DISK: + ret |= flagsave_disk(&f, tbl); break; - case NP2FLAG_EXT: - ret |= flagsave_ext(&f, &np2tbl[i]); + case NP2FLAG_DMA: + ret |= flagsave_dma(&f, tbl); + break; + + case NP2FLAG_EGC: + ret |= flagsave_egc(&f, tbl); break; case NP2FLAG_EVT: - ret |= flagsave_evt(&f, &np2tbl[i]); + ret |= flagsave_evt(&f, tbl); break; - case NP2FLAG_GIJ: - ret |= flagsave_gij(&f, &np2tbl[i]); + case NP2FLAG_EXT: + ret |= flagsave_ext(&f, tbl); break; case NP2FLAG_FM: - ret |= flagsave_fm(&f, &np2tbl[i]); + ret |= flagsave_fm(&f, tbl); break; - case NP2FLAG_DISK: - ret |= flagsave_disk(&f, &np2tbl[i]); + case NP2FLAG_GIJ: + ret |= flagsave_gij(&f, tbl); break; -#if defined(MIDICH) - case NP2FLAG_MIDI: - ret |= flagsave_midi(&f, &np2tbl[i]); + case NP2FLAG_MEM: + ret |= flagsave_mem(&f, tbl); break; -#endif } + tbl++; } flagclose(&f); return(ret); @@ -1209,11 +1310,12 @@ int statsave_save(const char *filename) int statsave_check(const char *filename, char *buf, int size) { - NP2FFILE f; + ERR_BUF e; + _NP2FFILE f; int ret; - UINT i; BOOL done; - ERR_BUF e; +const STENTRY *tbl; +const STENTRY *tblterm; e.buf = buf; e.remain = size; @@ -1235,38 +1337,38 @@ int statsave_check(const char *filename, ret |= flagload_create(&f); CopyMemory(index, f.p.index, sizeof(f.p.index)); index[10] = 0; - for (i=0; iindex)) { break; } + tbl++; } - if (i < (sizeof(np2tbl)/sizeof(STENTRY))) { - switch(np2tbl[i].type) { + if (tbl < tblterm) { + switch(tbl->type) { case NP2FLAG_BIN: - ret |= flagcheck_versize(&f, &np2tbl[i], &e); + case NP2FLAG_CLOCK: + case NP2FLAG_MEM: + ret |= flagcheck_versize(&f, tbl, &e); break; case NP2FLAG_TERM: done = TRUE; break; - case NP2FLAG_CLOCK: + case NP2FLAG_COM: case NP2FLAG_DMA: case NP2FLAG_EGC: - case NP2FLAG_EXT: case NP2FLAG_EVT: + case NP2FLAG_EXT: case NP2FLAG_GIJ: -#if defined(MIDICH) - case NP2FLAG_MIDI: -#endif - ret |= flagcheck_veronly(&f, &np2tbl[i], &e); + case NP2FLAG_FM: + ret |= flagcheck_veronly(&f, tbl, &e); break; case NP2FLAG_DISK: - ret |= flagcheck_disk(&f, &np2tbl[i], &e); - break; - - case NP2FLAG_FM: // ver0.31 + ret |= flagcheck_disk(&f, tbl, &e); break; default: @@ -1289,10 +1391,11 @@ int statsave_check(const char *filename, int statsave_load(const char *filename) { - NP2FFILE f; + _NP2FFILE f; int ret; - UINT i; BOOL done; +const STENTRY *tbl; +const STENTRY *tblterm; ret = flagopen(&f, filename, NULL); if (ret == NP2FLAG_FAILURE) { @@ -1312,15 +1415,18 @@ int statsave_load(const char *filename) ret |= flagload_create(&f); CopyMemory(index, f.p.index, sizeof(f.p.index)); index[10] = 0; - for (i=0; iindex)) { break; } + tbl++; } - if (i < (sizeof(np2tbl)/sizeof(STENTRY))) { - switch(np2tbl[i].type) { + if (tbl < tblterm) { + switch(tbl->type) { case NP2FLAG_BIN: - ret |= flagload_common(&f, &np2tbl[i]); + ret |= flagload_common(&f, tbl); break; case NP2FLAG_TERM: @@ -1328,42 +1434,44 @@ int statsave_load(const char *filename) break; case NP2FLAG_CLOCK: - ret |= flagload_clock(&f, &np2tbl[i]); + ret |= flagload_clock(&f, tbl); break; - case NP2FLAG_DMA: - ret |= flagload_dma(&f, &np2tbl[i]); + case NP2FLAG_COM: + ret |= flagload_com(&f, tbl); break; - case NP2FLAG_EGC: - ret |= flagload_egc(&f, &np2tbl[i]); + case NP2FLAG_DISK: + ret |= flagload_disk(&f, tbl); break; - case NP2FLAG_EXT: - ret |= flagload_ext(&f, &np2tbl[i]); + case NP2FLAG_DMA: + ret |= flagload_dma(&f, tbl); + break; + + case NP2FLAG_EGC: + ret |= flagload_egc(&f, tbl); break; case NP2FLAG_EVT: - ret |= flagload_evt(&f, &np2tbl[i]); + ret |= flagload_evt(&f, tbl); break; - case NP2FLAG_GIJ: - ret |= flagload_gij(&f, &np2tbl[i]); + case NP2FLAG_EXT: + ret |= flagload_ext(&f, tbl); break; case NP2FLAG_FM: - ret |= flagload_fm(&f, &np2tbl[i]); + ret |= flagload_fm(&f, tbl); break; - case NP2FLAG_DISK: - ret |= flagload_disk(&f, &np2tbl[i]); + case NP2FLAG_GIJ: + ret |= flagload_gij(&f, tbl); break; -#if defined(MIDICH) - case NP2FLAG_MIDI: - ret |= flagload_midi(&f, &np2tbl[i]); + case NP2FLAG_MEM: + ret |= flagload_mem(&f, tbl); break; -#endif default: ret |= NP2FLAG_WARNING; @@ -1390,6 +1498,10 @@ int statsave_load(const char *filename) gdcs.palchange = GDCSCRN_REDRAW; tramflag.renewal = 1; cgwindow.writable |= 0x80; +#if defined(CPUSTRUC_FONTPTR) + FONTPTR_LOW = fontrom + cgwindow.low; + FONTPTR_HIGH = fontrom + cgwindow.high; +#endif i286_vram_dispatch(vramop.operate); soundmng_play();