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