--- np2/io/gdc.c 2004/03/21 11:47:20 1.30 +++ np2/io/gdc.c 2004/03/23 22:39:40 1.32 @@ -404,6 +404,8 @@ const GDCCLK *clk; y = clk->maxy; } hclock = clk->clock / x; + gdc.hclock = hclock; + gdc.vclock = hclock * 10 / y; cnt = (pccore.baseclock * y) / hclock; cnt *= pccore.multiple; gdc.rasterclock = cnt / y; @@ -933,14 +935,67 @@ static REG8 IOINPCALL gdc_iae(UINT port) #if defined(SUPPORT_PC9821) static void IOOUTCALL gdc_o9a0(UINT port, REG8 dat) { + gdc.ff2 = dat; (void)port; - (void)dat; } static REG8 IOINPCALL gdc_i9a0(UINT port) { + REG8 ret; + + ret = 0; + switch(gdc.ff2) { + case 0x00: + ret = 0xff; + break; + + case 0x01: + ret = (gdc.mode1 >> 1) & 1; + break; + + case 0x02: + ret = (gdc.mode1 >> 4) & 1; + break; + + case 0x03: + ret = (gdc.mode1 >> 7) & 1; + break; + + case 0x04: + ret = (gdc.mode2 >> 0) & 1; + break; + + case 0x05: + ret = (gdc.display >> GDCDISP_PLAZMA) & 1; + break; + + case 0x07: + ret = (gdc.mode2 >> 2) & 1; + break; + + case 0x08: + ret = (gdc.mode2 >> 3) & 1; + break; + + case 0x09: + ret = (gdc.clock >> 0) & 1; + break; + + case 0x0a: + ret = (gdc.analog >> GDCANALOG_256) & 1; + break; + + case 0x0b: + ret = 1; + break; + + case 0x0d: + ret = (gdc.analog >> GDCANALOG_256E) & 1; + break; + } + ret |= (gdc.clock & 2); (void)port; - return(0); + return(ret); } #endif @@ -1087,7 +1142,7 @@ void gdc_reset(void) { void gdc_bind(void) { gdc_updateclock(); -#if defined(SUPPORT_PC9821) // とりあえずフックだけ +#if defined(SUPPORT_PC9821) iocore_attachout(0x09a0, gdc_o9a0); iocore_attachinp(0x09a0, gdc_i9a0); #endif