--- np2/pccore.c 2005/03/05 11:58:02 1.101 +++ np2/pccore.c 2005/05/20 13:59:45 1.106 @@ -141,12 +141,23 @@ static void pccore_set(void) { // HDDの接続 (I/Oの使用状態が変わるので.. if (np2cfg.dipsw[1] & 0x20) { pccore.hddif |= PCHDD_IDE; +#if defined(SUPPORT_IDEIO) + sxsi_setdevtype(0x02, SXSIDEV_CDROM); +#endif + } + else { + sxsi_setdevtype(0x02, SXSIDEV_NC); } // 拡張メモリ extsize = 0; if (!(np2cfg.dipsw[2] & 0x80)) { - extsize = min(np2cfg.EXTMEM, 13); + extsize = np2cfg.EXTMEM; +#if defined(CPUCORE_IA32) + extsize = min(extsize, 63); +#else + extsize = min(extsize, 13); +#endif } pccore.extmem = extsize; CopyMemory(pccore.dipsw, np2cfg.dipsw, 3); @@ -217,11 +228,6 @@ void pccore_init(void) { dispsync_initialize(); sxsi_initialize(); - // CDドライブの接続 -#if defined(SUPPORT_IDEIO) - sxsi_setdevtype(0x02, SXSIDEV_CDROM); -#endif - font_initialize(); font_load(np2cfg.fontfile, TRUE); maketext_initialize(); @@ -325,7 +331,7 @@ void pccore_reset(void) { } // HDDセット - sxsihdd_allbind(); + diskdrv_hddbind(); // SASI/IDEどっち? #if defined(SUPPORT_SASI) if (sxsi_issasi()) { @@ -353,7 +359,7 @@ void pccore_reset(void) { cbuscore_reset(); fmboard_reset(pccore.sound); - i286_memorymap((pccore.model & PCMODEL_EPSON)?1:0); + MEMM_ARCH((pccore.model & PCMODEL_EPSON)?1:0); iocore_build(); iocore_bind(); cbuscore_bind(); @@ -558,6 +564,8 @@ void screenvsync(NEVENTITEM item) { // --------------------------------------------------------------------------- +// #define SINGLESTEPONLY + #if defined(TRACE) static int resetcnt = 0; static int execcnt = 0; @@ -596,6 +604,7 @@ void pccore_exec(BOOL draw) { CPU_RESETREQ = 0; CPU_SHUT(); } +#if !defined(SINGLESTEPONLY) if (CPU_REMCLOCK > 0) { if (!(CPU_TYPE & CPUTYPE_V30)) { CPU_EXEC(); @@ -604,6 +613,11 @@ void pccore_exec(BOOL draw) { CPU_EXECV30(); } } +#else + while(CPU_REMCLOCK > 0) { + CPU_STEPEXEC(); + } +#endif nevent_progress(); } artic_callback();