--- xmil/io/subcpu.c 2004/08/08 06:59:22 1.2 +++ xmil/io/subcpu.c 2004/08/11 16:09:04 1.5 @@ -3,42 +3,51 @@ #include "z80core.h" #include "pccore.h" #include "iocore.h" +#include "nevent.h" +#include "ievent.h" #include "keystat.h" #include "calendar.h" // e3 e4 e5 e6 e7 e8 e9 ea eb ec ed ee ef -static const UINT8 CMD_TBL[] = { 0, 1, 0, 0, 1, 0, 1, 0, 0, 3, 0, 3, 0}; -static const UINT8 DAT_TBL[] = { 3, 0, 0, 2, 0, 1, 0, 1, 1, 0, 3, 0, 3}; +static const UINT8 cmdtbl[] = { 0, 1, 0, 0, 1, 0, 1, 0, 0, 3, 0, 3, 0}; +static const UINT8 dattbl[] = { 3, 0, 0, 2, 0, 1, 0, 1, 1, 0, 3, 0, 3}; //********************************************************************** -// キーボード割り込み -short x1_sub_int(void) { // 990922 +void neitem_scpu(UINT id) { + + nevent_repeat(id); + if (keystat.req_int) { + keystat.req_int = 0; + ievent_set(IEVENT_SUBCPU); + } +} + +BRESULT ieitem_scpu(UINT id) { UINT key; - if ((!keystat.req_int) || (subcpu.cmdcnt) || (subcpu.datacnt) || - (!Z80_ABLEINTERRUPT())) { // 割り込めなかったら - return(1); // また来週〜 + if ((subcpu.cmdcnt) || (subcpu.datacnt)) { + keystat.req_int = 1; // 再送しる + return(FALSE); } - keystat.req_int = 0; if (!subcpu.Ex[4][0]) { // 割り込み不要だったら捨てる - return(1); + return(FALSE); } if (keystat.shift & 0x40) { // キーが押された場合 key = keystat_getflag(); subcpu.Ex[0x06][0] = (UINT8)(key >> 0); subcpu.Ex[0x06][1] = (UINT8)(key >> 8); if (!subcpu.Ex[0x06][1]) { // 無効なキーだったら捨てる - return(1); + return(FALSE); } subcpu.INT_SW = 1; } else { if (!subcpu.INT_SW) { // 何も押されてなかったら割り込まない - return(1); + return(FALSE); } subcpu.INT_SW = 0; key = keystat_getflag(); @@ -52,11 +61,13 @@ short x1_sub_int(void) { // 99092 subcpu.OBF = 0; subcpu.IBF = 1; - Z80_INT2(subcpu.Ex[4][0]); - return(0); + Z80_INTERRUPT(subcpu.Ex[4][0]); + (void)id; + return(TRUE); } -//********************************************************************** + +// ---- void IOOUTCALL subcpu_o(UINT port, REG8 value) { @@ -69,17 +80,17 @@ void IOOUTCALL subcpu_o(UINT port, REG8 subcpu.mode = (UINT8)value; subcpu.cmdcnt = 0; subcpu.datacnt = 0; - if (value >= 0xd0 && value <= 0xd7) { + if ((value >= 0xd0) && (value <= 0xd7)) { subcpu.cmdcnt = 6; subcpu.datacnt = 0; } - else if (value >= 0xd8 && value <= 0xdf) { + else if ((value >= 0xd8) && (value <= 0xdf)) { subcpu.cmdcnt = 0; subcpu.datacnt = 6; } - else if (value >= 0xe3 && value <= 0xef) { - subcpu.cmdcnt = CMD_TBL[value - 0xe3]; - subcpu.datacnt = DAT_TBL[value - 0xe3]; + else if ((value >= 0xe3) && (value <= 0xef)) { + subcpu.cmdcnt = cmdtbl[value - 0xe3]; + subcpu.datacnt = dattbl[value - 0xe3]; } if (value < 0xe0) { subcpu.dataptr = offsetof(SUBCPU, Dx[value - 0xd0][0]); @@ -227,5 +238,7 @@ void subcpu_reset(void) { ZeroMemory(&subcpu, sizeof(subcpu)); subcpu.OBF = 1; + nevent_set(NEVENT_SUBCPU, pccore.realclock / 480, + neitem_scpu, NEVENT_ABSOLUTE); }