Diff for /np2/pccore.c between versions 1.2 and 1.111

version 1.2, 2003/10/17 03:52:24 version 1.111, 2011/02/23 10:11:44
Line 1 Line 1
   /**
    * @file        pccore.c
    * @brief       emluration core
    *
    * @author      $Author$
    * @date        $Date$
    */
   
 #include        "compiler.h"  #include        "compiler.h"
   #include        "strres.h"
 #include        "dosio.h"  #include        "dosio.h"
 #include        "scrnmng.h"  
 #include        "soundmng.h"  #include        "soundmng.h"
 #include        "sysmng.h"  #include        "sysmng.h"
 #include        "timemng.h"  #include        "timemng.h"
   #include        "cpucore.h"
 #include        "i286.h"  
 #include        "memory.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        "mpu98ii.h"
   #include        "amd98.h"
   #include        "bios.h"
   #include        "biosmem.h"
 #include        "vram.h"  #include        "vram.h"
 #include        "scrndraw.h"  #include        "scrndraw.h"
   #include        "dispsync.h"
 #include        "palettes.h"  #include        "palettes.h"
 #include        "maketext.h"  #include        "maketext.h"
 #include        "maketgrp.h"  #include        "maketgrp.h"
 #include        "makegrph.h"  #include        "makegrph.h"
   #include        "makegrex.h"
 #include        "sound.h"  #include        "sound.h"
 #include        "beep.h"  
 #include        "fmboard.h"  #include        "fmboard.h"
 #include        "bios.h"  #include        "beep.h"
 #include        "timing.h"  #include        "s98.h"
 #include        "dialog.h"  
 #include        "fddfile.h"  
 #include        "fdd_mtr.h"  
 #include        "calendar.h"  
 #include        "font.h"  #include        "font.h"
 #include        "dispsync.h"  
 //#include      "hostdrv.h"  
 #include        "mpu98ii.h"  
 #include        "diskdrv.h"  #include        "diskdrv.h"
   #include        "fddfile.h"
   #include        "fdd_mtr.h"
 #include        "sxsi.h"  #include        "sxsi.h"
   #if defined(SUPPORT_HOSTDRV)
   #include        "hostdrv.h"
   #endif
   #include        "np2ver.h"
   #include        "calendar.h"
   #include        "timing.h"
   #include        "keystat.h"
   #include        "debugsub.h"
   
 #include        "keydisp.h"  
 #include        "pc9861k.h"  
   
   const OEMCHAR np2version[] = OEMTEXT(NP2VER_CORE);
   
   #if defined(_WIN32_WCE)
   #define PCBASEMULTIPLE  2
   #else
   #define PCBASEMULTIPLE  4
   #endif
   
         const char      np2version[] = "ver.0.36";  
   
         NP2CFG          np2cfg = {          NP2CFG  np2cfg = {
                                 PCBASECLOCK25, 4, 0,                                  0, 1, 0, 32, 0, 0, 0x40,
                                 {0x3e, 0x63, 0x7a},                                  0, 0, 0, 0,
                                 {0x48, 0x05, 0x0c, 0x00, 0x01, 0x00, 0x00, 0x6E},                                  {0x3e, 0x73, 0x7b}, 0,
                                 {0x0c, 0x08, 0x0c, 0x06, 0x03, 0x0c},                           // ver0.27                                  0, 0, {1, 1, 6, 1, 8, 1},
                                 {1, 1, 6, 1, 8, 1},  
                                 0, 4, 32, 22050, 800, 0, 1, 1, 0,                                  OEMTEXT("VX"), PCBASECLOCK25, PCBASEMULTIPLE,
                                 0, 0,                                  {0x48, 0x05, 0x04, 0x00, 0x01, 0x00, 0x00, 0x6e},
 //                              0, 0, {1, 2, 2, 1},                                                     // ver0.28                                  1, 1, 2, 1, 0x000000, 0xffffff,
                                 0, {0, 0, 0}, 0xd1, 0x7f, 0xd1, 0, 0, 1, 0x82,          // ver0.30                                  22050, 500, 4, 0,
                                 1, 80, 3, 1, 1, 0, 0x000000, 0xffffff,                                  {0, 0, 0}, 0xd1, 0x7f, 0xd1, 0, 0, 1,
                                 0, 0, 0, 0x40, 0,                                  3, {0x0c, 0x0c, 0x08, 0x06, 0x03, 0x0c}, 64, 64, 64, 64, 64,
                                 64, 64, 64, 64, 64,                                                                     // ver0.27                                  1, 0x82,
                                 0, {0x17, 0x04, 0x1f}, {0x0c, 0x0c, 0x02, 0x10, 0x3f, 0x3f},                                  0, {0x17, 0x04, 0x1f}, {0x0c, 0x0c, 0x02, 0x10, 0x3f, 0x3f},
                                 2, 1, 0, 0,                                  3, 1, 80, 0, 0,
                                 {"", ""}, ""};                                  {OEMTEXT(""), OEMTEXT("")},
   #if defined(SUPPORT_SCSI)
                                   {OEMTEXT(""), OEMTEXT(""), OEMTEXT(""), OEMTEXT("")},
   #endif
                                   OEMTEXT(""), OEMTEXT(""), OEMTEXT("")};
   
         PCCORE  pc = {  PCBASECLOCK25,          PCCORE  pccore = {      PCBASECLOCK25, PCBASEMULTIPLE,
                                                         4,                                                  0, PCMODEL_VX, 0, 0, {0x3e, 0x73, 0x7b}, 0,
                                                         4 * PCBASECLOCK25,                                                  0, 0,
                                                         4 * PCBASECLOCK25 * 50 / 3104,                                                  PCBASECLOCK25 * PCBASEMULTIPLE};
                                                         4 * PCBASECLOCK25 * 5 / 3104,          PCSTAT  pcstat = {3, TRUE, FALSE, FALSE};
                                                         4 * PCBASECLOCK25 / 120,  
                                                         4 * PCBASECLOCK25 / 200,  //      UINT8   screenupdate = 3;
                                                         4 * PCBASECLOCK25 / 100,  //      int             screendispflag = 1;
                                                         4 * PCBASECLOCK25 / 1920,          UINT8   soundrenewal = 0;
                                                         4 * PCBASECLOCK25 / 3125,  //      BOOL    drawframe;
                                                         (4 * PCBASECLOCK25 / 22050) + 1,  
                                                         (4 * PCBASECLOCK25 / 56400),  
                                                         100, 20,  
                                                         0};  
   
                                                                         // on=0, off=1  
         BYTE    dip_default[3] = {0x3e, 0x63, 0x7a};  
         BYTE    msw_default[8] = {0x48, 0x05, 0x04, 0x00, 0x01, 0x00, 0x00, 0x6E};  
   
         BYTE    screenupdate = 3;  
         int             screendispflag = 1;  
         int             soundrenewal = 0;  
         BOOL    drawframe;  
         UINT    drawcount = 0;          UINT    drawcount = 0;
   //      BOOL    hardwarereset = FALSE;
         BYTE    mem[0x200000];                                                          // ver0.28  
   
   
 // ---------------------------------------------------------------------------  // ---------------------------------------------------------------------------
   
 static void setvsyncclock(void) {                                                               // ver0.28  void getbiospath(OEMCHAR *path, const OEMCHAR *fname, int maxlen) {
   
         UINT    vfp;  const OEMCHAR   *p;
         UINT    vbp;  
         UINT    lf;          p = np2cfg.biospath;
         UINT    disp;          if (p[0]) {
         UINT    vs;                  file_cpyname(path, p, maxlen);
         UINT    maxy;                  file_setseparator(path, maxlen);
         UINT    cnt;                  file_catname(path, fname, maxlen);
   
         vfp = gdc.m.para[GDC_SYNC + 5] & 0x3f;  
         if (!vfp) {  
                 vfp = 1;  
         }  
         vbp = gdc.m.para[GDC_SYNC + 7] >> 2;  
         if (!vbp) {  
                 vbp = 1;  
         }  
         lf = LOADINTELWORD(gdc.m.para + GDC_SYNC + 6);  
         lf &= 0x3ff;  
         if (!lf) {  
                 lf = 1024;  
         }  
         disp = vfp + vbp + lf;  
         vs = LOADINTELWORD(gdc.m.para + GDC_SYNC + 4);  
         vs = (vs >> 5) & 0x1f;  
         if (!vs) {  
                 vs = 1;  
         }  
         maxy = disp + vs;  
         cnt = (pc.realclock * 5) / 282;  
         pc.raster = cnt / maxy;  
         pc.hsync = (pc.raster * 4) / 5;  
         pc.dispclock = pc.raster * disp;  
         pc.vsyncclock = cnt - pc.dispclock;  
 }  
   
 static void setpcclock(UINT base, UINT multiple) {                      // ver0.28  
   
         if (base >= ((PCBASECLOCK25 + PCBASECLOCK20) / 2)) {  
                 pc.baseclock = PCBASECLOCK25;                   // 2.5MHz  
                 pc.cpumode = 0;  
         }          }
         else {          else {
                 pc.baseclock = PCBASECLOCK20;                   // 2.0MHz                  file_cpyname(path, file_getcd(fname), maxlen);
                 pc.cpumode = CPUMODE_8MHz;  
         }          }
         if (multiple == 0) {  }
   
   
   // ----
   
   static void pccore_set(const NP2CFG *pConfig)
   {
           UINT8   model;
           UINT32  multiple;
           UINT8   extsize;
   
           ZeroMemory(&pccore, sizeof(pccore));
           model = PCMODEL_VX;
           if (!milstr_cmp(pConfig->model, str_VM)) {
                   model = PCMODEL_VM;
           }
           else if (!milstr_cmp(pConfig->model, str_EPSON)) {
                   model = PCMODEL_EPSON | PCMODEL_VM;
           }
           pccore.model = model;
   
           if (np2cfg.baseclock >= ((PCBASECLOCK25 + PCBASECLOCK20) / 2))
           {
                   pccore.baseclock = PCBASECLOCK25;                       // 2.5MHz
                   pccore.cpumode = 0;
           }
           else
           {
                   pccore.baseclock = PCBASECLOCK20;                       // 2.0MHz
                   pccore.cpumode = CPUMODE_8MHZ;
           }
           multiple = pConfig->multiple;
           if (multiple == 0)
           {
                 multiple = 1;                  multiple = 1;
         }          }
         else if (multiple > 32) {          else if (multiple > 32)
           {
                 multiple = 32;                  multiple = 32;
         }          }
         pc.multiple = multiple;          pccore.multiple = multiple;
         pc.realclock = pc.baseclock * multiple;          pccore.realclock = pccore.baseclock * multiple;
         pc.raster = pc.realclock / 24816;                                                       // ver0.28  
         pc.hsync = (pc.raster * 4) / 5;                                                         // ver0.28          // HDDの接続 (I/Oの使用状態が変わるので..
         pc.dispclock = pc.realclock * 50 / 3102;          if (pConfig->dipsw[1] & 0x20)
         pc.vsyncclock = pc.realclock * 5 / 3102;          {
         pc.mouseclock = pc.realclock / 120;                  pccore.hddif |= PCHDD_IDE;
         pc.dsoundclock = (pc.realclock) / 200;                          // ver0.28  #if defined(SUPPORT_IDEIO)
         pc.dsoundclock2 = pc.realclock / 100;                  sxsi_setdevtype(0x02, SXSIDEV_CDROM);
         pc.keyboardclock = pc.realclock / 1920;  #endif
         pc.midiclock = pc.realclock / 3125;  
         pc.frame1000 = pc.realclock / 56400;  
         if (opna_rate) {  
 //              pc.sampleclock = (pc.realclock / opna_rate) + 1;  
                 pc.sampleclock = (pc.realclock / opna_rate);  
         }          }
         else {          else
                 pc.sampleclock = 0;          {
                   sxsi_setdevtype(0x02, SXSIDEV_NC);
           }
   
           // 拡張メモリ
           extsize = 0;
           if (!(pConfig->dipsw[2] & 0x80))
           {
                   extsize = np2cfg.EXTMEM;
   #if defined(CPUCORE_IA32)
                   extsize = min(extsize, 63);
   #else
                   extsize = min(extsize, 13);
   #endif
           }
           pccore.extmem = extsize;
           CopyMemory(pccore.dipsw, pConfig->dipsw, 3);
   
           // サウンドボードの接続
           pccore.sound = pConfig->SOUND_SW;
   
           // その他CBUSの接続
           pccore.device = 0;
           if (pConfig->pc9861enable)
           {
                   pccore.device |= PCCBUS_PC9861K;
           }
           if (pConfig->mpuenable)
           {
                   pccore.device |= PCCBUS_MPU98;
         }          }
 }  }
   
   
 // --------------------------------------------------------------------------  // --------------------------------------------------------------------------
   
 static void sound_init(void) {  #if !defined(DISABLE_SOUND)
   static void sound_init(void)
   {
         UINT    rate;          UINT    rate;
   
         rate = np2cfg.samplingrate;          rate = np2cfg.samplingrate;
         if ((rate != 11025) && (rate != 22050) && (rate != 44100)) {          if ((rate != 11025) && (rate != 22050) && (rate != 44100))
           {
                 rate = 0;                  rate = 0;
         }          }
         sound_create(rate, np2cfg.delayms);          sound_create(rate, np2cfg.delayms);
           fddmtrsnd_initialize(rate);
         beep_initialize(rate);          beep_initialize(rate);
         beep_setvol(np2cfg.BEEP_VOL);          beep_setvol(np2cfg.BEEP_VOL);
         tms3631_initialize(rate);          tms3631_initialize(rate);
Line 188  static void sound_init(void) { Line 222  static void sound_init(void) {
         adpcm_setvol(np2cfg.vol_adpcm);          adpcm_setvol(np2cfg.vol_adpcm);
         pcm86gen_initialize(rate);          pcm86gen_initialize(rate);
         pcm86gen_setvol(np2cfg.vol_pcm);          pcm86gen_setvol(np2cfg.vol_pcm);
           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();
           beep_deinitialize();
           fddmtrsnd_deinitialize();
         sound_destroy();          sound_destroy();
 }  }
   #endif
   
 void pccore_init(void) {  void pccore_init(void) {
   
           CPU_INITIALIZE();
   
         pal_initlcdtable();          pal_initlcdtable();
         pal_makelcdpal();          pal_makelcdpal();
         pal_makeskiptable();          pal_makeskiptable();
         dispsync_init();          dispsync_initialize();
         sxsi_initialize();          sxsi_initialize();
   
         font_init();          font_initialize();
         font_load(np2cfg.fontfile, TRUE);          font_load(np2cfg.fontfile, TRUE);
         maketext_init();          maketext_initialize();
         makegrph_init();          makegrph_initialize();
         gdcsub_init();          gdcsub_initialize();
         fddfile_init();          fddfile_initialize();
   
   #if !defined(DISABLE_SOUND)
         sound_init();          sound_init();
   #endif
   
         mpu98ii_construct();  
         rs232c_construct();          rs232c_construct();
         pc9861k_construct();          mpu98ii_construct();
           pc9861k_initialize();
   
         iocore_create();          iocore_create();
   
   #if defined(SUPPORT_HOSTDRV)
           hostdrv_initialize();
   #endif
 }  }
   
 void pccore_term(void) {  void pccore_term(void) {
   
   #if defined(SUPPORT_HOSTDRV)
           hostdrv_deinitialize();
   #endif
   
   #if !defined(DISABLE_SOUND)
           sound_term();
   #endif
   
         fdd_eject(0);          fdd_eject(0);
         fdd_eject(1);          fdd_eject(1);
         fdd_eject(2);          fdd_eject(2);
         fdd_eject(3);          fdd_eject(3);
   
         extmemmng_clear();                                                                                              // ver0.28  
   
         iocore_destroy();          iocore_destroy();
   
         pc9861k_destruct();          pc9861k_deinitialize();
         rs232c_destruct();  
         mpu98ii_destruct();          mpu98ii_destruct();
           rs232c_destruct();
   
         sound_term();          sxsi_alltrash();
   
         sxsi_trash();          CPU_DEINITIALIZE();
 }  }
   
   
Line 248  void pccore_cfgupdate(void) { Line 302  void pccore_cfgupdate(void) {
         int             i;          int             i;
   
         renewal = FALSE;          renewal = FALSE;
         for (i=0; i<8; i++) {          for (i=0; i<8; i++)
                 if (np2cfg.memsw[i] != mem[0xa3fe2 + i*4]) {          {
                         np2cfg.memsw[i] = mem[0xa3fe2 + i*4];                  if (np2cfg.memsw[i] != mem[MEMX_MSW + i*4])
                   {
                           np2cfg.memsw[i] = mem[MEMX_MSW + i*4];
                           renewal = TRUE;
                   }
           }
           for (i=0; i<3; i++)
           {
                   if (np2cfg.dipsw[i] != pccore.dipsw[i])
                   {
                           np2cfg.dipsw[i] = pccore.dipsw[i];
                         renewal = TRUE;                          renewal = TRUE;
                 }                  }
         }          }
Line 259  void pccore_cfgupdate(void) { Line 323  void pccore_cfgupdate(void) {
         }          }
 }  }
   
   /**
    * Reset the virtual machine
    */
 void pccore_reset(void) {  void pccore_reset(void) {
   
         int             i;          int             i;
           BOOL    epson;
   
 //      reset_hostdrv();          soundmng_stop();
   #if !defined(DISABLE_SOUND)
         ZeroMemory(mem, 0x10fff0);                                                                      // ver0.28          if (soundrenewal) {
                   soundrenewal = 0;
                   sound_term();
                   sound_init();
           }
   #endif
           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);
   
         i286_reset();  
         CPUTYPE = 0;  
         if (np2cfg.dipsw[2] & 0x80) {  
                 CPUTYPE = CPUTYPE_V30;  
         }  
   
         //メモリスイッチ          //メモリスイッチ
         for (i=0; i<8; i++) {          for (i=0; i<8; i++)
           {
                 mem[0xa3fe2 + i*4] = np2cfg.memsw[i];                  mem[0xa3fe2 + i*4] = np2cfg.memsw[i];
         }          }
   
         fddfile_reset2dmode();          pccore_set(&np2cfg);
         bios0x18_16(0x20, 0xe1);          nevent_allreset();
   
         soundmng_stop();          CPU_RESET();
         if (soundrenewal) {          CPU_SETEXTSIZE((UINT32)pccore.extmem);
                 soundrenewal = 0;  
                 sound_term();  
                 sound_init();  
         }  
   
         setpcclock(np2cfg.baseclock, np2cfg.multiple);          CPU_TYPE = 0;
         nevent_init();          if (pccore.dipsw[2] & 0x80) {
                   CPU_TYPE = CPUTYPE_V30;
           }
   
           epson = (pccore.model & PCMODEL_EPSON) ? TRUE : FALSE;
           if (epson) {
                   /* enable RAM (D0000-DFFFF) */
                   CPU_RAM_D000 = 0xffff;
           }
           font_setchargraph(epson);
   
           // HDDセット
           diskdrv_hddbind();
           // SASI/IDEどっち?
   #if defined(SUPPORT_SASI)
           if (sxsi_issasi()) {
                   pccore.hddif &= ~PCHDD_IDE;
                   pccore.hddif |= PCHDD_SASI;
                   TRACEOUT(("supported SASI"));
           }
   #endif
   #if defined(SUPPORT_SCSI)
           if (sxsi_isscsi()) {
                   pccore.hddif |= PCHDD_SCSI;
                   TRACEOUT(("supported SCSI"));
           }
   #endif
   
           sound_changeclock();
           beep_changeclock();
         sound_reset();          sound_reset();
           fddmtrsnd_bind();
   
         iocore_reset();                                                         // サウンドでpicを呼ぶので…          fddfile_reset2dmode();
         cbuscore_reset();          bios0x18_16(0x20, 0xe1);
         fmboard_reset(np2cfg.SOUND_SW);  
           iocore_reset(&np2cfg);                                                          // サウンドでpicを呼ぶので…
           cbuscore_reset(&np2cfg);
           fmboard_reset(&np2cfg, pccore.sound);
   
           MEMM_ARCH((epson) ? 1 : 0);
         iocore_build();          iocore_build();
         iocore_bind();          iocore_bind();
         cbuscore_bind();          cbuscore_bind();
         fmboard_bind();          fmboard_bind();
   
         timing_init();          fddmtr_initialize();
         fddmtr_init();          calendar_initialize();
         calendar_init();          vram_initialize();
         vram_init();  
   
         pal_change(1);          pal_change(1);
   
         bios_init();          bios_initialize();
         sxsi_open();  
   
         if (np2cfg.ITF_WORK) {          CS_BASE = 0xf0000;
                 CS_BASE = 0xf0000;          CPU_CS = 0xf000;
                 I286_CS = 0xf000;          CPU_IP = 0xfff0;
                 I286_IP = 0xfff0;  
         }          CPU_CLEARPREFETCH();
         else {  
                 for (i=0; i<8; i++) {  
                         mem[0xa3fe2 + i*4] = msw_default[i];  
                 }  
                 CS_BASE = 0xfd800;  
                 I286_CS = 0xfd80;  
                 I286_IP = 0x0002;  
         }  
         i286_resetprefetch();  
         sysmng_cpureset();          sysmng_cpureset();
   
   #if defined(SUPPORT_HOSTDRV)
           hostdrv_reset();
   #endif
   
           timing_reset();
         soundmng_play();          soundmng_play();
   
   #if 0 && defined(SUPPORT_IDEIO) // Test!
           sxsi_devopen(0x02, OEMTEXT("e:\\pn\\pn.iso"));
   #endif
 }  }
   
 static void drawscreen(void) {  static void drawscreen(void) {
   
         BYTE    timing;          UINT8   timing;
           void    (VRAMCALL * grphfn)(int page, int alldraw);
           UINT8   bit;
   
         tramflag.timing++;          tramflag.timing++;
         timing = ((LOADINTELWORD(gdc.m.para + GDC_CSRFORM + 1)) >> 5) & 0x3e;          timing = ((LOADINTELWORD(gdc.m.para + GDC_CSRFORM + 1)) >> 5) & 0x3e;
Line 350  static void drawscreen(void) { Line 448  static void drawscreen(void) {
                 tramflag.renewal |= 1;                  tramflag.renewal |= 1;
         }          }
   
         if ((gdcs.textdisp & GDCSCRN_EXT) ||                                            // ver0.28          if (gdcs.textdisp & GDCSCRN_EXT) {
                 (gdcs.grphdisp & GDCSCRN_EXT)) {                  gdc_updateclock();
                 setvsyncclock();  
         }          }
   
         if (drawframe) {          if (!pcstat.drawframe) {
                 if ((gdcs.textdisp & GDCSCRN_EXT) ||                                    // ver0.26                  return;
                         (gdcs.grphdisp & GDCSCRN_EXT)) {          }
                         if (dispsync_renewalvertical()) {          if ((gdcs.textdisp & GDCSCRN_EXT) || (gdcs.grphdisp & GDCSCRN_EXT)) {
                                 gdcs.textdisp |= GDCSCRN_ALLDRAW2;                  if (dispsync_renewalvertical()) {
                                 gdcs.grphdisp |= GDCSCRN_ALLDRAW2;                          gdcs.textdisp |= 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();
                         tramflag.renewal |= 1;                  tramflag.renewal |= 1;
                         if (dispsync_renewalmode()) {                  if (dispsync_renewalmode()) {
                                 screenupdate |= 2;                          pcstat.screenupdate |= 2;
                         }  
                 }                  }
                                                                                                                                 // ver0.28/pr4          }
                 if (gdcs.palchange) {                                                                   // grphを先に          if (gdcs.palchange) {
                         gdcs.palchange = 0;                  gdcs.palchange = 0;
                         pal_change(0);                  pal_change(0);
                         screenupdate |= 1;                  pcstat.screenupdate |= 1;
                 }          }
                 if (gdcs.grphdisp & GDCSCRN_EXT) {          if (gdcs.grphdisp & GDCSCRN_EXT) {
                         gdcs.grphdisp &= ~GDCSCRN_EXT;                  gdcs.grphdisp &= ~GDCSCRN_EXT;
                         if (((gdc.clock & 0x80) && (gdc.clock != 0x83)) ||                  if (((gdc.clock & 0x80) && (gdc.clock != 0x83)) ||
                                 (gdc.clock == 0x03)) {                          (gdc.clock == 0x03)) {
                                 gdc.clock ^= 0x80;                          gdc.clock ^= 0x80;
                                 gdcs.grphdisp |= GDCSCRN_ALLDRAW2;                          gdcs.grphdisp |= GDCSCRN_ALLDRAW2;
                   }
           }
           if (gdcs.grphdisp & GDCSCRN_ENABLE) {
                   if (!(gdc.mode1 & 2)) {
                           grphfn = makegrph;
                           bit = GDCSCRN_MAKE;
                           if (gdcs.disp) {
                                   bit <<= 1;
                           }
   #if defined(SUPPORT_PC9821)
                           if (gdc.analog & 2) {
                                   grphfn = makegrphex;
                                   if (gdc.analog & 4) {
                                           bit = GDCSCRN_MAKE | (GDCSCRN_MAKE << 1);
                                   }
                           }
   #endif
                           if (gdcs.grphdisp & bit) {
                                   (*grphfn)(gdcs.disp, gdcs.grphdisp & bit & GDCSCRN_ALLDRAW2);
                                   gdcs.grphdisp &= ~bit;
                                   pcstat.screenupdate |= 1;
                         }                          }
                 }                  }
                 if (gdcs.grphdisp & GDCSCRN_ENABLE) {                  else if (gdcs.textdisp & GDCSCRN_ENABLE) {
                         if (!(gdc.mode1 & 2)) {                          if (!gdcs.disp) {
                                 if (!gdcs.disp) {                                  if ((gdcs.grphdisp & GDCSCRN_MAKE) ||
                                         if (gdcs.grphdisp & GDCSCRN_MAKE) {                                          (gdcs.textdisp & GDCSCRN_MAKE)) {
                                                 makegrph(0, gdcs.grphdisp & GDCSCRN_ALLDRAW);                                          if (!(gdc.mode1 & 0x4)) {
                                                 gdcs.grphdisp &= ~GDCSCRN_MAKE;                                                  maketextgrph(0, gdcs.textdisp & GDCSCRN_ALLDRAW,
                                                 screenupdate |= 1;                                                                  gdcs.grphdisp & GDCSCRN_ALLDRAW);
                                         }                                          }
                                 }                                          else {
                                 else {                                                  maketextgrph40(0, gdcs.textdisp & GDCSCRN_ALLDRAW,
                                         if (gdcs.grphdisp & (GDCSCRN_MAKE << 1)) {                                                                  gdcs.grphdisp & GDCSCRN_ALLDRAW);
                                                 makegrph(1, gdcs.grphdisp & (GDCSCRN_ALLDRAW << 1));  
                                                 gdcs.grphdisp &= ~(GDCSCRN_MAKE << 1);  
                                                 screenupdate |= 1;  
                                         }                                          }
                                           gdcs.grphdisp &= ~GDCSCRN_MAKE;
                                           pcstat.screenupdate |= 1;
                                 }                                  }
                         }                          }
                         else if (gdcs.textdisp & GDCSCRN_ENABLE) {                          else {
                                 if (!gdcs.disp) {                                  if ((gdcs.grphdisp & (GDCSCRN_MAKE << 1)) ||
                                         if ((gdcs.grphdisp & GDCSCRN_MAKE) ||                                          (gdcs.textdisp & GDCSCRN_MAKE)) {
                                                 (gdcs.textdisp & GDCSCRN_MAKE)) {                                          if (!(gdc.mode1 & 0x4)) {
                                                 if (!(gdc.mode1 & 0x4)) {                                                  maketextgrph(1, gdcs.textdisp & GDCSCRN_ALLDRAW,
                                                         maketextgrph(0, gdcs.textdisp & GDCSCRN_ALLDRAW,                                                                  gdcs.grphdisp & (GDCSCRN_ALLDRAW << 1));
                                                                         gdcs.grphdisp & GDCSCRN_ALLDRAW);  
                                                 }  
                                                 else {  
                                                         maketextgrph40(0, gdcs.textdisp & GDCSCRN_ALLDRAW,  
                                                                         gdcs.grphdisp & GDCSCRN_ALLDRAW);  
                                                 }  
                                                 gdcs.grphdisp &= ~GDCSCRN_MAKE;  
                                                 screenupdate |= 1;  
                                         }                                          }
                                 }                                          else {
                                 else {                                                  maketextgrph40(1, gdcs.textdisp & GDCSCRN_ALLDRAW,
                                         if ((gdcs.grphdisp & (GDCSCRN_MAKE << 1)) ||                                                                  gdcs.grphdisp & (GDCSCRN_ALLDRAW << 1));
                                                 (gdcs.textdisp & GDCSCRN_MAKE)) {  
                                                 if (!(gdc.mode1 & 0x4)) {  
                                                         maketextgrph(1, gdcs.textdisp & GDCSCRN_ALLDRAW,  
                                                                         gdcs.grphdisp & (GDCSCRN_ALLDRAW << 1));  
                                                 }  
                                                 else {  
                                                         maketextgrph40(1, gdcs.textdisp & GDCSCRN_ALLDRAW,  
                                                                         gdcs.grphdisp & (GDCSCRN_ALLDRAW << 1));  
                                                 }  
                                                 gdcs.grphdisp &= ~(GDCSCRN_MAKE << 1);  
                                                 screenupdate |= 1;  
                                         }                                          }
                                           gdcs.grphdisp &= ~(GDCSCRN_MAKE << 1);
                                           pcstat.screenupdate |= 1;
                                 }                                  }
                         }                          }
                 }                  }
           }
                 if (gdcs.textdisp & GDCSCRN_ENABLE) {          if (gdcs.textdisp & GDCSCRN_ENABLE) {
                         if (tramflag.renewal) {                  if (tramflag.renewal) {
                                 gdcs.textdisp |= maketext_curblink();                          gdcs.textdisp |= maketext_curblink();
                         }                  }
                         if ((cgwindow.writable & 0x80) && (tramflag.gaiji)) {                  if ((cgwindow.writable & 0x80) && (tramflag.gaiji)) {
                                 gdcs.textdisp |= GDCSCRN_ALLDRAW;                          gdcs.textdisp |= GDCSCRN_ALLDRAW;
                   }
                   cgwindow.writable &= ~0x80;
                   if (gdcs.textdisp & GDCSCRN_MAKE) {
                           if (!(gdc.mode1 & 0x4)) {
                                   maketext(gdcs.textdisp & GDCSCRN_ALLDRAW);
                         }                          }
                         cgwindow.writable &= ~0x80;                          else {
                         if (gdcs.textdisp & GDCSCRN_MAKE) {                                  maketext40(gdcs.textdisp & GDCSCRN_ALLDRAW);
                                 if (!(gdc.mode1 & 0x4)) {  
                                         maketext(gdcs.textdisp & GDCSCRN_ALLDRAW);  
                                 }  
                                 else {  
                                         maketext40(gdcs.textdisp & GDCSCRN_ALLDRAW);  
                                 }  
                                 gdcs.textdisp &= ~GDCSCRN_MAKE;  
                                 screenupdate |= 1;  
                         }                          }
                           gdcs.textdisp &= ~GDCSCRN_MAKE;
                           pcstat.screenupdate |= 1;
                 }                  }
                 if (screenupdate) {          }
                         screenupdate = scrndraw_draw((BYTE)(screenupdate & 2));          if (pcstat.screenupdate) {
                         drawcount++;                  pcstat.screenupdate = scrndraw_draw((UINT8)(pcstat.screenupdate & 2));
                 }                  drawcount++;
         }          }
 }  }
   
Line 469  void screendisp(NEVENTITEM item) { Line 567  void screendisp(NEVENTITEM item) {
   
         gdc_work(GDCWORK_SLAVE);          gdc_work(GDCWORK_SLAVE);
         gdc.vsync = 0;          gdc.vsync = 0;
         screendispflag = 0;          pcstat.screendispflag = 0;
         if (!np2cfg.DISPSYNC) {                                                                                 // ver0.29          if (!np2cfg.DISPSYNC) {
                 drawscreen();                  drawscreen();
         }          }
         pi = &pic.pi[0];          pi = &pic.pi[0];
Line 483  void screendisp(NEVENTITEM item) { Line 581  void screendisp(NEVENTITEM item) {
   
 void screenvsync(NEVENTITEM item) {  void screenvsync(NEVENTITEM item) {
   
         vramop.tramwait = np2cfg.wait[1];          MEMWAIT_TRAM = np2cfg.wait[1];
         vramop.vramwait = np2cfg.wait[3];          MEMWAIT_VRAM = np2cfg.wait[3];
         vramop.grcgwait = np2cfg.wait[5];          MEMWAIT_GRCG = np2cfg.wait[5];
         gdc_work(GDCWORK_MASTER);          gdc_work(GDCWORK_MASTER);
         gdc.vsync = 0x20;          gdc.vsync = 0x20;
         if (gdc.vsyncint) {          if (gdc.vsyncint) {
                 gdc.vsyncint = 0;                  gdc.vsyncint = 0;
                 pic_setirq(2);                  pic_setirq(2);
         }          }
         nevent_set(NEVENT_FLAMES, pc.vsyncclock, screendisp, NEVENT_RELATIVE);          nevent_set(NEVENT_FLAMES, gdc.vsyncclock, screendisp, NEVENT_RELATIVE);
   
         // drawscreenで pc.vsyncclockが変更される可能性があります               // ver0.28          // drawscreenで pccore.vsyncclockが変更される可能性があります
         if (np2cfg.DISPSYNC) {                                                                                  // ver0.29          if (np2cfg.DISPSYNC) {
                 drawscreen();                  drawscreen();
         }          }
         (void)item;          (void)item;
 }  }
   
   
 // ---------------------------------------------------------------------------  // ---------------------------------------------------------------------------
   
   // #define SINGLESTEPONLY
   
   #if defined(TRACE)
   static int resetcnt = 0;
   static int execcnt = 0;
   int piccnt = 0;
   #endif
   
   
   void pccore_postevent(UINT32 event) {   // yet!
   
           (void)event;
   }
   
 void pccore_exec(BOOL draw) {  void pccore_exec(BOOL draw) {
   
         drawframe = draw;          pcstat.drawframe = (UINT8)draw;
   //      keystat_sync();
         soundmng_sync();          soundmng_sync();
         mouseif_sync();          mouseif_sync();
         pal_eventclear();          pal_eventclear();
   
         gdc.vsync = 0;          gdc.vsync = 0;
         screendispflag = 1;          pcstat.screendispflag = 1;
         vramop.tramwait = np2cfg.wait[0];          MEMWAIT_TRAM = np2cfg.wait[0];
         vramop.vramwait = np2cfg.wait[2];          MEMWAIT_VRAM = np2cfg.wait[2];
         vramop.grcgwait = np2cfg.wait[4];          MEMWAIT_GRCG = np2cfg.wait[4];
         nevent_set(NEVENT_FLAMES, pc.dispclock, screenvsync, NEVENT_RELATIVE);          nevent_set(NEVENT_FLAMES, gdc.dispclock, screenvsync, NEVENT_RELATIVE);
   
 //      nevent_get1stevent();  //      nevent_get1stevent();
   
         while(screendispflag) {          while(pcstat.screendispflag) {
   #if defined(TRACE)
                   resetcnt++;
   #endif
                 pic_irq();                  pic_irq();
                 if (cpuio.reset_req) {                  if (CPU_RESETREQ) {
                         cpuio.reset_req = 0;                          CPU_RESETREQ = 0;
                         I286_CS = 0xf000;                          CPU_SHUT();
                         CS_BASE = 0xf0000;                  }
                         I286_IP = 0xfff0;  #if !defined(SINGLESTEPONLY)
 #ifdef CPU386                                                                                   // defineを変えてね                  if (CPU_REMCLOCK > 0) {
                         I286_DX = 0x0300;                          if (!(CPU_TYPE & CPUTYPE_V30)) {
 #endif                                  CPU_EXEC();
                         i286_resetprefetch();  
                 }  
   
 #if 1 // ndef TRACE  
                 if (nevent.remainclock > 0) {  
                         if (!(CPUTYPE & CPUTYPE_V30)) {  
                                 i286();  
                         }                          }
                         else {                          else {
                                 v30();                                  CPU_EXECV30();
                         }                          }
                 }                  }
 #else  #else
                 while(nevent.remainclock > 0) {                  while(CPU_REMCLOCK > 0) {
 {                          CPU_STEPEXEC();
 static FILEH fh = FILEH_INVALID;  
 if (I286_CS == 0x0e14) {  
         if (fh == FILEH_INVALID) {  
                 fh = file_create("log.txt");  
         }  
 }  
 if (fh != FILEH_INVALID) {  
 char buf[32];  
 wsprintf(buf, "%.4x:%.4x\r\n", I286_CS, I286_IP);  
 file_write(fh, buf, strlen(buf));  
 }  
 }  
                         i286_step();  
                 }                  }
 #endif  #endif
                 nevent_progress();                  nevent_progress();
         }          }
         artic_callback();                                                                                               // ver0.28          artic_callback();
         mpu98ii_callback();          mpu98ii_callback();
         diskdrv_callback();          diskdrv_callback();
         calendar_inc();          calendar_inc();
         sound_sync();                                                                                                   // happy!          S98_sync();
           sound_sync();
   
           if (pcstat.hardwarereset) {
                   pcstat.hardwarereset = FALSE;
                   pccore_cfgupdate();
                   pccore_reset();
           }
   
   #if defined(TRACE)
           execcnt++;
           if (execcnt >= 60) {
   //              TRACEOUT(("resetcnt = %d / pic %d", resetcnt, piccnt));
                   execcnt = 0;
                   resetcnt = 0;
                   piccnt = 0;
           }
   #endif
 }  }
   

Removed from v.1.2  
changed lines
  Added in v.1.111


RetroPC.NET-CVS <cvs@retropc.net>