--- np2/cbus/board86.c 2003/10/16 17:58:00 1.1 +++ np2/cbus/board86.c 2007/11/03 00:00:19 1.8 @@ -9,28 +9,36 @@ #include "s98.h" -static void IOOUTCALL opna_o188(UINT port, BYTE dat) { +static void IOOUTCALL opna_o188(UINT port, REG8 dat) { - opn.opnreg = dat; + opn.addr = dat; + opn.data = dat; (void)port; } -static void IOOUTCALL opna_o18a(UINT port, BYTE dat) { +static void IOOUTCALL opna_o18a(UINT port, REG8 dat) { - S98_put(NORMAL2608, opn.opnreg, dat); - if (opn.opnreg < 0x10) { - if (opn.opnreg != 0x0e) { - psggen_setreg(&psg1, opn.opnreg, dat); + UINT addr; + + opn.data = dat; + addr = opn.addr; + if (addr >= 0x100) { + return; + } + S98_put(NORMAL2608, addr, dat); + if (addr < 0x10) { + if (addr != 0x0e) { + psggen_setreg(&psg1, addr, dat); } } else { - if (opn.opnreg < 0x20) { + if (addr < 0x20) { if (opn.extend) { - rhythm_setreg(&rhythm, opn.opnreg, dat); + rhythm_setreg(&rhythm, addr, dat); } } - else if (opn.opnreg < 0x30) { - if (opn.opnreg == 0x28) { + else if (addr < 0x30) { + if (addr == 0x28) { if ((dat & 0x0f) < 3) { opngen_keyon(dat & 0x0f, dat); } @@ -40,35 +48,48 @@ static void IOOUTCALL opna_o18a(UINT por } } else { - fmtimer_setreg(opn.opnreg, dat); - if (opn.opnreg == 0x27) { + fmtimer_setreg(addr, dat); + if (addr == 0x27) { opnch[2].extop = dat & 0xc0; } } } - else if (opn.opnreg < 0xc0) { - opngen_setreg(0, opn.opnreg, dat); + else if (addr < 0xc0) { + opngen_setreg(0, addr, dat); } - opn.reg[opn.opnreg] = dat; + opn.reg[addr] = dat; } (void)port; } -static void IOOUTCALL opna_o18c(UINT port, BYTE dat) { +static void IOOUTCALL opna_o18c(UINT port, REG8 dat) { - opn.extreg = dat; + if (opn.extend) { + opn.addr = dat + 0x100; + opn.data = dat; + } (void)port; } -static void IOOUTCALL opna_o18e(UINT port, BYTE dat) { +static void IOOUTCALL opna_o18e(UINT port, REG8 dat) { - S98_put(EXTEND2608, opn.extreg, dat); - opn.reg[opn.extreg + 0x100] = dat; - if (opn.extreg >= 0x30) { - opngen_setreg(3, opn.extreg, dat); + UINT addr; + + if (!opn.extend) { + return; + } + opn.data = dat; + addr = opn.addr - 0x100; + if (addr >= 0x100) { + return; + } + S98_put(EXTEND2608, addr, dat); + opn.reg[addr + 0x100] = dat; + if (addr >= 0x30) { + opngen_setreg(3, addr, dat); } else { - if (opn.extreg == 0x10) { + if (addr == 0x10) { if (!(dat & 0x80)) { opn.adpcmmask = ~(dat & 0x1c); } @@ -77,25 +98,31 @@ static void IOOUTCALL opna_o18e(UINT por (void)port; } -static BYTE IOINPCALL opna_i188(UINT port) { +static REG8 IOINPCALL opna_i188(UINT port) { (void)port; return(fmtimer.status); } -static BYTE IOINPCALL opna_i18a(UINT port) { +static REG8 IOINPCALL opna_i18a(UINT port) { - if (opn.opnreg == 0x0e) { + UINT addr; + + addr = opn.addr; + if (addr == 0x0e) { return(fmboard_getjoy(&psg1)); } - else if (opn.opnreg < 0x10) { - return(psggen_getreg(&psg1, opn.opnreg)); + else if (addr < 0x10) { + return(psggen_getreg(&psg1, addr)); + } + else if (addr == 0xff) { + return(1); } (void)port; - return(opn.reg[opn.opnreg]); + return(opn.data); } -static BYTE IOINPCALL opna_i18c(UINT port) { +static REG8 IOINPCALL opna_i18c(UINT port) { if (opn.extend) { return((fmtimer.status & 3) | (opn.adpcmmask & 8)); @@ -104,16 +131,20 @@ static BYTE IOINPCALL opna_i18c(UINT por return(0xff); } -static BYTE IOINPCALL opna_i18e(UINT port) { +static REG8 IOINPCALL opna_i18e(UINT port) { if (opn.extend) { - return(opn.reg[opn.opnreg]); + UINT addr = opn.addr - 0x100; + if ((addr == 0x08) || (addr == 0x0f)) { + return(opn.reg[addr + 0x100]); + } + return(opn.data); } (void)port; return(0xff); } -static void extendchannel(BYTE enable) { +static void extendchannel(REG8 enable) { opn.extend = enable; if (enable) { @@ -137,24 +168,28 @@ static const IOINP opna_i[4] = { opna_i188, opna_i18a, opna_i18c, opna_i18e}; -void board86_reset(void) { +void board86_reset(const NP2CFG *pConfig) { - fmtimer_reset((BYTE)((np2cfg.snd86opt & 0x10) | - ((np2cfg.snd86opt & 0x4) << 5) | - ((np2cfg.snd86opt & 0x8) << 3))); + fmtimer_reset((pConfig->snd86opt & 0x10) | + ((pConfig->snd86opt & 0x4) << 5) | + ((pConfig->snd86opt & 0x8) << 3)); opngen_setcfg(3, OPN_STEREO | 0x038); - if (np2cfg.snd86opt & 2) { - soundrom_load(0xcc000, "86"); + if (pConfig->snd86opt & 2) { + soundrom_load(0xcc000, OEMTEXT("86")); } - opn.base = (np2cfg.snd86opt & 0x01)?0x000:0x100; + opn.base = (pConfig->snd86opt & 0x01)?0x000:0x100; fmboard_extreg(extendchannel); } void board86_bind(void) { + fmboard_fmrestore(0, 0); + fmboard_fmrestore(3, 1); + psggen_restore(&psg1); + fmboard_rhyrestore(&rhythm, 0); sound_streamregist(&opngen, (SOUNDCB)opngen_getpcm); sound_streamregist(&psg1, (SOUNDCB)psggen_getpcm); - sound_streamregist(&rhythm, (SOUNDCB)rhythm_getpcm); + rhythm_bind(&rhythm); pcm86io_bind(); cbuscore_attachsndex(0x188 + opn.base, opna_o, opna_i); } @@ -162,23 +197,32 @@ void board86_bind(void) { // ---- + chibioto -static void IOOUTCALL opnac_o18e(UINT port, BYTE dat) { +static void IOOUTCALL opnac_o18e(UINT port, REG8 dat) { - S98_put(EXTEND2608, opn.extreg, dat); - opn.reg[opn.extreg + 0x100] = dat; - if (opn.extreg >= 0x30) { - opngen_setreg(3, opn.extreg, dat); + UINT addr; + + if (!opn.extend) { + return; + } + opn.data = dat; + addr = opn.addr - 0x100; + if (addr >= 0x100) { + return; + } + S98_put(EXTEND2608, addr, dat); + opn.reg[addr + 0x100] = dat; + if (addr >= 0x30) { + opngen_setreg(3, addr, dat); } else { - if (opn.extreg < 0x12) { - sound_sync(); - adpcm_setreg(&adpcm, opn.extreg, dat); + if (addr < 0x12) { + adpcm_setreg(&adpcm, addr, dat); } } (void)port; } -static BYTE IOINPCALL opnac_i18c(UINT port) { +static REG8 IOINPCALL opnac_i18c(UINT port) { if (opn.extend) { return((fmtimer.status & 3) | adpcm_status(&adpcm)); @@ -188,13 +232,17 @@ static BYTE IOINPCALL opnac_i18c(UINT po return(0xff); } -static BYTE IOINPCALL opnac_i18e(UINT port) { +static REG8 IOINPCALL opnac_i18e(UINT port) { if (opn.extend) { - if (opn.extreg == 0x08) { + UINT addr = opn.addr - 0x100; + if (addr == 0x08) { return(adpcm_readsample(&adpcm)); } - return(opn.reg[opn.opnreg]); + else if (addr == 0x0f) { + return(opn.reg[addr + 0x100]); + } + return(opn.data); } (void)port; return(0xff); @@ -209,9 +257,13 @@ static const IOINP opnac_i[4] = { void board86c_bind(void) { + fmboard_fmrestore(0, 0); + fmboard_fmrestore(3, 1); + psggen_restore(&psg1); + fmboard_rhyrestore(&rhythm, 0); sound_streamregist(&opngen, (SOUNDCB)opngen_getpcm); sound_streamregist(&psg1, (SOUNDCB)psggen_getpcm); - sound_streamregist(&rhythm, (SOUNDCB)rhythm_getpcm); + rhythm_bind(&rhythm); sound_streamregist(&adpcm, (SOUNDCB)adpcm_getpcm); pcm86io_bind(); cbuscore_attachsndex(0x188 + opn.base, opnac_o, opnac_i);