Diff for /xmil/pccore.c between versions 1.8 and 1.12

version 1.8, 2004/08/05 04:53:15 version 1.12, 2004/08/07 07:19:56
Line 7 Line 7
 #include        "z80core.h"  #include        "z80core.h"
 #include        "pccore.h"  #include        "pccore.h"
 #include        "iocore.h"  #include        "iocore.h"
 #include        "draw.h"  #include        "makescrn.h"
 #include        "sound.h"  #include        "sound.h"
 #include        "sndctrl.h"  #include        "sndctrl.h"
 #include        "menu.h"  
 #include        "font.h"  #include        "font.h"
 #include        "juliet.h"  
 #include        "xmilver.h"  #include        "xmilver.h"
 #include        "fddfile.h"  #include        "fddfile.h"
 #include        "calendar.h"  #include        "calendar.h"
Line 23 Line 21
   
 const OEMCHAR xmilversion[] = OEMTEXT(XMILVER_CORE);  const OEMCHAR xmilversion[] = OEMTEXT(XMILVER_CORE);
   
         XMILCFG         xmilcfg = {     0, 0, 1, 0, 1, 2, 0, 1,          XMILCFG         xmilcfg = {     0, 0, 1,
                                                           2, 0, 1,
                                                         22050, 1000, 0, 80,                                                          22050, 1000, 0, 80,
                                                         0, 0,                                                          0, 0,
                                                         0, 0,                                                          0, 0,
                                                         0, 0, 0,                                                          0, 0, 0,
                                                         1,  
                                                         1, 0};                                                          1, 0};
   
         PCCORE          pccore = {250, 0, 1, 0};          PCCORE          pccore = {250, 0, 1, 0};
           CORESTAT        corestat;
         BYTE            mMAIN[0x10000];          BYTE            mMAIN[0x10000];
         BYTE            mBIOS[0x8000];          BYTE            mBIOS[0x8000];
         BYTE            mBANK[16][0x8000];          BYTE            mBANK[16][0x8000];
Line 41  const OEMCHAR xmilversion[] = OEMTEXT(XM Line 40  const OEMCHAR xmilversion[] = OEMTEXT(XM
         BYTE            *RAM0r;          BYTE            *RAM0r;
         BYTE            *RAM0w;          BYTE            *RAM0w;
         DWORD           h_cntbase;          DWORD           h_cntbase;
         BRESULT         soundrenewal;  
   
   
   
Line 92  BYTE reset_x1(BYTE ROM_TYPE, BYTE SOUND_ Line 90  BYTE reset_x1(BYTE ROM_TYPE, BYTE SOUND_
                 scrnmng_setcolormode(FALSE);                  scrnmng_setcolormode(FALSE);
         }          }
   
         textdrawproc_renewal();  
         ipl_load();          ipl_load();
   
         Z80_RESET();          Z80_RESET();
Line 130  BYTE reset_x1(BYTE ROM_TYPE, BYTE SOUND_ Line 127  BYTE reset_x1(BYTE ROM_TYPE, BYTE SOUND_
 ***********************************************************************/  ***********************************************************************/
   
 static  BYTE    keyintcnt = 0;  static  BYTE    keyintcnt = 0;
 static  BYTE    flame = 0;  
 static  BYTE    inttiming = 0;  
   
 void pccore_initialize(void) {  void pccore_initialize(void) {
   
Line 153  void pccore_initialize(void) { Line 148  void pccore_initialize(void) {
 void pccore_reset(void) {  void pccore_reset(void) {
   
         soundmng_stop();          soundmng_stop();
         if (soundrenewal) {          if (corestat.soundrenewal) {
                 soundrenewal = 0;                  corestat.soundrenewal = 0;
                 sndctrl_deinitialize();                  sndctrl_deinitialize();
                 sndctrl_initialize();                  sndctrl_initialize();
         }          }
           sound_reset();
   
         reset_x1(xmilcfg.ROM_TYPE, xmilcfg.SOUND_SW, xmilcfg.DIP_SW);          reset_x1(xmilcfg.ROM_TYPE, xmilcfg.SOUND_SW, xmilcfg.DIP_SW);
         soundmng_play();          soundmng_play();
 }  }
Line 208  void iptrace_out(void) { Line 205  void iptrace_out(void) {
 }  }
 #endif  #endif
   
   void pccore_exec(BRESULT draw) {
   
           REG8    inttiming;
   
 void x1r_exec(void) {          corestat.drawframe = draw;
   
 extern  BYTE    disp_flashscreen;  
   
         v_cnt = 0;          v_cnt = 0;
         s_cnt = 0;          s_cnt = 0;
         xmilcfg.DISPSYNC &= 1;  
         inttiming = xmilcfg.CPU8MHz & 1;          inttiming = xmilcfg.CPU8MHz & 1;
 //      TRACEOUT(("*sync"));  
   
         while(s_cnt < 266) {          while(s_cnt < 266) {
                 while(h_cnt < pccore.HSYNC_CLK) {                  while(h_cnt < pccore.HSYNC_CLK) {
 #if defined(TRACE)  
 //                      TRACEOUT(("%.4x", Z80_PC));  
 //                      if (Z80_PC == 0x8198) {  
 //                              TRACEOUT(("---->sound"));  
 //                      }  
 //                      if (Z80_PC == 0x8188) {  
 //                              TRACEOUT(("-- poll sound"));  
 //                      }  
 #endif  
 #if IPTRACE  #if IPTRACE
                         treip[trpos & (IPTRACE - 1)] = Z80_PC;                          treip[trpos & (IPTRACE - 1)] = Z80_PC;
                         trpos++;                          trpos++;
Line 242  extern BYTE disp_flashscreen; Line 228  extern BYTE disp_flashscreen;
                 h_cntbase += pccore.HSYNC_CLK;                  h_cntbase += pccore.HSYNC_CLK;
                 inttiming ^= 2;                  inttiming ^= 2;
                 if (inttiming != 3) {                  if (inttiming != 3) {
                         if (xmilcfg.SOUNDPLY) {                          sound_makesample(pcmbufsize[s_cnt]);
                                 sound_makesample(pcmbufsize[s_cnt]);  //                      if (xmilcfg.SOUNDPLY) {
                                 juliet2_exec();  //                              juliet2_exec();
                         }  //                      }
                         s_cnt++;                          s_cnt++;
                         x1_ctc_int();                          x1_ctc_int();
                         if (!((++keyintcnt) & 15)) {                          if (!((++keyintcnt) & 15)) {
Line 257  extern BYTE disp_flashscreen; Line 243  extern BYTE disp_flashscreen;
                 }                  }
                 v_cnt++;                  v_cnt++;
                 if (crtc.s.CRT_YL == v_cnt) {                  if (crtc.s.CRT_YL == v_cnt) {
 //                      TRACEOUT(("--->sync"));  
                         pcg.r.vsync = 1;                          pcg.r.vsync = 1;
                         if (xmilcfg.DISPSYNC == 1) {                          if (xmilcfg.DISPSYNC & 1) {
                                 xmilcfg.DISPSYNC |= 0x80;  
                                 scrnupdate();                                  scrnupdate();
                         }                          }
                 }                  }
         }          }
         if (++flame >= 60) {          sound_sync();
                 flame = 0;          calendar_inc();
                 calendar_inc();          scrnupdate();
         }  
         if (!xmilcfg.SOUNDPLY) {  
                 sound_makesample(framesoundcnt);  
         }  
         if (!(xmilcfg.DISPSYNC & 0x80)) {  
                 scrnupdate();  
         }  
 }  }
   

Removed from v.1.8  
changed lines
  Added in v.1.12


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