--- xmil/ievent.c 2004/08/11 12:08:16 1.1 +++ xmil/ievent.c 2008/06/02 20:07:30 1.6 @@ -6,7 +6,7 @@ #include "ievent.h" - IEVENT ievent; +/* ここでデイジーチェイン */ typedef BRESULT (*IEVENTFN)(UINT id); @@ -18,31 +18,34 @@ static BRESULT dummy(UINT id) { } static const IEVENTFN ieventfn[IEVENT_MAX] = { - dummy, // IEVENT_SIO - dummy, // IEVENT_DMA - ieitem_ctc, // IEVENT_CTC0 - ieitem_ctc, // IEVENT_CTC1 - ieitem_ctc, // IEVENT_CTC2 - ieitem_scpu}; // IEVENT_SUBCPU + dummy, /* IEVENT_SIO */ + ieitem_dmac, /* IEVENT_DMA */ + ieitem_ctc, /* IEVENT_CTC0 */ + ieitem_ctc, /* IEVENT_CTC1 */ + ieitem_ctc, /* IEVENT_CTC2 */ + ieitem_scpu}; /* IEVENT_SUBCPU */ -// ---- - -void ievent_reset(void) { -} +/* ---- */ void ievent_progress(void) { UINT i; UINT bit; - if ((CPU_REQIRQ == 0) || (!Z80_ABLEINTERRUPT())) { + if ((CPU_REQIRQ == 0) || (Z80_DI)) { return; } for (i=0, bit=1; i> 1; + if (!(r & bit)) { + return; + } + nevent_forceexit(); +} + +void ievent_eoi(void) { + + UINT i; + UINT bit; + + if (CPU_IRQ == 0) { + return; + } + for (i=0, bit=1; i= IEVENT_CTC0) && (i <= IEVENT_CTC2)) { + ieeoi_ctc(i); + } + break; + } + } + if ((!(Z80_IFF & ((1 << IFF_IFLAG) | (1 << IFF_NMI)))) && + (CPU_REQIRQ != 0)) { + CPU_BASECLOCK -= CPU_REMCLOCK; + CPU_REMCLOCK = 0; } }