Diff for /np2/i386c/Attic/dmap.c between versions 1.2 and 1.4

version 1.2, 2004/01/05 09:31:25 version 1.4, 2004/03/07 01:23:14
Line 5 Line 5
 #include        "dmap.h"  #include        "dmap.h"
   
   
 void dmap_i286(void) {  void dmap(void) {
   
         DMACH   ch;          DMACH   ch;
         REG8    bit;          REG8    bit;
           UINT32  addr;
   
         if (dmac.working) {          if (dmac.working) {
                 ch = dmac.dmach;                  ch = dmac.dmach;
Line 22  void dmap_i286(void) { Line 23  void dmap_i286(void) {
                                         ch->proc.extproc(DMAEXT_END);                                          ch->proc.extproc(DMAEXT_END);
                                 }                                  }
                                 ch->leng.w--;                                  ch->leng.w--;
                                   addr = ch->adrs.d;
                                 switch(ch->mode & 0x0c) {                                  if (necio.port0439 & 4) {
                                         case 0x00:              // verifty                                          addr = ch->adrs.d & 0xffffff;
                                                 ch->proc.inproc();  
                                                 break;  
   
                                         case 0x04:              // port->mem  
                                                 i286_memorywrite(ch->adrs.d, ch->proc.inproc());  
                                                 break;  
   
                                         default:  
                                                 ch->proc.outproc(i286_memoryread(ch->adrs.d));  
                                                 break;  
                                 }                                  }
                                 ch->adrs.d += ((ch->mode & 0x20)?-1:1);                                  ch->adrs.d += ((ch->mode & 0x20)?-1:1);
                         }  //                              ch->adrs.w[DMA16_LOW] += ((ch->mode & 0x20)?-1:1);
                         ch++;  
                         bit <<= 1;  
                 } while(bit & 0x0f);  
         }  
 }  
   
 void dmap_v30(void) {  
   
         DMACH   ch;  
         REG8    bit;  
   
         if (dmac.working) {  
                 ch = dmac.dmach;  
                 bit = 1;  
                 do {  
                         if (dmac.working & bit) {  
                                 // DMA working !  
                                 if (!ch->leng.w) {  
                                         dmac.stat |= bit;  
                                         dmac.working &= ~bit;  
                                         ch->proc.extproc(DMAEXT_END);  
                                 }  
                                 ch->leng.w--;  
   
                                 switch(ch->mode & 0x0c) {                                  switch(ch->mode & 0x0c) {
                                         case 0x00:              // verifty                                          case 0x00:              // verifty
                                                 ch->proc.inproc();                                                  ch->proc.inproc();
                                                 break;                                                  break;
   
                                         case 0x04:              // port->mem                                          case 0x04:              // port->mem
                                                 i286_memorywrite(ch->adrs.d, ch->proc.inproc());                                                  i286_memorywrite(addr, ch->proc.inproc());
                                                 break;                                                  break;
   
                                         default:                                          default:
                                                 ch->proc.outproc(i286_memoryread(ch->adrs.d));                                                  ch->proc.outproc(i286_memoryread(addr));
                                                 break;                                                  break;
                                 }                                  }
                                 ch->adrs.w[DMA16_LOW] += ((ch->mode & 0x20)?-1:1);  
                         }                          }
                         ch++;                          ch++;
                         bit <<= 1;                          bit <<= 1;

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


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