Diff for /np2/fdd/sxsi.c between versions 1.9 and 1.17

version 1.9, 2004/01/27 03:24:19 version 1.17, 2005/03/05 12:19:53
Line 4 Line 4
 #include        "sysmng.h"  #include        "sysmng.h"
 #include        "cpucore.h"  #include        "cpucore.h"
 #include        "pccore.h"  #include        "pccore.h"
   #include        "iocore.h"
 #include        "sxsi.h"  #include        "sxsi.h"
   #if defined(SUPPORT_IDEIO)
   #include        "ideio.h"
   #endif
   
           _SXSIDEV        sxsi_dev[SASIHDD_MAX + SCSIHDD_MAX];
   
 const char sig_vhd[8] = "VHD1.00";  
 const char sig_nhd[15] = "T98HDDIMAGE.R0";  
   
 const SASIHDD sasihdd[7] = {  // ----
                                 {33, 4, 153},                   // 5MB  
                                 {33, 4, 310},                   // 10MB  
                                 {33, 6, 310},                   // 15MB  
                                 {33, 8, 310},                   // 20MB  
                                 {33, 4, 615},                   // 20MB (not used!)  
                                 {33, 6, 615},                   // 30MB  
                                 {33, 8, 615}};                  // 40MB  
   
 #if 0  
 static const _SXSIDEV defide = {615*33*8, 615, 256, 33, 8,  
                                                                 SXSITYPE_IDE | SXSITYPE_HDD, 256, 0, {0x00}};  
 static const _SXSIDEV defscsi = {40*16*32*8, 40*16, 256, 32, 8,  
                                                                 SXSITYPE_SCSI | SXSITYPE_HDD, 220, 0, {0x00}};  
 #endif  
   
   static REG8     nc_read(SXSIDEV sxsi, long pos, UINT8 *buf, UINT size) {
   
         _SXSIDEV        sxsi_dev[SASIHDD_MAX + SCSIHDD_MAX];          (void)sxsi;
           (void)pos;
           (void)buf;
           (void)size;
           return(0x60);
   }
   
   static REG8 nc_write(SXSIDEV sxsi, long pos, const UINT8 *buf, UINT size) {
   
 // SASI規格HDDかチェック          (void)sxsi;
 static void sasihddcheck(SXSIDEV sxsi) {          (void)pos;
           (void)buf;
           (void)size;
           return(0x60);
   }
   
 const SASIHDD   *sasi;  static REG8 nc_format(SXSIDEV sxsi, long pos) {
         UINT            i;  
   
         sasi = sasihdd;          (void)sxsi;
         for (i=0; i<sizeof(sasihdd)/sizeof(SASIHDD); i++, sasi++) {          (void)pos;
                 if ((sxsi->size == 256) &&          return(0x60);
                         (sxsi->sectors == sasi->sectors) &&  }
                         (sxsi->surfaces == sasi->surfaces) &&  
                         (sxsi->cylinders == sasi->cylinders)) {  static void sxsi_disconnect(SXSIDEV sxsi) {
                         sxsi->type = (UINT16)(SXSITYPE_SASI + (i << 8) + SXSITYPE_HDD);  
                         break;          FILEH   fh;
   
           if (sxsi) {
   #if defined(SUPPORT_IDEIO)
                   ideio_notify(sxsi->drv, 0);
   #endif
                   fh = (FILEH)sxsi->fh;
                   sxsi->flag = 0;
                   sxsi->fh = (INTPTR)FILEH_INVALID;
                   sxsi->read = nc_read;
                   sxsi->write = nc_write;
                   sxsi->format = nc_format;
                   if (fh != FILEH_INVALID) {
                           file_close(fh);
                 }                  }
         }          }
 }  }
