--- np2/fdd/newdisk.c 2004/01/27 07:24:25 1.6 +++ np2/fdd/newdisk.c 2004/01/30 01:29:13 1.7 @@ -43,9 +43,10 @@ static BOOL writezero(FILEH fh, UINT siz return(SUCCESS); } -static void writehddipl(FILEH fh, UINT ssize) { +static BOOL writehddipl(FILEH fh, UINT ssize, UINT32 tsize) { BYTE work[1024]; + UINT size; ZeroMemory(work, sizeof(work)); CopyMemory(work, hdddiskboot, sizeof(hdddiskboot)); @@ -53,7 +54,21 @@ static void writehddipl(FILEH fh, UINT s work[ssize - 2] = 0x55; work[ssize - 1] = 0xaa; } - file_write(fh, work, sizeof(work)); + if (file_write(fh, work, sizeof(work)) != sizeof(work)) { + return(FAILURE); + } + if (tsize > sizeof(work)) { + tsize -= sizeof(work); + ZeroMemory(work, sizeof(work)); + while(tsize) { + size = min(tsize, sizeof(work)); + tsize -= size; + if (file_write(fh, work, size) != size) { + return(FAILURE); + } + } + } + return(SUCCESS); } void newdisk_thd(const char *fname, UINT hddsize) { @@ -61,44 +76,60 @@ void newdisk_thd(const char *fname, UINT FILEH fh; BYTE work[256]; UINT size; + BOOL r; if ((fname == NULL) || (hddsize < 5) || (hddsize > 256)) { - return; + goto ndthd_err; } fh = file_create(fname); - if (fh != FILEH_INVALID) { - ZeroMemory(work, 256); - size = hddsize * 15; - STOREINTELWORD(work, size); - file_write(fh, work, 256); - writehddipl(fh, 256); - file_close(fh); + if (fh == FILEH_INVALID) { + goto ndthd_err; } + ZeroMemory(work, 256); + size = hddsize * 15; + STOREINTELWORD(work, size); + r = (file_write(fh, work, 256) != 256); + r |= writehddipl(fh, 256, 0); + file_close(fh); + if (r) { + file_delete(fname); + } + +ndthd_err: + return; } void newdisk_nhd(const char *fname, UINT hddsize) { FILEH fh; NHDHDR nhd; - UINT tmp; + UINT size; + BOOL r; if ((fname == NULL) || (hddsize < 5) || (hddsize > 512)) { - return; + goto ndnhd_err; } fh = file_create(fname); - if (fh != FILEH_INVALID) { - ZeroMemory(&nhd, sizeof(nhd)); - CopyMemory(&nhd.sig, sig_nhd, 15); - STOREINTELDWORD(nhd.headersize, sizeof(nhd)); - tmp = hddsize * 16; - STOREINTELDWORD(nhd.cylinders, tmp); - STOREINTELWORD(nhd.surfaces, 8); - STOREINTELWORD(nhd.sectors, 32); - STOREINTELWORD(nhd.sectorsize, 256); - file_write(fh, &nhd, sizeof(nhd)); - writehddipl(fh, 256); - file_close(fh); + if (fh == FILEH_INVALID) { + goto ndnhd_err; + } + ZeroMemory(&nhd, sizeof(nhd)); + CopyMemory(&nhd.sig, sig_nhd, 15); + STOREINTELDWORD(nhd.headersize, sizeof(nhd)); + size = hddsize * 16; + STOREINTELDWORD(nhd.cylinders, size); + STOREINTELWORD(nhd.surfaces, 8); + STOREINTELWORD(nhd.sectors, 32); + STOREINTELWORD(nhd.sectorsize, 256); + r = (file_write(fh, &nhd, sizeof(nhd)) != sizeof(nhd)); + r |= writehddipl(fh, 256, size * 8 * 32 * 256); + file_close(fh); + if (r) { + file_delete(fname); } + +ndnhd_err: + return; } // hddtype = 0:5MB / 1:10MB / 2:15MB / 3:20MB / 5:30MB / 6:40MB @@ -107,29 +138,37 @@ void newdisk_hdi(const char *fname, UINT const SASIHDD *sasi; FILEH fh; HDIHDR hdi; - UINT32 tmp; + UINT32 size; + BOOL r; hddtype &= 7; if ((fname == NULL) || (hddtype == 7)) { - return; + goto ndhdi_err; } sasi = sasihdd + hddtype; fh = file_create(fname); - if (fh != FILEH_INVALID) { - ZeroMemory(&hdi, sizeof(hdi)); - tmp = 256 * sasi->sectors * sasi->surfaces * sasi->cylinders; -// STOREINTELDWORD(hdi.hddtype, 0); // ??? - STOREINTELDWORD(hdi.headersize, 4096); - STOREINTELDWORD(hdi.hddsize, tmp); - STOREINTELDWORD(hdi.sectorsize, 256); - STOREINTELDWORD(hdi.sectors, sasi->sectors); - STOREINTELDWORD(hdi.surfaces, sasi->surfaces); - STOREINTELDWORD(hdi.cylinders, sasi->cylinders); - file_write(fh, &hdi, sizeof(hdi)); - writezero(fh, 4096 - sizeof(hdi)); - writehddipl(fh, 256); - file_close(fh); + if (fh == FILEH_INVALID) { + goto ndhdi_err; + } + ZeroMemory(&hdi, sizeof(hdi)); + size = 256 * sasi->sectors * sasi->surfaces * sasi->cylinders; +// STOREINTELDWORD(hdi.hddtype, 0); + STOREINTELDWORD(hdi.headersize, 4096); + STOREINTELDWORD(hdi.hddsize, size); + STOREINTELDWORD(hdi.sectorsize, 256); + STOREINTELDWORD(hdi.sectors, sasi->sectors); + STOREINTELDWORD(hdi.surfaces, sasi->surfaces); + STOREINTELDWORD(hdi.cylinders, sasi->cylinders); + r = (file_write(fh, &hdi, sizeof(hdi)) != sizeof(hdi)); + r |= writezero(fh, 4096 - sizeof(hdi)); + r |= writehddipl(fh, 256, size); + file_close(fh); + if (r) { + file_delete(fname); } + +ndhdi_err: + return; } void newdisk_vhd(const char *fname, UINT hddsize) { @@ -137,25 +176,33 @@ void newdisk_vhd(const char *fname, UINT FILEH fh; VHDHDR vhd; UINT tmp; + BOOL r; if ((fname == NULL) || (hddsize < 2) || (hddsize > 512)) { - return; + goto ndvhd_err; } fh = file_create(fname); - if (fh != FILEH_INVALID) { - ZeroMemory(&vhd, sizeof(vhd)); - CopyMemory(&vhd.sig, sig_vhd, 7); - STOREINTELWORD(vhd.mbsize, (UINT16)hddsize); - STOREINTELWORD(vhd.sectorsize, 256); - vhd.sectors = 32; - vhd.surfaces = 8; - tmp = hddsize * 16; // = * 1024 * 1024 / (8 * 32 * 256); - STOREINTELWORD(vhd.cylinders, (UINT16)tmp); - tmp *= 8 * 32; - STOREINTELDWORD(vhd.totals, tmp); - file_write(fh, &vhd, sizeof(vhd)); - writehddipl(fh, 256); - file_close(fh); + if (fh == FILEH_INVALID) { + goto ndvhd_err; + } + ZeroMemory(&vhd, sizeof(vhd)); + CopyMemory(&vhd.sig, sig_vhd, 7); + STOREINTELWORD(vhd.mbsize, (UINT16)hddsize); + STOREINTELWORD(vhd.sectorsize, 256); + vhd.sectors = 32; + vhd.surfaces = 8; + tmp = hddsize * 16; // = * 1024 * 1024 / (8 * 32 * 256); + STOREINTELWORD(vhd.cylinders, (UINT16)tmp); + tmp *= 8 * 32; + STOREINTELDWORD(vhd.totals, tmp); + r = (file_write(fh, &vhd, sizeof(vhd)) != sizeof(vhd)); + r |= writehddipl(fh, 256, 0); + file_close(fh); + if (r) { + file_delete(fname); } + +ndvhd_err: + return; }