Diff for /np2/io/dmac.c between versions 1.3 and 1.7

version 1.3, 2003/12/08 00:55:32 version 1.7, 2004/01/22 01:10:04
Line 3 Line 3
 #include        "iocore.h"  #include        "iocore.h"
 #include        "sound.h"  #include        "sound.h"
 #include        "cs4231.h"  #include        "cs4231.h"
   #include        "sasiio.h"
   
   
 void DMACCALL dma_dummyout(REG8 data) {  void DMACCALL dma_dummyout(REG8 data) {
Line 21  REG8 DMACCALL dma_dummyproc(REG8 func) { Line 22  REG8 DMACCALL dma_dummyproc(REG8 func) {
         return(0);          return(0);
 }  }
   
   static const DMAPROC dmaproc[] = {
                   {dma_dummyout,          dma_dummyin,            dma_dummyproc},         // NONE
                   {fdc_datawrite,         fdc_dataread,           fdc_dmafunc},           // FDD
   #if defined(SUPPORT_SASI)
                   {sasi_datawrite,        sasi_dataread,          sasi_dmafunc},          // SASI
   #else
                   {dma_dummyout,          dma_dummyin,            dma_dummyproc},         // SASI
   #endif
                   {dma_dummyout,          dma_dummyin,            dma_dummyproc},         // SCSI
                   {dma_dummyout,          dma_dummyin,            cs4231dmafunc},         // CS4231
   };
   
   
 // ----  // ----
   
Line 37  void dmac_check(void) { Line 50  void dmac_check(void) {
                 if ((!(dmac.mask & bit)) && (ch->ready)) {                  if ((!(dmac.mask & bit)) && (ch->ready)) {
                         if (!(dmac.work & bit)) {                          if (!(dmac.work & bit)) {
                                 dmac.work |= bit;                                  dmac.work |= bit;
                                 if (ch->extproc(DMAEXT_START)) {                                  if (ch->proc.extproc(DMAEXT_START)) {
                                         dmac.stat &= ~bit;                                              // ver0.27                                          dmac.stat &= ~bit;                                              // ver0.27
                                         dmac.working |= bit;                                          dmac.working |= bit;
                                         workchg = TRUE;                                          workchg = TRUE;
Line 48  void dmac_check(void) { Line 61  void dmac_check(void) {
                         if (dmac.work & bit) {                          if (dmac.work & bit) {
                                 dmac.work &= ~bit;                                  dmac.work &= ~bit;
                                 dmac.working &= ~bit;                                  dmac.working &= ~bit;
                                 ch->extproc(DMAEXT_BREAK);                                  ch->proc.extproc(DMAEXT_BREAK);
                                 workchg = TRUE;                                  workchg = TRUE;
                         }                          }
                 }                  }
Line 140  static void IOOUTCALL dmac_o21(UINT port Line 153  static void IOOUTCALL dmac_o21(UINT port
         DMACH   dmach;          DMACH   dmach;
   
         dmach = dmac.dmach + (((port >> 1) + 1) & 3);          dmach = dmac.dmach + (((port >> 1) + 1) & 3);
         dmach->adrs.b[DMA32_HIGH + DMA16_LOW] = dat;          dmach->adrs.b[DMA32_HIGH + DMA16_LOW] = dat & 0x0f;
 }  }
   
 static REG8 IOINPCALL dmac_i01(UINT port) {  static REG8 IOINPCALL dmac_i01(UINT port) {
Line 151  static REG8 IOINPCALL dmac_i01(UINT port Line 164  static REG8 IOINPCALL dmac_i01(UINT port
         dmach = dmac.dmach + ((port >> 2) & 3);          dmach = dmac.dmach + ((port >> 2) & 3);
         lh = dmac.lh;          lh = dmac.lh;
         dmac.lh = lh ^ 1;          dmac.lh = lh ^ 1;
         return(dmach->leng.b[lh]);          return(dmach->adrs.b[lh + DMA32_LOW]);
 }  }
   
 static REG8 IOINPCALL dmac_i03(UINT port) {  static REG8 IOINPCALL dmac_i03(UINT port) {
Line 162  static REG8 IOINPCALL dmac_i03(UINT port Line 175  static REG8 IOINPCALL dmac_i03(UINT port
         dmach = dmac.dmach + ((port >> 2) & 3);          dmach = dmac.dmach + ((port >> 2) & 3);
         lh = dmac.lh;          lh = dmac.lh;
         dmac.lh = lh ^ 1;          dmac.lh = lh ^ 1;
         return(dmach->adrs.b[lh + DMA32_LOW]);          return(dmach->leng.b[lh]);
 }  }
   
 static REG8 IOINPCALL dmac_i11(UINT port) {  static REG8 IOINPCALL dmac_i11(UINT port) {
Line 191  static const IOOUT dmaco21[4] = { Line 204  static const IOOUT dmaco21[4] = {
   
 void dmac_reset(void) {  void dmac_reset(void) {
   
         int             i;  
   
         ZeroMemory(&dmac, sizeof(dmac));          ZeroMemory(&dmac, sizeof(dmac));
         dmac.lh = DMA16_LOW;          dmac.lh = DMA16_LOW;
         dmac.mask = 0xf;          dmac.mask = 0xf;
         for (i=0; i<4; i++) {          dmac_procset();
                 dmac.dmach[i].outproc = dma_dummyout;  
                 dmac.dmach[i].inproc = dma_dummyin;  
                 dmac.dmach[i].extproc = dma_dummyproc;  
         }  
         dmac.dmach[0].extproc = cs4231dmafunc;  
         dmac.dmach[DMA_2HD].inproc = fdc_DataRegRead;  
         dmac.dmach[DMA_2HD].outproc = fdc_DataRegWrite;  
         dmac.dmach[DMA_2HD].extproc = fdc_dmafunc;  
         dmac.dmach[DMA_2DD].inproc = fdc_DataRegRead;  
         dmac.dmach[DMA_2DD].outproc = fdc_DataRegWrite;  
         dmac.dmach[DMA_2DD].extproc = fdc_dmafunc;  
   
 //      TRACEOUT(("sizeof(_DMACH) = %d", sizeof(_DMACH)));  //      TRACEOUT(("sizeof(_DMACH) = %d", sizeof(_DMACH)));
 }  }
   
Line 219  void dmac_bind(void) { Line 218  void dmac_bind(void) {
         iocore_attachsysoutex(0x0021, 0x0cf1, dmaco21, 4);          iocore_attachsysoutex(0x0021, 0x0cf1, dmaco21, 4);
 }  }
   
   
   // ----
   
   static void dmacset(REG8 channel) {
   
           DMADEV          *dev;
           DMADEV          *devterm;
           UINT            dmadev;
   
           dev = dmac.device;
           devterm = dev + dmac.devices;
           dmadev = DMADEV_NONE;
           while(dev < devterm) {
                   if (dev->channel == channel) {
                           dmadev = dev->device;
                   }
                   dev++;
           }
           if (dmadev >= sizeof(dmaproc) / sizeof(DMAPROC)) {
                   dmadev = 0;
           }
           dmac.dmach[channel].proc = dmaproc[dmadev];
   }
   
   void dmac_procset(void) {
   
           REG8    i;
   
           for (i=0; i<4; i++) {
                   dmacset(i);
           }
   }
   
   void dmac_attach(REG8 device, REG8 channel) {
   
           dmac_detach(device);
   
           if (dmac.devices < (sizeof(dmac.device) / sizeof(DMADEV))) {
                   dmac.device[dmac.devices].device = device;
                   dmac.device[dmac.devices].channel = channel;
                   dmac.devices++;
                   dmacset(channel);
           }
   }
   
   void dmac_detach(REG8 device) {
   
           DMADEV  *dev;
           DMADEV  *devterm;
           REG8    ch;
   
           dev = dmac.device;
           devterm = dev + dmac.devices;
           while(dev < devterm) {
                   if (dev->device == device) {
                           break;
                   }
                   dev++;
           }
           if (dev < devterm) {
                   ch = dev->channel;
                   dev++;
                   while(dev < devterm) {
                           *(dev - 1) = *dev;
                           dev++;
                   }
                   dmac.devices--;
                   dmacset(ch);
           }
   }
   

Removed from v.1.3  
changed lines
  Added in v.1.7


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