--- np2/cbus/boardx2.c 2003/10/16 17:58:00 1.1 +++ np2/cbus/boardx2.c 2004/02/03 08:24:40 1.4 @@ -9,24 +9,24 @@ #include "s98.h" -static void IOOUTCALL opn_o088(UINT port, BYTE dat) { +static void IOOUTCALL opn_o088(UINT port, REG8 dat) { opn.opn2reg = dat; (void)port; } -static void IOOUTCALL opn_o08a(UINT port, BYTE dat) { +static void IOOUTCALL opn_o08a(UINT port, REG8 dat) { if (opn.opn2reg < 0x10) { if (opn.opn2reg != 0x0e) { - psggen_setreg(&psg2, opn.opn2reg, dat); + psggen_setreg(&psg1, opn.opn2reg, dat); } } else { if (opn.opn2reg < 0x30) { if (opn.opn2reg == 0x28) { if ((dat & 0x0f) < 3) { - opngen_keyon((dat & 0x0f), dat); + opngen_keyon(dat & 0x0f, dat); } } else { @@ -44,19 +44,19 @@ static void IOOUTCALL opn_o08a(UINT port (void)port; } -static BYTE IOINPCALL opn_i088(UINT port) { +static REG8 IOINPCALL opn_i088(UINT port) { (void)port; return(fmtimer.status); } -static BYTE IOINPCALL opn_i08a(UINT port) { +static REG8 IOINPCALL opn_i08a(UINT port) { if (opn.opn2reg == 0x0e) { return(0xff); } if (opn.opn2reg < 0x10) { - return(psggen_getreg(&psg2, opn.opn2reg)); + return(psggen_getreg(&psg1, opn.opn2reg)); } (void)port; return(0xff); @@ -65,18 +65,18 @@ static BYTE IOINPCALL opn_i08a(UINT port // ---- -static void IOOUTCALL opna_o188(UINT port, BYTE dat) { +static void IOOUTCALL opna_o188(UINT port, REG8 dat) { opn.opnreg = 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); + psggen_setreg(&psg2, opn.opnreg, dat); } } else { @@ -88,11 +88,11 @@ static void IOOUTCALL opna_o18a(UINT por else if (opn.opnreg < 0x30) { if (opn.opnreg == 0x28) { if ((dat & 0x0f) < 3) { - opngen_keyon((dat & 0x0f)+3, dat); + opngen_keyon((dat & 0x0f) + 3, dat); } else if (((dat & 0x0f) != 3) && ((dat & 0x0f) < 7)) { - opngen_keyon((dat & 0x0f)+2, dat); + opngen_keyon((dat & 0x0f) + 2, dat); } } else { @@ -110,13 +110,13 @@ static void IOOUTCALL opna_o18a(UINT por (void)port; } -static void IOOUTCALL opna_o18c(UINT port, BYTE dat) { +static void IOOUTCALL opna_o18c(UINT port, REG8 dat) { opn.extreg = 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; @@ -133,25 +133,25 @@ 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) { - return(fmboard_getjoy(&psg1)); + return(fmboard_getjoy(&psg2)); } else if (opn.opnreg < 0x10) { - return(psggen_getreg(&psg1, opn.opnreg)); + return(psggen_getreg(&psg2, opn.opnreg)); } (void)port; return(opn.reg[opn.opnreg]); } -static BYTE IOINPCALL opna_i18c(UINT port) { +static REG8 IOINPCALL opna_i18c(UINT port) { if (opn.extend) { return((fmtimer.status & 3) | (opn.adpcmmask & 8)); @@ -160,7 +160,7 @@ 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]); @@ -169,7 +169,7 @@ static BYTE IOINPCALL opna_i18e(UINT por return(0xff); } -static void extendchannel(BYTE enable) { +static void extendchannel(REG8 enable) { opn.extend = enable; if (enable) { @@ -210,6 +210,12 @@ void boardx2_reset(void) { void boardx2_bind(void) { + fmboard_fmrestore(0, 2); + fmboard_fmrestore(3, 0); + fmboard_fmrestore(6, 1); + psggen_restore(&psg1); + psggen_restore(&psg2); + fmboard_rhyrestore(&rhythm, 0); sound_streamregist(&opngen, (SOUNDCB)opngen_getpcm); sound_streamregist(&psg1, (SOUNDCB)psggen_getpcm); sound_streamregist(&psg2, (SOUNDCB)psggen_getpcm);