Line 56  void sxsi_initialize(void) { Line 68  void sxsi_initialize(void) {
         UINT    i;          UINT    i;
   
         ZeroMemory(sxsi_dev, sizeof(sxsi_dev));          ZeroMemory(sxsi_dev, sizeof(sxsi_dev));
         for (i=0; i<(sizeof(sxsi_dev)/sizeof(_SXSIDEV)); i++) {          for (i=0; i<SASIHDD_MAX; i++) {
                 sxsi_dev[i].fh = (long)FILEH_INVALID;                  sxsi_dev[i].drv = (UINT8)(SXSIDRV_SASI + i);
           }
   #if defined(SUPPORT_SCSI)
           for (i=0; i<SCSIHDD_MAX; i++) {
                   sxsi_dev[SASIHDD_MAX + i].drv = (UINT8)(SXSIDRV_SCSI + i);
           }
   #endif
           for (i=0; i<NELEMENTS(sxsi_dev); i++) {
                   sxsi_dev[i].fh = (INTPTR)FILEH_INVALID;
                   sxsi_disconnect(sxsi_dev + i);
         }          }
 }  }
   
 SXSIDEV sxsi_getptr(REG8 drv) {  void sxsi_allflash(void) {
   
         UINT    num;          SXSIDEV sxsi;
           SXSIDEV sxsiterm;
           FILEH   fh;
   
         num = drv & 0x0f;          sxsi = sxsi_dev;
         if (!(drv & 0x20)) {                    // SASI or IDE          sxsiterm = sxsi + NELEMENTS(sxsi_dev);
                 if (num < 2) {          while(sxsi < sxsiterm) {
                         return(sxsi_dev + num);                  fh = (FILEH)sxsi->fh;
                 }                  sxsi->fh = (INTPTR)FILEH_INVALID;
         }                  if (fh != FILEH_INVALID) {
         else {                          file_close(fh);
                 if (num < 4) {                          // SCSI  
                         return(sxsi_dev + SASIHDD_MAX + num);  
                 }                  }
                   sxsi++;
         }          }
         return(NULL);  
 }  }
   
 const char *sxsi_getname(REG8 drv) {  void sxsi_alltrash(void) {
   
         SXSIDEV sxsi;          SXSIDEV sxsi;
           SXSIDEV sxsiterm;
   
         sxsi = sxsi_getptr(drv);          sxsi = sxsi_dev;
         if (sxsi) {          sxsiterm = sxsi + NELEMENTS(sxsi_dev);
                 return(sxsi->fname);          while(sxsi < sxsiterm) {
                   sxsi_disconnect(sxsi);
                   sxsi++;
         }          }
         return(NULL);  
 }  }
   
 BOOL sxsi_hddopen(REG8 drv, const char *file) {  BOOL sxsi_isconnect(SXSIDEV sxsi) {
   
         SXSIDEV sxsi;          if (sxsi) {
         FILEH   fh;                  switch(sxsi->devtype) {
 const char      *ext;                          case SXSIDEV_HDD:
         UINT16  type;                                  if (sxsi->flag & SXSIFLAG_READY) {
         long    totals;                                          return(TRUE);
         UINT32  headersize;                                  }
         UINT32  surfaces;                                  break;
         UINT32  cylinders;  
         UINT32  sectors;  
         UINT32  size;  
   
         if ((file == NULL) || (file[0] == '\0')) {                          case SXSIDEV_CDROM:
                 goto sxsiope_err1;                                  return(TRUE);
         }  
         sxsi = sxsi_getptr(drv);  
         if (sxsi == NULL) {  
                 goto sxsiope_err1;  
         }  
         fh = file_open(file);  
         if (fh == FILEH_INVALID) {  
                 goto sxsiope_err1;  
         }  
         ext = file_getext((char *)file);  
         type = SXSITYPE_HDD;  
         if ((!file_cmpname(ext, str_thd)) && (!(drv & 0x20))) {  
                 THDHDR thd;                                             // T98 HDD (IDE)  
                 if (file_read(fh, &thd, sizeof(thd)) != sizeof(thd)) {  
                         goto sxsiope_err2;  
                 }  
                 headersize = 256;  
                 surfaces = 8;  
                 cylinders = LOADINTELWORD(thd.cylinders);  
                 sectors = 33;  
                 size = 256;  
                 totals = cylinders * sectors * surfaces;  
         }  
         else if ((!file_cmpname(ext, str_hdi)) && (!(drv & 0x20))) {  
                 HDIHDR hdi;                                             // ANEX86 HDD (SASI) thanx Mamiya  
                 if (file_read(fh, &hdi, sizeof(hdi)) != sizeof(hdi)) {  
                         goto sxsiope_err2;  
                 }  
                 headersize = LOADINTELDWORD(hdi.headersize);  
                 surfaces = LOADINTELDWORD(hdi.surfaces);  
                 cylinders = LOADINTELDWORD(hdi.cylinders);  
                 sectors = LOADINTELDWORD(hdi.sectors);  
                 size = LOADINTELDWORD(hdi.sectorsize);  
                 totals = cylinders * sectors * surfaces;  
         }  
         else if ((!file_cmpname(ext, str_nhd)) && (!(drv & 0x20))) {  
                 NHDHDR nhd;                                             // T98Next HDD (IDE)  
                 if ((file_read(fh, &nhd, sizeof(nhd)) != sizeof(nhd)) ||  
                         (memcmp(nhd.sig, sig_nhd, 15))) {  
                         goto sxsiope_err2;  
                 }  
                 headersize = LOADINTELDWORD(nhd.headersize);  
                 surfaces = LOADINTELWORD(nhd.surfaces);  
                 cylinders = LOADINTELDWORD(nhd.cylinders);  
                 sectors = LOADINTELWORD(nhd.sectors);  
                 size = LOADINTELWORD(nhd.sectorsize);  
                 totals = cylinders * sectors * surfaces;  
         }  
         else if ((!file_cmpname(ext, str_hdd)) && (drv & 0x20)) {  
                 VHDHDR vhd;                                             // Virtual98 HDD (SCSI)  
                 if ((file_read(fh, &vhd, sizeof(vhd)) != sizeof(vhd)) ||  
                         (memcmp(vhd.sig, sig_vhd, 5))) {  
                         goto sxsiope_err2;  
                 }                  }
                 headersize = 220;  
                 surfaces = vhd.surfaces;  
                 cylinders = LOADINTELWORD(vhd.cylinders);  
                 sectors = vhd.sectors;  
                 size = LOADINTELWORD(vhd.sectorsize);  
                 totals = (SINT32)LOADINTELDWORD(vhd.totals);  
         }  
         else {  
                 goto sxsiope_err2;  
         }          }
           return(FALSE);
   }
   
         // フォーマット確認〜  BRESULT sxsi_prepare(SXSIDEV sxsi) {
         if ((surfaces == 0) || (surfaces >= 256) ||  
                 (cylinders == 0) || (cylinders >= 65536) ||          FILEH   fh;
                 (sectors == 0) || (sectors >= 256) ||  
                 (size == 0) || ((size & (size - 1)) != 0)) {          if ((sxsi == NULL) || (!(sxsi->flag & SXSIFLAG_READY))) {
                 goto sxsiope_err2;                  return(FAILURE);
         }  
         if (!(drv & 0x20)) {  
                 type |= SXSITYPE_IDE;  
         }          }
         else {          fh = (FILEH)sxsi->fh;
                 type |= SXSITYPE_SCSI;          if (fh == FILEH_INVALID) {
                 if (!(size & 0x700)) {                  // not 256,512,1024                  fh = file_open(sxsi->filename);
                         goto sxsiope_err2;                  sxsi->fh = (INTPTR)fh;
                   if (fh == FILEH_INVALID) {
                           sxsi->flag = 0;
                           return(FAILURE);
                 }                  }
         }          }
         sxsi->totals = totals;          sysmng_hddaccess(sxsi->drv);
         sxsi->cylinders = (UINT16)cylinders;  
         sxsi->size = (UINT16)size;  
         sxsi->sectors = (UINT8)sectors;  
         sxsi->surfaces = (UINT8)surfaces;  
         sxsi->type = type;  
         sxsi->headersize = headersize;  
         sxsi->fh = (long)fh;  
         file_cpyname(sxsi->fname, file, sizeof(sxsi->fname));  
         if (type == (SXSITYPE_IDE | SXSITYPE_HDD)) {  
                 sasihddcheck(sxsi);  
         }  
         return(SUCCESS);          return(SUCCESS);
   }
   
 sxsiope_err2:  
         file_close(fh);  
   
 sxsiope_err1:  // ----
         return(FAILURE);  
 }  
   
 void sxsi_open(void) {  SXSIDEV sxsi_getptr(REG8 drv) {
   
         int             i;          UINT    num;
         REG8    drv;  
   
         sxsi_trash();          num = drv & 0x0f;
         drv = 0;          if (!(drv & 0x20)) {                                    // SASI or IDE
         for (i=0; i<2; i++) {                  if (num < SASIHDD_MAX) {
                 if (sxsi_hddopen(drv, np2cfg.sasihdd[i]) == SUCCESS) {                          return(sxsi_dev + num);
                         drv++;  
                 }                  }
         }          }
         drv = 0x20;  #if defined(SUPPORT_SCSI)
         for (i=0; i<4; i++) {          else {
                 if (sxsi_hddopen(drv, np2cfg.scsihdd[i]) == SUCCESS) {                  if (num < SCSIHDD_MAX) {                        // SCSI
                         drv++;                          return(sxsi_dev + SASIHDD_MAX + num);
                 }                  }
         }          }
   #endif
           return(NULL);
 }  }
   
 void sxsi_flash(void) {  const OEMCHAR *sxsi_getfilename(REG8 drv) {
   
         SXSIDEV sxsi;          SXSIDEV sxsi;
         SXSIDEV sxsiterm;  
   
         sxsi = sxsi_dev;          sxsi = sxsi_getptr(drv);
         sxsiterm = sxsi + (sizeof(sxsi_dev)/sizeof(_SXSIDEV));          if ((sxsi) && (sxsi->flag & SXSIFLAG_READY)) {
         while(sxsi < sxsiterm) {                  return(sxsi->filename);
                 if ((FILEH)sxsi->fh != FILEH_INVALID) {  
                         file_close((FILEH)sxsi->fh);  
                         sxsi->fh = (long)FILEH_INVALID;  
                 }  
                 sxsi++;  
         }          }
           return(NULL);
 }  }
   
 void sxsi_trash(void) {  BRESULT sxsi_setdevtype(REG8 drv, UINT8 dev) {
   
         SXSIDEV sxsi;          SXSIDEV sxsi;
         SXSIDEV sxsiterm;  
   
         sxsi = sxsi_dev;          sxsi = sxsi_getptr(drv);
         sxsiterm = sxsi + (sizeof(sxsi_dev)/sizeof(_SXSIDEV));          if (sxsi) {
         while(sxsi < sxsiterm) {                  if (sxsi->devtype != dev) {
                 if ((FILEH)sxsi->fh != FILEH_INVALID) {                          sxsi_disconnect(sxsi);
                         file_close((FILEH)sxsi->fh);                          sxsi->devtype = dev;
                 }                  }
                 ZeroMemory(sxsi, sizeof(_SXSIDEV));                  return(SUCCESS);
                 sxsi->fh = (long)FILEH_INVALID;          }
                 sxsi++;          else {
                   return(FAILURE);
         }          }
 }  }
   
 static SXSIDEV getdrive(REG8 drv) {  BRESULT sxsi_devopen(REG8 drv, const OEMCHAR *file) {
   
         UINT    num;          SXSIDEV         sxsi;
         SXSIDEV ret;          BRESULT         r;
   
         num = drv & 0x0f;          if ((file == NULL) || (file[0] == '\0')) {
         if (num >= 2) {                  goto sxsiope_err;
                 return(NULL);  
         }          }
         num += (drv & 0x20) >> 4;          sxsi = sxsi_getptr(drv);
         ret = sxsi_dev + num;          if (sxsi == NULL) {
         if (ret->fname[0] == '\0') {                  goto sxsiope_err;
                 return(NULL);  
         }  
         if ((FILEH)ret->fh == FILEH_INVALID) {  
                 ret->fh = (long)file_open(ret->fname);  
                 if ((FILEH)ret->fh == FILEH_INVALID) {  
                         ret->fname[0] = '\0';  
                         return(NULL);  
                 }  
         }          }
         sysmng_hddaccess(drv);          switch(sxsi->devtype) {
         return(ret);                  case SXSIDEV_HDD:
                           r = sxsihdd_open(sxsi, file);
                           break;
   
                   case SXSIDEV_CDROM:
                           r = sxsicd_open(sxsi, file);
                           break;
   
                   default:
                           r = FAILURE;
                           break;
           }
           if (r != SUCCESS) {
                   goto sxsiope_err;
           }
           file_cpyname(sxsi->filename, file, NELEMENTS(sxsi->filename));
           sxsi->flag = SXSIFLAG_READY;
   #if defined(SUPPORT_IDEIO)
           ideio_notify(sxsi->drv, 1);
   #endif
           return(SUCCESS);
   
   sxsiope_err:
           return(FAILURE);
   }
   
   void sxsi_devclose(REG8 drv) {
   
           SXSIDEV         sxsi;
   
           sxsi = sxsi_getptr(drv);
           sxsi_disconnect(sxsi);
 }  }
   
 BOOL sxsi_issasi(void) {  BOOL sxsi_issasi(void) {
Line 290  BOOL sxsi_issasi(void) { Line 253  BOOL sxsi_issasi(void) {
         REG8    drv;          REG8    drv;
         SXSIDEV sxsi;          SXSIDEV sxsi;
         BOOL    ret;          BOOL    ret;
         UINT    sxsiif;  
   
         ret = FALSE;          ret = FALSE;
         for (drv=0x00; drv<0x04; drv++) {          for (drv=0x00; drv<0x04; drv++) {
                 sxsi = sxsi_getptr(drv);                  sxsi = sxsi_getptr(drv);
                 if (sxsi) {                  if (sxsi) {
                         sxsiif = sxsi->type & SXSITYPE_IFMASK;                          if (sxsi->devtype == SXSIDEV_HDD) {
                         if (sxsiif == SXSITYPE_SASI) {                                  if (sxsi->flag & SXSIFLAG_READY) {
                                 ret = TRUE;                                          if (sxsi->mediatype & SXSIMEDIA_INVSASI) {
                                                   return(FALSE);
                                           }
                                           ret = TRUE;
                                   }
                         }                          }
                         else if (sxsiif == SXSITYPE_IDE) {                          else {
                                 ret = FALSE;                                  return(FALSE);
                                 break;  
                         }                          }
                 }                  }
         }          }
Line 316  BOOL sxsi_isscsi(void) { Line 281  BOOL sxsi_isscsi(void) {
   
         for (drv=0x20; drv<0x28; drv++) {          for (drv=0x20; drv<0x28; drv++) {
                 sxsi = sxsi_getptr(drv);                  sxsi = sxsi_getptr(drv);
                 if ((sxsi) && (sxsi->type)) {                  if (sxsi_isconnect(sxsi)) {
                         return(TRUE);                          return(TRUE);
                 }                  }
         }          }
Line 330  BOOL sxsi_iside(void) { Line 295  BOOL sxsi_iside(void) {
   
         for (drv=0x00; drv<0x04; drv++) {          for (drv=0x00; drv<0x04; drv++) {
                 sxsi = sxsi_getptr(drv);                  sxsi = sxsi_getptr(drv);
                 if ((sxsi) && (sxsi->type)) {                  if (sxsi_isconnect(sxsi)) {
                         return(TRUE);                          return(TRUE);
                 }                  }
         }          }
         return(FALSE);          return(FALSE);
 }  }
   
 REG8 sxsi_read(REG8 drv, long pos, BYTE *buf, UINT size) {  
   
 const _SXSIDEV  *sxsi;  
         long            r;  
         UINT            rsize;  
   
         sxsi = getdrive(drv);  REG8 sxsi_read(REG8 drv, long pos, UINT8 *buf, UINT size) {
         if (sxsi == NULL) {  
                 return(0x60);          SXSIDEV sxsi;
   
           sxsi = sxsi_getptr(drv);
           if (sxsi != NULL) {
                   return(sxsi->read(sxsi, pos, buf, size));
         }          }
         pos = pos * sxsi->size + sxsi->headersize;          else {
         r = file_seek((FILEH)sxsi->fh, pos, FSEEK_SET);                  return(0x60);
         if (r == -1) {  
                 return(0x40);  
         }  
         if (pos != r) {  
                 return(0xd0);  
         }  
         while(size) {  
                 rsize = min(size, sxsi->size);  
                 CPU_REMCLOCK -= rsize;  
                 if (file_read((FILEH)sxsi->fh, buf, rsize) != rsize) {  
                         return(0xd0);  
                 }  
                 buf += rsize;  
                 size -= rsize;  
         }          }
         return(0x00);  
 }  }
   
 REG8 sxsi_write(REG8 drv, long pos, const BYTE *buf, UINT size) {  REG8 sxsi_write(REG8 drv, long pos, const UINT8 *buf, UINT size) {
   
 const _SXSIDEV  *sxsi;          SXSIDEV sxsi;
         long            r;  
         UINT            wsize;  
   
         sxsi = getdrive(drv);          sxsi = sxsi_getptr(drv);
         if (sxsi == NULL) {          if (sxsi != NULL) {
                 return(0x60);                  return(sxsi->write(sxsi, pos, buf, size));
         }          }
         pos = pos * sxsi->size + sxsi->headersize;          else {
         r = file_seek((FILEH)sxsi->fh, pos, FSEEK_SET);                  return(0x60);
         if (r == -1) {  
                 return(0x40);  
         }  
         if (pos != r) {  
                 return(0xd0);  
         }  
         while(size) {  
                 wsize = min(size, sxsi->size);  
                 CPU_REMCLOCK -= wsize;  
                 if (file_write((FILEH)sxsi->fh, buf, wsize) != wsize) {  
                         return(0x70);  
                 }  
                 buf += wsize;  
                 size -= wsize;  
         }          }
         return(0x00);  
 }  }
   
 REG8 sxsi_format(REG8 drv, long pos) {  REG8 sxsi_format(REG8 drv, long pos) {
   
 const _SXSIDEV  *sxsi;          SXSIDEV sxsi;
         long            r;  
         UINT16          i;  
         BYTE            work[256];  
         UINT            size;  
         UINT            wsize;  
   
         sxsi = getdrive(drv);          sxsi = sxsi_getptr(drv);
         if (sxsi == NULL) {          if (sxsi != NULL) {
                 return(0x60);                  return(sxsi->format(sxsi, pos));
         }          }
         pos = pos * sxsi->size + sxsi->headersize;          else {
         r = file_seek((FILEH)sxsi->fh, pos, FSEEK_SET);                  return(0x60);
         if (r == -1) {  
                 return(0x40);  
         }  
         if (pos != r) {  
                 return(0xd0);  
         }  
         FillMemory(work, sizeof(work), 0xe5);  
         for (i=0; i<sxsi->sectors; i++) {  
                 size = sxsi->size;  
                 while(size) {  
                         wsize = min(size, sizeof(work));  
                         size -= wsize;  
                         CPU_REMCLOCK -= wsize;  
                         if (file_write((FILEH)sxsi->fh, work, wsize) != wsize) {  
                                 return(0x70);  
                         }  
                 }  
         }          }
         return(0x00);  
 }  }
   

Removed from v.1.9  
changed lines
  Added in v.1.17


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