--- np2/io/iocore.c 2005/02/12 12:40:39 1.21 +++ np2/io/iocore.c 2007/11/03 00:00:20 1.23 @@ -68,8 +68,16 @@ static UINT8 ioterminate[0x100]; static void IOOUTCALL defout8(UINT port, REG8 dat) { #if !defined(DISABLE_SOUND) - if ((port & 0xfff0) == cs4231.port) { - cs4231io_w8(port, dat); + UINT tmp; + + tmp = port - cs4231.port[0]; + if (tmp < 8) { + cs4231io0_w8(port, dat); + return; + } + tmp = port - cs4231.port[5]; + if (tmp < 2) { + cs4231io5_w8(port, dat); return; } #endif @@ -83,8 +91,15 @@ static void IOOUTCALL defout8(UINT port, static REG8 IOINPCALL definp8(UINT port) { #if !defined(DISABLE_SOUND) - if ((port & 0xfff0) == cs4231.port) { - return(cs4231io_r8(port)); + UINT tmp; + + tmp = port - cs4231.port[0]; + if (tmp < 8) { + return(cs4231io0_r8(port)); + } + tmp = port - cs4231.port[5]; + if (tmp < 2) { + return(cs4231io5_r8(port)); } #endif if ((port & 0xf0ff) == 0x801e) { @@ -426,7 +441,8 @@ icbld_err: // ---- -static const IOCBFN resetfn[] = { +static const FNIORESET resetfn[] = +{ // PC-9801 System... cgrom_reset, crtc_reset, dmac_reset, gdc_reset, fdc_reset, @@ -443,9 +459,10 @@ static const IOCBFN resetfn[] = { #if defined(SUPPORT_PC9821) pcidev_reset, #endif - }; +}; -static const IOCBFN bindfn[] = { +static const FNIOBIND bindfn[] = +{ // PC-9801 System... cgrom_bind, cpuio_bind, crtc_bind, dmac_bind, gdc_bind, fdc_bind, @@ -462,26 +479,36 @@ static const IOCBFN bindfn[] = { #if defined(SUPPORT_PC9821) pcidev_bind, #endif - }; +}; -void iocore_cb(const IOCBFN *cbfn, UINT count) { - - while(count--) { - (*cbfn)(); - cbfn++; +void iocore_cbreset(const FNIORESET *pfn, UINT uCount, const NP2CFG *pConfig) +{ + while(uCount--) + { + (*pfn)(pConfig); + pfn++; } } -void iocore_reset(void) { - - iocore_cb(resetfn, NELEMENTS(resetfn)); +void iocore_cbbind(const FNIOBIND *pfn, UINT uCount) +{ + while(uCount--) + { + (*pfn)(); + pfn++; + } } -void iocore_bind(void) { +void iocore_reset(const NP2CFG *pConfig) +{ + iocore_cbreset(resetfn, NELEMENTS(resetfn), pConfig); +} +void iocore_bind(void) +{ iocore.busclock = pccore.multiple; - iocore_cb(bindfn, NELEMENTS(bindfn)); + iocore_cbbind(bindfn, NELEMENTS(bindfn)); } void IOOUTCALL iocore_out8(UINT port, REG8 dat) {