trunk/src/lib/formats/wd177x_dsk.c
| r20117 | r20118 | |
| 106 | 106 | } |
| 107 | 107 | } |
| 108 | 108 | |
| 109 | | bool wd177x_format::load(io_generic *io, UINT32 form_factor, floppy_image *image) |
| 109 | floppy_image_format_t::desc_e* wd177x_format::get_desc_fm(const format &f, int ¤t_size) |
| 110 | 110 | { |
| 111 | | int type = find_size(io, form_factor); |
| 112 | | if(type == -1) |
| 113 | | return false; |
| 111 | static floppy_image_format_t::desc_e desc[25] = { |
| 112 | /* 00 */ { FM, 0xff, f.gap_1 }, |
| 113 | /* 01 */ { SECTOR_LOOP_START, 0, f.sector_count-1 }, |
| 114 | /* 02 */ { FM, 0x00, 6 }, |
| 115 | /* 03 */ { CRC_CCITT_FM_START, 1 }, |
| 116 | /* 04 */ { RAW, 0x4489, 0 }, // TODO remove |
| 117 | /* 05 */ { FM, 0xfe, 1 }, |
| 118 | /* 06 */ { TRACK_ID_FM }, |
| 119 | /* 07 */ { HEAD_ID_FM }, |
| 120 | /* 08 */ { SECTOR_ID_FM }, |
| 121 | /* 09 */ { SIZE_ID_FM }, |
| 122 | /* 10 */ { CRC_END, 1 }, |
| 123 | /* 11 */ { CRC, 1 }, |
| 124 | /* 12 */ { FM, 0xff, f.gap_2 }, |
| 125 | /* 13 */ { FM, 0x00, 6 }, |
| 126 | /* 14 */ { CRC_CCITT_FM_START, 2 }, |
| 127 | /* 15 */ { RAW, 0x4489, 0 }, // TODO remove |
| 128 | /* 16 */ { FM, 0xfb, 1 }, |
| 129 | /* 17 */ { SECTOR_DATA_FM, -1 }, |
| 130 | /* 18 */ { CRC_END, 2 }, |
| 131 | /* 19 */ { CRC, 2 }, |
| 132 | /* 20 */ { FM, 0xff, f.gap_3 }, |
| 133 | /* 21 */ { SECTOR_LOOP_END }, |
| 134 | /* 22 */ { FM, 0x00, 0 }, |
| 135 | /* 23 */ { RAWBITS, 0x9254, 0 }, |
| 136 | /* 24 */ { END } |
| 137 | }; |
| 114 | 138 | |
| 115 | | const format &f = formats[type]; |
| 139 | current_size = f.gap_1*16; |
| 140 | if(f.sector_base_size) |
| 141 | current_size += f.sector_base_size * f.sector_count * 16; |
| 142 | else { |
| 143 | for(int j=0; j != f.sector_count; j++) |
| 144 | current_size += f.per_sector_size[j] * 16; |
| 145 | } |
| 146 | current_size += (6+1+4+2+f.gap_2+6+1+2+f.gap_3) * f.sector_count * 16; |
| 116 | 147 | |
| 117 | | floppy_image_format_t::desc_e desc[] = { |
| 148 | return desc; |
| 149 | } |
| 150 | |
| 151 | floppy_image_format_t::desc_e* wd177x_format::get_desc_mfm(const format &f, int ¤t_size) |
| 152 | { |
| 153 | static floppy_image_format_t::desc_e desc[25] = { |
| 118 | 154 | /* 00 */ { MFM, 0x4e, f.gap_1 }, |
| 119 | 155 | /* 01 */ { SECTOR_LOOP_START, 0, f.sector_count-1 }, |
| 120 | 156 | /* 02 */ { MFM, 0x00, 12 }, |
| r20117 | r20118 | |
| 142 | 178 | /* 24 */ { END } |
| 143 | 179 | }; |
| 144 | 180 | |
| 145 | | int current_size = f.gap_1*16; |
| 181 | current_size = f.gap_1*16; |
| 146 | 182 | if(f.sector_base_size) |
| 147 | 183 | current_size += f.sector_base_size * f.sector_count * 16; |
| 148 | 184 | else { |
| r20117 | r20118 | |
| 151 | 187 | } |
| 152 | 188 | current_size += (12+3+1+4+2+f.gap_2+12+3+1+2+f.gap_3) * f.sector_count * 16; |
| 153 | 189 | |
| 190 | return desc; |
| 191 | } |
| 192 | |
| 193 | bool wd177x_format::load(io_generic *io, UINT32 form_factor, floppy_image *image) |
| 194 | { |
| 195 | int type = find_size(io, form_factor); |
| 196 | if(type == -1) |
| 197 | return false; |
| 198 | |
| 199 | const format &f = formats[type]; |
| 200 | floppy_image_format_t::desc_e *desc; |
| 201 | int current_size; |
| 202 | |
| 203 | switch (f.encoding) |
| 204 | { |
| 205 | case floppy_image::FM: |
| 206 | desc = get_desc_fm(f, current_size); |
| 207 | break; |
| 208 | case floppy_image::MFM: |
| 209 | default: |
| 210 | desc = get_desc_mfm(f, current_size); |
| 211 | break; |
| 212 | } |
| 213 | |
| 154 | 214 | int total_size = 200000000/f.cell_size; |
| 155 | 215 | int remaining_size = total_size - current_size; |
| 156 | 216 | if(remaining_size < 0) |
| r20117 | r20118 | |
| 308 | 368 | |
| 309 | 369 | // Extract the sectors |
| 310 | 370 | generate_bitstream_from_track(0, 0, formats[candidates[0]].cell_size, bitstream, track_size, image); |
| 311 | | extract_sectors_from_bitstream_mfm_pc(bitstream, track_size, sectors, sectdata, sizeof(sectdata)); |
| 312 | 371 | |
| 372 | switch (formats[candidates[0]].encoding) |
| 373 | { |
| 374 | case floppy_image::FM: |
| 375 | extract_sectors_from_bitstream_fm_pc(bitstream, track_size, sectors, sectdata, sizeof(sectdata)); |
| 376 | break; |
| 377 | case floppy_image::MFM: |
| 378 | extract_sectors_from_bitstream_mfm_pc(bitstream, track_size, sectors, sectdata, sizeof(sectdata)); |
| 379 | break; |
| 380 | } |
| 381 | |
| 313 | 382 | // Check compatibility with every candidate, copy in-place |
| 314 | 383 | int *ok_cands = candidates; |
| 315 | 384 | for(int i=0; i != candidates_count; i++) { |
| r20117 | r20118 | |
| 343 | 412 | candidates_count = ok_cands - candidates; |
| 344 | 413 | } |
| 345 | 414 | |
| 346 | | |
| 347 | 415 | void wd177x_format::extract_sectors(floppy_image *image, const format &f, desc_s *sdesc, int track, int head) |
| 348 | 416 | { |
| 349 | 417 | UINT8 bitstream[500000/8]; |
| r20117 | r20118 | |
| 353 | 421 | |
| 354 | 422 | // Extract the sectors |
| 355 | 423 | generate_bitstream_from_track(track, head, f.cell_size, bitstream, track_size, image); |
| 356 | | extract_sectors_from_bitstream_mfm_pc(bitstream, track_size, sectors, sectdata, sizeof(sectdata)); |
| 357 | 424 | |
| 425 | switch (f.encoding) |
| 426 | { |
| 427 | case floppy_image::FM: |
| 428 | extract_sectors_from_bitstream_fm_pc(bitstream, track_size, sectors, sectdata, sizeof(sectdata)); |
| 429 | break; |
| 430 | case floppy_image::MFM: |
| 431 | extract_sectors_from_bitstream_mfm_pc(bitstream, track_size, sectors, sectdata, sizeof(sectdata)); |
| 432 | break; |
| 433 | } |
| 434 | |
| 358 | 435 | for(int i=0; i<f.sector_count; i++) { |
| 359 | 436 | desc_s &ds = sdesc[i]; |
| 360 | 437 | desc_xs &xs = sectors[ds.sector_id]; |
trunk/src/lib/formats/comx35_dsk.c
| r20117 | r20118 | |
| 43 | 43 | |
| 44 | 44 | TODO: |
| 45 | 45 | |
| 46 | | - implement 70 track image detection |
| 46 | - implement 70 track image detection (first byte of file = 0x01 -> single sided) |
| 47 | - format double sided, single track density |
| 47 | 48 | |
| 49 | :exp:fd:wd1770: track description |
| 50 | 40xff 6x00 |
| 51 | fe 4x00 f7 17x00 fb 128x00 f7 17x00 |
| 52 | fe 2x00 07 00 f7 17x00 fb 128x00 f7 17x00 |
| 53 | fe 2x00 0e 00 f7 17x00 fb 128x00 f7 16x00 |
| 54 | fe 2x00 05 00 f7 17x00 fb 128x00 f7 17x00 |
| 55 | fe 2x00 0c 00 f7 17x00 fb 128x00 f7 16x00 |
| 56 | fe 2x00 03 00 f7 17x00 fb 128x00 f7 17x00 |
| 57 | fe 2x00 0a 00 f7 17x00 fb 128x00 f7 16x00 |
| 58 | fe 2x00 01 00 f7 17x00 fb 128x00 f7 17x00 |
| 59 | fe 2x00 08 00 f7 17x00 fb 128x00 f7 17x00 |
| 60 | fe 2x00 0f 00 f7 17x00 fb 128x00 f7 16x00 |
| 61 | fe 2x00 06 00 f7 17x00 fb 128x00 f7 17x00 |
| 62 | fe 2x00 0d 00 f7 17x00 fb 128x00 f7 16x00 |
| 63 | fe 2x00 04 00 f7 17x00 fb 128x00 f7 17x00 |
| 64 | fe 2x00 0b 00 f7 17x00 fb 128x00 f7 16x00 |
| 65 | fe 2x00 02 00 f7 17x00 fb 128x00 f7 17x00 |
| 66 | fe 2x00 09 00 f7 17x00 fb 128x00 f7 3476x00 |
| 67 | |
| 48 | 68 | */ |
| 49 | 69 | |
| 50 | 70 | #include "emu.h" |
| r20117 | r20118 | |
| 71 | 91 | |
| 72 | 92 | // Unverified gap sizes |
| 73 | 93 | const comx35_format::format comx35_format::formats[] = { |
| 74 | | { // 70K 5 1/4 inch single density single sided 35 tracks |
| 75 | | floppy_image::FF_525, floppy_image::SSSD, |
| 76 | | 2000, 16, 35, 1, 128, {}, 0, {}, 100, 22, 84 |
| 94 | { // 70K 5 1/4 inch single density, single sided, 35 tracks |
| 95 | floppy_image::FF_525, floppy_image::SSSD, floppy_image::FM, |
| 96 | 4000, 16, 35, 1, 128, {}, -1, { 0,7,14,5,12,3,10,1,8,15,6,13,4,11,2,9 }, 40, 11, 10 |
| 77 | 97 | }, |
| 78 | | { // 140K 5 1/4 inch single density double sided 35 tracks |
| 79 | | floppy_image::FF_525, floppy_image::DSSD, |
| 80 | | 2000, 16, 35, 2, 128, {}, 0, {}, 100, 22, 84 |
| 98 | { // 140K 5 1/4 inch single density, double sided, 35 tracks |
| 99 | floppy_image::FF_525, floppy_image::DSSD, floppy_image::FM, |
| 100 | 4000, 16, 35, 2, 128, {}, -1, { 0,7,14,5,12,3,10,1,8,15,6,13,4,11,2,9 }, 40, 11, 10 |
| 81 | 101 | }, |
| 82 | | /*{ // 140K 5 1/4 inch quad density single sided 70 tracks |
| 83 | | floppy_image::FF_525, floppy_image::SSQD, |
| 84 | | 2000, 16, 70, 1, 128, {}, 0, {}, 100, 22, 84 |
| 102 | /*{ // 140K 5 1/4 inch single density, double track density, single sided, 70 tracks |
| 103 | floppy_image::FF_525, floppy_image::SSQD, floppy_image::FM, |
| 104 | 4000, 16, 70, 1, 128, {}, -1, { 0,7,14,5,12,3,10,1,8,15,6,13,4,11,2,9 }, 40, 11, 10 |
| 85 | 105 | },*/ |
| 86 | 106 | {} |
| 87 | 107 | }; |
| 88 | 108 | |
| 89 | 109 | const floppy_format_type FLOPPY_COMX35_FORMAT = &floppy_image_format_creator<comx35_format>; |
| 90 | | |
| 91 | | |
| 92 | | #ifdef UNUSED_CODE |
| 93 | | |
| 94 | | /********************************************************************* |
| 95 | | |
| 96 | | formats/comx35_dsk.c |
| 97 | | |
| 98 | | COMX35 disk images |
| 99 | | |
| 100 | | *********************************************************************/ |
| 101 | | |
| 102 | | #include "formats/comx35_dsk.h" |
| 103 | | #include "formats/basicdsk.h" |
| 104 | | |
| 105 | | /*************************************************************************** |
| 106 | | IMPLEMENTATION |
| 107 | | ***************************************************************************/ |
| 108 | | |
| 109 | | /*------------------------------------------------- |
| 110 | | FLOPPY_IDENTIFY( comx35_dsk_identify ) |
| 111 | | -------------------------------------------------*/ |
| 112 | | |
| 113 | | static FLOPPY_IDENTIFY( comx35_dsk_identify ) |
| 114 | | { |
| 115 | | *vote = ((floppy_image_size(floppy) == (35*1*16*128)) || (floppy_image_size(floppy) == (35*2*16*128))) ? 100 : 0; |
| 116 | | |
| 117 | | return FLOPPY_ERROR_SUCCESS; |
| 118 | | } |
| 119 | | |
| 120 | | /*------------------------------------------------- |
| 121 | | FLOPPY_CONSTRUCT( comx35_dsk_construct ) |
| 122 | | -------------------------------------------------*/ |
| 123 | | |
| 124 | | static FLOPPY_CONSTRUCT( comx35_dsk_construct ) |
| 125 | | { |
| 126 | | UINT8 header[1]; |
| 127 | | int heads = 1; |
| 128 | | int cylinders = 35; |
| 129 | | |
| 130 | | switch (floppy_image_size(floppy)) |
| 131 | | { |
| 132 | | case 35*1*16*128: |
| 133 | | heads = 1; |
| 134 | | cylinders = 35; |
| 135 | | break; |
| 136 | | |
| 137 | | case 35*2*16*128: |
| 138 | | floppy_image_read(floppy, header, 0x12, 1); |
| 139 | | |
| 140 | | if (header[0] == 0x01) |
| 141 | | { |
| 142 | | heads = 1; |
| 143 | | cylinders = 70; |
| 144 | | } |
| 145 | | else |
| 146 | | { |
| 147 | | heads = 2; |
| 148 | | cylinders = 35; |
| 149 | | } |
| 150 | | break; |
| 151 | | } |
| 152 | | |
| 153 | | struct basicdsk_geometry geometry; |
| 154 | | memset(&geometry, 0, sizeof(geometry)); |
| 155 | | |
| 156 | | geometry.heads = heads; |
| 157 | | geometry.first_sector_id = 0; |
| 158 | | geometry.sector_length = 128; |
| 159 | | geometry.tracks = cylinders; |
| 160 | | geometry.sectors = 16; |
| 161 | | |
| 162 | | return basicdsk_construct(floppy, &geometry); |
| 163 | | } |
| 164 | | |
| 165 | | /*------------------------------------------------- |
| 166 | | FLOPPY_OPTIONS( comx35 ) |
| 167 | | -------------------------------------------------*/ |
| 168 | | |
| 169 | | LEGACY_FLOPPY_OPTIONS_START( comx35 ) |
| 170 | | LEGACY_FLOPPY_OPTION( comx35, "img", "COMX35 floppy disk image", comx35_dsk_identify, comx35_dsk_construct, NULL, NULL ) |
| 171 | | LEGACY_FLOPPY_OPTIONS_END |
| 172 | | |
| 173 | | #endif |
trunk/src/lib/formats/flopimg.c
| r20117 | r20118 | |
| 1102 | 1102 | bool floppy_image_format_t::type_no_data(int type) const |
| 1103 | 1103 | { |
| 1104 | 1104 | return type == CRC_CCITT_START || |
| 1105 | type == CRC_CCITT_FM_START || |
| 1105 | 1106 | type == CRC_AMIGA_START || |
| 1106 | 1107 | type == CRC_MACHEAD_START || |
| 1107 | 1108 | type == CRC_END || |
| r20117 | r20118 | |
| 1115 | 1116 | return !type_no_data(type) && |
| 1116 | 1117 | type != RAW && |
| 1117 | 1118 | type != RAWBITS && |
| 1118 | | (type != CRC || (crcs[p1].type != CRC_CCITT && crcs[p1].type != CRC_AMIGA)); |
| 1119 | (type != CRC || (crcs[p1].type != CRC_CCITT && crcs[p1].type != CRC_CCITT_FM && crcs[p1].type != CRC_AMIGA)); |
| 1119 | 1120 | } |
| 1120 | 1121 | |
| 1121 | 1122 | void floppy_image_format_t::collect_crcs(const desc_e *desc, gen_crc_info *crcs) |
| r20117 | r20118 | |
| 1129 | 1130 | case CRC_CCITT_START: |
| 1130 | 1131 | crcs[desc[i].p1].type = CRC_CCITT; |
| 1131 | 1132 | break; |
| 1133 | case CRC_CCITT_FM_START: |
| 1134 | crcs[desc[i].p1].type = CRC_CCITT_FM; |
| 1135 | break; |
| 1132 | 1136 | case CRC_AMIGA_START: |
| 1133 | 1137 | crcs[desc[i].p1].type = CRC_AMIGA; |
| 1134 | 1138 | break; |
| r20117 | r20118 | |
| 1149 | 1153 | { |
| 1150 | 1154 | switch(type) { |
| 1151 | 1155 | case CRC_CCITT: return 32; |
| 1156 | case CRC_CCITT_FM: return 32; |
| 1152 | 1157 | case CRC_AMIGA: return 64; |
| 1153 | 1158 | case CRC_MACHEAD: return 8; |
| 1154 | 1159 | default: return 0; |
| r20117 | r20118 | |
| 1242 | 1247 | mfm_w(buffer, offset, 16, calc_crc_ccitt(buffer, crc->start, crc->end)); |
| 1243 | 1248 | } |
| 1244 | 1249 | |
| 1250 | void floppy_image_format_t::fixup_crc_ccitt_fm(UINT32 *buffer, const gen_crc_info *crc) |
| 1251 | { |
| 1252 | int offset = crc->write; |
| 1253 | fm_w(buffer, offset, 16, calc_crc_ccitt(buffer, crc->start, crc->end)); |
| 1254 | } |
| 1255 | |
| 1245 | 1256 | void floppy_image_format_t::fixup_crc_machead(UINT32 *buffer, const gen_crc_info *crc) |
| 1246 | 1257 | { |
| 1247 | 1258 | UINT8 v = 0; |
| r20117 | r20118 | |
| 1258 | 1269 | switch(crcs[i].type) { |
| 1259 | 1270 | case CRC_AMIGA: fixup_crc_amiga(buffer, crcs+i); break; |
| 1260 | 1271 | case CRC_CCITT: fixup_crc_ccitt(buffer, crcs+i); break; |
| 1272 | case CRC_CCITT_FM: fixup_crc_ccitt_fm(buffer, crcs+i); break; |
| 1261 | 1273 | case CRC_MACHEAD: fixup_crc_machead(buffer, crcs+i); break; |
| 1262 | 1274 | } |
| 1263 | 1275 | if(crcs[i].fixup_mfm_clock) { |
| r20117 | r20118 | |
| 1339 | 1351 | while(desc[index].type != END) { |
| 1340 | 1352 | // printf("%d.%d.%d (%d) - %d %d\n", desc[index].type, desc[index].p1, desc[index].p2, index, offset, offset/8); |
| 1341 | 1353 | switch(desc[index].type) { |
| 1354 | case FM: |
| 1355 | for(int i=0; i<desc[index].p2; i++) |
| 1356 | fm_w(buffer, offset, 8, desc[index].p1); |
| 1357 | break; |
| 1358 | |
| 1342 | 1359 | case MFM: |
| 1343 | 1360 | for(int i=0; i<desc[index].p2; i++) |
| 1344 | 1361 | mfm_w(buffer, offset, 8, desc[index].p1); |
| r20117 | r20118 | |
| 1361 | 1378 | mfm_w(buffer, offset, 8, track); |
| 1362 | 1379 | break; |
| 1363 | 1380 | |
| 1381 | case TRACK_ID_FM: |
| 1382 | fm_w(buffer, offset, 8, track); |
| 1383 | break; |
| 1384 | |
| 1364 | 1385 | case TRACK_ID_GCR6: |
| 1365 | 1386 | raw_w(buffer, offset, 8, gcr6fw_tb[track & 0x3f]); |
| 1366 | 1387 | break; |
| r20117 | r20118 | |
| 1369 | 1390 | mfm_w(buffer, offset, 8, head); |
| 1370 | 1391 | break; |
| 1371 | 1392 | |
| 1393 | case HEAD_ID_FM: |
| 1394 | fm_w(buffer, offset, 8, head); |
| 1395 | break; |
| 1396 | |
| 1372 | 1397 | case HEAD_ID_SWAP: |
| 1373 | 1398 | mfm_w(buffer, offset, 8, !head); |
| 1374 | 1399 | break; |
| r20117 | r20118 | |
| 1381 | 1406 | mfm_w(buffer, offset, 8, sect[sector_idx].sector_id); |
| 1382 | 1407 | break; |
| 1383 | 1408 | |
| 1409 | case SECTOR_ID_FM: |
| 1410 | fm_w(buffer, offset, 8, sect[sector_idx].sector_id); |
| 1411 | break; |
| 1412 | |
| 1384 | 1413 | case SECTOR_ID_GCR6: |
| 1385 | 1414 | raw_w(buffer, offset, 8, gcr6fw_tb[sect[sector_idx].sector_id]); |
| 1386 | 1415 | break; |
| r20117 | r20118 | |
| 1393 | 1422 | break; |
| 1394 | 1423 | } |
| 1395 | 1424 | |
| 1425 | case SIZE_ID_FM: { |
| 1426 | int size = sect[sector_idx].size; |
| 1427 | int id; |
| 1428 | for(id = 0; size > 128; size >>=1, id++); |
| 1429 | fm_w(buffer, offset, 8, id); |
| 1430 | break; |
| 1431 | } |
| 1432 | |
| 1396 | 1433 | case SECTOR_INFO_GCR6: |
| 1397 | 1434 | raw_w(buffer, offset, 8, gcr6fw_tb[sect[sector_idx].sector_info]); |
| 1398 | 1435 | break; |
| r20117 | r20118 | |
| 1446 | 1483 | |
| 1447 | 1484 | case CRC_AMIGA_START: |
| 1448 | 1485 | case CRC_CCITT_START: |
| 1486 | case CRC_CCITT_FM_START: |
| 1449 | 1487 | case CRC_MACHEAD_START: |
| 1450 | 1488 | crcs[desc[index].p1].start = offset; |
| 1451 | 1489 | break; |
| r20117 | r20118 | |
| 1466 | 1504 | break; |
| 1467 | 1505 | } |
| 1468 | 1506 | |
| 1507 | case SECTOR_DATA_FM: { |
| 1508 | const desc_s *csect = sect + (desc[index].p1 >= 0 ? desc[index].p1 : sector_idx); |
| 1509 | for(int i=0; i != csect->size; i++) |
| 1510 | fm_w(buffer, offset, 8, csect->data[i]); |
| 1511 | break; |
| 1512 | } |
| 1513 | |
| 1469 | 1514 | case SECTOR_DATA_O: { |
| 1470 | 1515 | const desc_s *csect = sect + (desc[index].p1 >= 0 ? desc[index].p1 : sector_idx); |
| 1471 | 1516 | for(int i=0; i != csect->size; i++) |
trunk/src/lib/formats/flopimg.h
| r20117 | r20118 | |
| 301 | 301 | //! Opcodes of the format description language used by generate_track() |
| 302 | 302 | enum { |
| 303 | 303 | END, //!< End of description |
| 304 | FM, //!< One byte in p1 to be fm-encoded, msb first, repeated p2 times |
| 304 | 305 | MFM, //!< One byte in p1 to be mfm-encoded, msb first, repeated p2 times |
| 305 | 306 | MFMBITS, //!< A value of p2 bits in p1 to be mfm-encoded, msb first |
| 306 | 307 | RAW, //!< One 16 bits word in p1 to be written raw, msb first, repeated p2 times |
| 307 | 308 | RAWBITS, //!< A value of p2 bits in p1 to be copied as-is, msb first |
| 308 | 309 | TRACK_ID, //!< Track id byte, mfm-encoded |
| 310 | TRACK_ID_FM, //!< Track id byte, fm-encoded |
| 309 | 311 | TRACK_ID_GCR6, //!< Track id low 6 bits, gcr6-encoded |
| 310 | 312 | HEAD_ID, //!< Head id byte, mfm-encoded |
| 313 | HEAD_ID_FM, //!< Head id byte, fm-encoded |
| 311 | 314 | HEAD_ID_SWAP, //!< Head id byte swapped (0->1, 1->0), mfm-encoded |
| 312 | 315 | TRACK_HEAD_ID_GCR6, //!< Track id 7th bit + head, gc6-encoded |
| 313 | 316 | SECTOR_ID, //!< Sector id byte, mfm-encoded |
| 317 | SECTOR_ID_FM, //!< Sector id byte, fm-encoded |
| 314 | 318 | SECTOR_ID_GCR6, //!< Sector id byte, gcr6-encoded |
| 315 | 319 | SIZE_ID, //!< Sector size code on one byte [log2(size/128)], mfm-encoded |
| 320 | SIZE_ID_FM, //!< Sector size code on one byte [log2(size/128)], fm-encoded |
| 316 | 321 | SECTOR_INFO_GCR6, //!< Sector info byte, gcr6-encoded |
| 317 | 322 | OFFSET_ID_O, //!< Offset (track*2+head) byte, odd bits, mfm-encoded |
| 318 | 323 | OFFSET_ID_E, //!< Offset (track*2+head) byte, even bits, mfm-encoded |
| r20117 | r20118 | |
| 322 | 327 | REMAIN_E, //!< Remaining sector count, even bits, mfm-encoded, total sector count in p1 |
| 323 | 328 | |
| 324 | 329 | SECTOR_DATA, //!< Sector data to mfm-encode, which in p1, -1 for the current one per the sector id |
| 330 | SECTOR_DATA_FM, //!< Sector data to fm-encode, which in p1, -1 for the current one per the sector id |
| 325 | 331 | SECTOR_DATA_O, //!< Sector data to mfm-encode, odd bits only, which in p1, -1 for the current one per the sector id |
| 326 | 332 | SECTOR_DATA_E, //!< Sector data to mfm-encode, even bits only, which in p1, -1 for the current one per the sector id |
| 327 | 333 | SECTOR_DATA_MAC, //!< Transformed sector data + checksum, mac style, id in p1, -1 for the current one per the sector id |
| 328 | 334 | |
| 329 | 335 | CRC_CCITT_START, //!< Start a CCITT CRC calculation, with the usual x^16 + x^12 + x^5 + 1 (11021) polynomial, p1 = crc id |
| 336 | CRC_CCITT_FM_START, //!< Start a CCITT CRC calculation, with the usual x^16 + x^12 + x^5 + 1 (11021) polynomial, p1 = crc id |
| 330 | 337 | CRC_AMIGA_START, //!< Start an amiga checksum calculation, p1 = crc id |
| 331 | 338 | CRC_MACHEAD_START, //!< Start of the mac gcr6 sector header checksum calculation (xor of pre-encode 6-bits values, gcr6-encoded) |
| 332 | 339 | CRC_END, //!< End the checksum, p1 = crc id |
| r20117 | r20118 | |
| 542 | 549 | void gcr6_decode(UINT8 e0, UINT8 e1, UINT8 e2, UINT8 e3, UINT8 &va, UINT8 &vb, UINT8 &vc); |
| 543 | 550 | |
| 544 | 551 | private: |
| 545 | | enum { CRC_NONE, CRC_AMIGA, CRC_CCITT, CRC_MACHEAD }; |
| 552 | enum { CRC_NONE, CRC_AMIGA, CRC_CCITT, CRC_CCITT_FM, CRC_MACHEAD }; |
| 546 | 553 | enum { MAX_CRC_COUNT = 64 }; |
| 547 | 554 | |
| 548 | 555 | //! Holds data used internally for generating CRCs. |
| r20117 | r20118 | |
| 560 | 567 | int crc_cells_size(int type) const; |
| 561 | 568 | void fixup_crc_amiga(UINT32 *buffer, const gen_crc_info *crc); |
| 562 | 569 | void fixup_crc_ccitt(UINT32 *buffer, const gen_crc_info *crc); |
| 570 | void fixup_crc_ccitt_fm(UINT32 *buffer, const gen_crc_info *crc); |
| 563 | 571 | void fixup_crc_machead(UINT32 *buffer, const gen_crc_info *crc); |
| 564 | 572 | void fixup_crcs(UINT32 *buffer, gen_crc_info *crcs); |
| 565 | 573 | void collect_crcs(const desc_e *desc, gen_crc_info *crcs); |
| r20117 | r20118 | |
| 651 | 659 | DSED = 0x44455344, //!< "DSED", Double-sided extra-density (2880K) |
| 652 | 660 | }; |
| 653 | 661 | |
| 662 | //! Encodings |
| 663 | enum { |
| 664 | FM = 0x2020464D, //!< " FM", frequency modulation |
| 665 | MFM = 0x204D464D, //!< " MFM", modified frequency modulation |
| 666 | M2FM = 0x4D32464D, //!< "M2FM", modified modified frequency modulation |
| 667 | }; |
| 668 | |
| 654 | 669 | // construction/destruction |
| 655 | 670 | |
| 656 | 671 | |
trunk/src/lib/formats/tiki100_dsk.c
| r20117 | r20118 | |
| 65 | 65 | // double sided disks have t0s0,t0s1,t1s0,t1s1... format |
| 66 | 66 | const tiki100_format::format tiki100_format::formats[] = { |
| 67 | 67 | { // 90K 5 1/4 inch single density single sided |
| 68 | | floppy_image::FF_525, floppy_image::SSSD, |
| 69 | | 2000, 18, 40, 1, 128, {}, 1, {}, 80, 22, 20 |
| 68 | floppy_image::FF_525, floppy_image::SSSD, floppy_image::FM, |
| 69 | 4000, 18, 40, 1, 128, {}, 1, {}, 80, 22, 20 |
| 70 | 70 | }, |
| 71 | 71 | { // 200K 5 1/4 inch double density single sided |
| 72 | | floppy_image::FF_525, floppy_image::SSDD, |
| 72 | floppy_image::FF_525, floppy_image::SSDD, floppy_image::MFM, |
| 73 | 73 | 2000, 10, 40, 1, 512, {}, -1, { 1,6,2,7,3,8,4,9,5,10 }, 80, 22, 20 |
| 74 | 74 | }, |
| 75 | 75 | { // 400K 5 1/4 inch double density |
| 76 | | floppy_image::FF_525, floppy_image::DSDD, |
| 76 | floppy_image::FF_525, floppy_image::DSDD, floppy_image::MFM, |
| 77 | 77 | 2000, 10, 40, 2, 512, {}, -1, { 1,6,2,7,3,8,4,9,5,10 }, 80, 22, 20 |
| 78 | 78 | }, |
| 79 | 79 | { // 800K 5 1/4 inch quad density |
| 80 | | floppy_image::FF_525, floppy_image::DSQD, |
| 80 | floppy_image::FF_525, floppy_image::DSQD, floppy_image::MFM, |
| 81 | 81 | 2000, 10, 80, 2, 512, {}, -1, { 1,6,2,7,3,8,4,9,5,10 }, 80, 22, 20 |
| 82 | 82 | }, |
| 83 | 83 | {} |
trunk/src/lib/formats/adam_dsk.c
| r20117 | r20118 | |
| 64 | 64 | // Unverified gap sizes |
| 65 | 65 | const adam_format::format adam_format::formats[] = { |
| 66 | 66 | { /* 160K 5 1/4 inch double density single sided */ |
| 67 | | floppy_image::FF_525, floppy_image::SSDD, |
| 67 | floppy_image::FF_525, floppy_image::SSDD, floppy_image::MFM, |
| 68 | 68 | 2000, 8, 40, 1, 512, {}, 1, {}, 100, 22, 84 |
| 69 | 69 | }, |
| 70 | 70 | { /* 320K 5 1/4 inch double density */ |
| 71 | | floppy_image::FF_525, floppy_image::DSDD, |
| 71 | floppy_image::FF_525, floppy_image::DSDD, floppy_image::MFM, |
| 72 | 72 | 2000, 8, 40, 2, 512, {}, 1, {}, 100, 22, 84 |
| 73 | 73 | }, |
| 74 | 74 | { /* 640K 5 1/4 inch quad density */ |
| 75 | | floppy_image::FF_525, floppy_image::DSQD, |
| 75 | floppy_image::FF_525, floppy_image::DSQD, floppy_image::MFM, |
| 76 | 76 | 2000, 8, 80, 2, 512, {}, 1, {}, 100, 22, 84 |
| 77 | 77 | }, |
| 78 | 78 | { /* 720K 3 1/2 inch double density */ |
| 79 | | floppy_image::FF_35, floppy_image::DSDD, |
| 79 | floppy_image::FF_35, floppy_image::DSDD, floppy_image::MFM, |
| 80 | 80 | 2000, 9, 80, 2, 512, {}, 1, {}, 100, 22, 84 |
| 81 | 81 | }, |
| 82 | 82 | { /* 1440K 3 1/2 inch high density */ |
| 83 | | floppy_image::FF_35, floppy_image::DSHD, |
| 83 | floppy_image::FF_35, floppy_image::DSHD, floppy_image::MFM, |
| 84 | 84 | 1000, 18, 80, 2, 512, {}, 1, {}, 100, 22, 84 |
| 85 | 85 | }, |
| 86 | 86 | {} |