| version 1.70, 2004/02/18 21:58:41 | version 1.74, 2004/02/21 00:25:33 | 
| Line 7 | Line 7 | 
 | #include        "cpucore.h" | #include        "cpucore.h" | 
 | #include        "pccore.h" | #include        "pccore.h" | 
 | #include        "iocore.h" | #include        "iocore.h" | 
 |  | #include        "gdc_sub.h" | 
 | #include        "cbuscore.h" | #include        "cbuscore.h" | 
 | #include        "pc9861k.h" | #include        "pc9861k.h" | 
 | #include        "mpu98ii.h" | #include        "mpu98ii.h" | 
 |  | #include        "amd98.h" | 
 | #include        "bios.h" | #include        "bios.h" | 
 | #include        "biosmem.h" | #include        "biosmem.h" | 
 | #include        "vram.h" | #include        "vram.h" | 
| Line 120  static void pccore_set(void) { | Line 122  static void pccore_set(void) { | 
 | } | } | 
 | else { | else { | 
 | pccore.baseclock = PCBASECLOCK20;                       // 2.0MHz | pccore.baseclock = PCBASECLOCK20;                       // 2.0MHz | 
| pccore.cpumode = CPUMODE_8MHz; | pccore.cpumode = CPUMODE_8MHZ; | 
 | } | } | 
 | multiple = np2cfg.multiple; | multiple = np2cfg.multiple; | 
 | if (multiple == 0) { | if (multiple == 0) { | 
| Line 192  static void sound_init(void) { | Line 194  static void sound_init(void) { | 
 | pcm86gen_initialize(rate); | pcm86gen_initialize(rate); | 
 | pcm86gen_setvol(np2cfg.vol_pcm); | pcm86gen_setvol(np2cfg.vol_pcm); | 
 | cs4231_initialize(rate); | cs4231_initialize(rate); | 
 |  | amd98_initialize(rate); | 
 | } | } | 
 |  |  | 
 | static void sound_term(void) { | static void sound_term(void) { | 
 |  |  | 
 | soundmng_stop(); | soundmng_stop(); | 
 |  | amd98_deinitialize(); | 
 | rhythm_deinitialize(); | rhythm_deinitialize(); | 
 | fddmtrsnd_deinitialize(); | fddmtrsnd_deinitialize(); | 
 | sound_destroy(); | sound_destroy(); | 
| Line 285  void pccore_reset(void) { | Line 289  void pccore_reset(void) { | 
 | sound_init(); | sound_init(); | 
 | } | } | 
 |  |  | 
| ZeroMemory(mem, 0x110000);                                                                      // ver0.28 | ZeroMemory(mem, 0x110000); | 
 | ZeroMemory(mem + VRAM1_B, 0x18000); | ZeroMemory(mem + VRAM1_B, 0x18000); | 
 | ZeroMemory(mem + VRAM1_E, 0x08000); | ZeroMemory(mem + VRAM1_E, 0x08000); | 
 | ZeroMemory(mem + FONT_ADRS, 0x08000); | ZeroMemory(mem + FONT_ADRS, 0x08000); | 
| Line 403  static void drawscreen(void) { | Line 407  static void drawscreen(void) { | 
 | gdcs.grphdisp |= GDCSCRN_ALLDRAW2; | gdcs.grphdisp |= GDCSCRN_ALLDRAW2; | 
 | } | } | 
 | } | } | 
 | // ver0.28/pr4 |  | 
 | if (gdcs.textdisp & GDCSCRN_EXT) { | if (gdcs.textdisp & GDCSCRN_EXT) { | 
 | gdcs.textdisp &= ~GDCSCRN_EXT; | gdcs.textdisp &= ~GDCSCRN_EXT; | 
 | dispsync_renewalhorizontal(); | dispsync_renewalhorizontal(); | 
| Line 412  static void drawscreen(void) { | Line 415  static void drawscreen(void) { | 
 | screenupdate |= 2; | screenupdate |= 2; | 
 | } | } | 
 | } | } | 
| // ver0.28/pr4 | if (gdcs.palchange) { | 
| if (gdcs.palchange) {                                                                   // grphを先に |  | 
 | gdcs.palchange = 0; | gdcs.palchange = 0; | 
 | pal_change(0); | pal_change(0); | 
 | screenupdate |= 1; | screenupdate |= 1; | 
| Line 510  void screendisp(NEVENTITEM item) { | Line 512  void screendisp(NEVENTITEM item) { | 
 | gdc_work(GDCWORK_SLAVE); | gdc_work(GDCWORK_SLAVE); | 
 | gdc.vsync = 0; | gdc.vsync = 0; | 
 | screendispflag = 0; | screendispflag = 0; | 
| if (!np2cfg.DISPSYNC) {                                                                                 // ver0.29 | if (!np2cfg.DISPSYNC) { | 
 | drawscreen(); | drawscreen(); | 
 | } | } | 
 | pi = &pic.pi[0]; | pi = &pic.pi[0]; | 
| Line 535  void screenvsync(NEVENTITEM item) { | Line 537  void screenvsync(NEVENTITEM item) { | 
 | nevent_set(NEVENT_FLAMES, gdc.vsyncclock, screendisp, NEVENT_RELATIVE); | nevent_set(NEVENT_FLAMES, gdc.vsyncclock, screendisp, NEVENT_RELATIVE); | 
 |  |  | 
 | // drawscreenで pccore.vsyncclockが変更される可能性があります | // drawscreenで pccore.vsyncclockが変更される可能性があります | 
| if (np2cfg.DISPSYNC) {                                                                                  // ver0.29 | if (np2cfg.DISPSYNC) { | 
 | drawscreen(); | drawscreen(); | 
 | } | } | 
 | (void)item; | (void)item; | 
| Line 544  void screenvsync(NEVENTITEM item) { | Line 546  void screenvsync(NEVENTITEM item) { | 
 |  |  | 
 | // --------------------------------------------------------------------------- | // --------------------------------------------------------------------------- | 
 |  |  | 
| // #define      IPTRACE                 (1 << 12) | #define IPTRACE                 (1 << 12) | 
 |  |  | 
 | #if defined(TRACE) && IPTRACE | #if defined(TRACE) && IPTRACE | 
 | static UINT             trpos = 0; | static UINT             trpos = 0; | 
| Line 651  void pccore_exec(BOOL draw) { | Line 653  void pccore_exec(BOOL draw) { | 
 | CPU_DX, CPU_DS, CPU_DI, mem[0xa3fe0])); | CPU_DX, CPU_DS, CPU_DI, mem[0xa3fe0])); | 
 | } | } | 
 | #endif | #endif | 
| #if 0 | //                      if ((CPU_CS == 0x2516) && (CPU_IP == 0x97B0)) { | 
| if ((tr & 2) && (mem[0x0471e] == '\\')) { | //                              TRACEOUT(("DS = %.4x", CPU_DS)); | 
| TRACEOUT(("DTA BREAK %.4x:%.4x", CPU_CS, CPU_IP)); | //                      } | 
| TRACEOUT(("0471:000e %.2x %.2x %.2x %.2x %.2x %.2x %.2x %.2x", |  | 
| mem[0x0471e+0], mem[0x0471e+1], mem[0x0471e+2], mem[0x0471e+3], |  | 
| mem[0x0471e+4], mem[0x0471e+5], mem[0x0471e+6], mem[0x0471e+7])); |  | 
| tr -= 2; |  | 
| } |  | 
| // DOS6 |  | 
| if (CPU_CS == 0xffd0) { |  | 
| if (CPU_IP == 0xc4c2) { |  | 
| TRACEOUT(("DS:DX = %.4x:%.4x / CX = %.4x", CPU_DS, CPU_DX, CPU_CX)); |  | 
| } |  | 
| else if (CPU_IP == 0xc21d) { |  | 
| TRACEOUT(("-> DS:BX = %.4x:%.4x", CPU_DS, CPU_BX)); |  | 
| } |  | 
| } |  | 
| #endif |  | 
| #if 0 |  | 
| if ((CPU_CS == 0x0620) || (CPU_CS == 0x08a0)) { |  | 
| TRACEOUT(("%.4x:%.4x", CPU_CS, CPU_IP)); |  | 
| } |  | 
| #endif |  | 
| #if 0           // VX LIO |  | 
| if (CPU_CS == 0xf990) { |  | 
| if (CPU_IP == 0x07BE) { |  | 
| TRACEOUT(("%d,%d - %d,%d", CPU_BP, CPU_DX, CPU_SI, CPU_DI)); |  | 
| } |  | 
| } |  | 
| #endif |  | 
 | //                      i286x_step(); | //                      i286x_step(); | 
 | i286c_step(); | i286c_step(); | 
 | } | } |