HP85 GPIB Disk Emulator
1.0
HP85GPIBDiskEmulator
|
Go to the documentation of this file.
68 void td0_B2S(uint8_t *B,
int index, uint8_t *name,
int size)
87 uint16_t
td0_crc16(uint8_t *B, uint16_t crc, uint16_t poly,
int size)
92 crc ^= (0xff00 & ((uint16_t)B[i] << 8));
94 for (bit = 0; bit < 8; bit++)
96 if ((crc & 0x8000) != 0)
97 crc = (uint16_t) ((crc << 1) ^ poly);
119 len = size > 16 ? 16 : size;
122 printf(
"%02x ",0xff & data[addr+i]);
130 if(data[addr+i] >= 0x20 && data[addr+i] <= 0x7e)
169 printf(
"TeleDisk error Header CRC16:%04Xh != %04Xh\n", (
int)crc, (
int)p->
CRC);
219 printf(
"TeleDisk error Track CRC16:%04Xh != %04Xh\n", (
int)crc, (
int)p->
CRC);
220 printf(
"\tCyl:%02d, Side:%02d, Sectors:%d\n",
273 count = osize * size;
276 c = lzss_getbyte(fp);
279 if(ind != (osize * size))
289 ind =
fread(p,osize,size,fp);
332 printf(
"td0_rle: type 0 len:%d > max:%d\n", len, max);
350 printf(
"td0_rle: type 1 len:%d > max:%d\n", len, max);
372 if((result+size) > max)
374 printf(
"td0_rle: type 1 len:%d > max:%d\n",
380 memcpy(
dst,src,size);
390 size = (1 << src[0]);
401 if((result+size) > max)
403 printf(
"td0_rle: type 1 len:%d > max:%d\n",
409 memcpy(
dst, src, size);
423 printf(
"td0_rle: type 1 len:%d < 0\n", len);
429 printf(
"td0_rle error unsupported type:%02Xh\n", type);
445 printf(
"cylinder:%02d, head:%02d, sector:%02d, size:%d, index:%d\n",
460 printf(
"cyl: %02d, side: %02d, sector: %02d, size: %03d\n",
474 long bitrate = 250000;
562 printf(
"\tAdvanced Compression\n");
564 printf(
"\tNot Compressed\n");
573 printf(
"Error: only TeleDisk versions 10 to 21 supported\n");
584 printf(
"Error: reading commment\n");
600 printf(
"Error: reading commment\n");
633 printf(
"\tNo Comment Block\n");
646 int cyl,head,sector,size;
648 int index, tracksectors, found, result;
656 uint8_t buffer[8*1024];
679 printf(
"Error: reading track header\n");
708 printf(
"Track: Cyl: %02d, Side: %02d, Sectors: %02d\n",
714 for ( s=0; s < td_track.
PSectors; s++ )
719 printf(
"Error: reading sector header\n");
720 printf(
"\t Track: Cyl: %02d, Side: %02d, Sectors: %02d\n",
728 if(td_track.
PCyl != td_sector.
Cyl )
730 printf(
"Warning: track Cyl:%d != sector Cyl:%d skipping\n",
731 (
int)td_track.
PCyl, (
int) td_sector.
Cyl);
739 printf(
"Warning: track side:%d != sector side:%d skipping\n",
740 (
int)td_track.
PSide, (
int) td_sector.
Side);
754 printf(
"Error: sector index: %d >= MAXSECTORS\n",
764 printf(
"Warning: skipping duplicate sector: %02d, skipping\n", index);
778 if(td_sector.
Flags & 0x02)
780 printf(
"Warning: alternate CRC flag not implemented\n");
784 if(td_sector.
Flags & 0x04)
786 printf(
"Warning: alternate data mark not implemented\n");
790 if(td_sector.
Flags & 0x20)
792 printf(
"Warning: missing address mark not implemented\n");
799 if ( !(td_sector.
SizeExp & 0xf8) && !(td_sector.
Flags & 0x30))
805 memset(buffer,0,
sizeof(buffer));
809 printf(
"Error: reading sector header\n");
818 printf(
"Error: reading sector data\n");
832 printf(
"Error: RLE result:%d != sector size:%d\n",
841 if(td_sector.
CRC != crc)
843 printf(
"Warning: Sector CRC16:%04Xh != %04Xh\n",
844 (
int)crc, (
int)td_sector.
CRC);
852 printf(
"Warning: unsupported sector flags:%02Xh\n", (
int)td_sector.
Flags);
904 int reject_side_two = 0;
915 printf(
"Warning: Override number of sides from 2 to 1\n");
921 printf(
"Error: NO sectors detected\n");
933 printf(
"Error: NO sectors detected\n");
965 for( t = 0; t < maxtracks; ++ t)
988 printf(
"Error: NO sectors detected\n");
997 for( t = 0; t < maxtracks; ++t)
999 maxsectors[t & 1] = 0;
1012 if( sector < 100 && sector >
liftel.
s.
last[t & 1] )
1017 ++maxsectors[t & 1];
1040 reject_side_two = 1;
1047 reject_side_two = 1;
1057 reject_side_two = 1;
1065 printf(
"Error: Damaged Disk - this should never happen\n");
1091 printf(
"Warning: Side %d user size:[%03d] NOT same as detected:[%03d]\n",
1131 if( reject_side_two)
1157 printf(
"track: [%d]\n", t);
1158 printf(
"sector count :[%d]\n", maxsectors[t & 1]);
1160 printf(
"flag:%d\n", flag);
1175 printf(
"Warning: track:0 has zero sectors\n");
1222 printf(
"Warning: Sector:%02d missing - found alternate sector:%02d\n",
1243 printf(
"Warning: Sector:%02d missing - zero filling\n", s);
1245 printf(
"Track: Cyl: %02d, Side: %02d\n",
1269 printf(
"\t Sector numbering: %2d to %2d\n",
1279 printf(
"Warning: rejecting side two\n");
1281 printf(
"\t Warning: Sector size: NOT the same on both sides\n");
1284 printf(
"\t Warning: Sector count: NOT the same on both sides\n");
1290 printf(
"\t Warning: Sector range: NOT a continuation of side 0\n");
1319 printf(
"ERROR: track:%02d, sector:%02d == NULL\n", t, s);
1320 printf(
"\t Program error - should never happen\n");
1321 printf(
"\tGiving up!\n");
1333 printf(
"LIF - no sectors left after processing\n");
1348 printf(
"LIF sectors processed: %ld\n", sectors);
1356 printf(
"LIF sectors processed: %ld\n", sectors);
1395 printf(
"LIF: [%s] position:%ld\n",
1397 printf(
"\t Error: Not a LIF image!\n");
1434 for(dir=0; dir < size; dir+=32)
1444 printf(
"LIF image sectors: [%04lXh]\n", (
long) LIF->
sectors);
1463 printf(
"LIF: [%s] position:%ld\n",
1465 printf(
"\t Warning: directory entry is out of order\n");
1466 printf(
"\t Treating as DirectoryEOF\n");
1482 printf(
"LIF: [%s] position:%ld\n",
1484 printf(
"\t Warning: bad director entry\n");
1485 printf(
"\t Treating as DirectoryEOF\n");
1498 printf(
"LIF: [%s] start:%6lXh size:%6lXh %s\n",
1538 tmp =
fwrite(data, 1, size, LIF->
fp);
1541 printf(
"LIF: [%s] position:%ld\n",
1543 printf(
"\t Write error\n");
1558 printf(
"td02lif help\n");
1562 "Usage: td02lif [options] file.td0 file.lif\n"
1564 "tdo2lif options:\n"
1565 "Notes: for any option that is NOT specified it is automatically detected\n"
1566 "\t -s256|512 | -s 256|512 - force sector size\n"
1567 "\t -h1|2 | -h 1|2 - force heads/surfaces\n"
1568 "\t -tNN | -t NN - force tracks\n"
1657 char *telediskname =
NULL;
1671 if(argc <= 1 ||
MATCHI(argv[1],
"help") )
1693 if(*ptr || (ptr = argv[++i]) )
1696 if(tmp != 256 && tmp != 512)
1698 printf(
"ERROR: size:[%d] != 256 or 512\n", tmp);
1711 if(*ptr || (ptr = argv[++i]) )
1714 if(tmp != 1 && tmp != 2)
1716 printf(
"ERROR: sides:[%d] != 1 or 2\n", tmp);
1730 if(*ptr || (ptr = argv[++i]) )
1745 if(*ptr ==
'?' ||
MATCH(ptr,
"help") )
1751 printf(
"ERROR: bad options:[%s]\n", ptr);
1756 else if(telediskname ==
NULL)
1760 else if(lifname ==
NULL)
1764 else if(
MATCH(ptr,
"help") )
1771 printf(
"ERROR: bad options:[%s]\n", ptr);
1785 if(!lifname|| !
strlen(lifname))
1787 printf(
"Expected LIF filename\n");
1791 if(!telediskname|| !
strlen(telediskname))
1793 printf(
"Expected TeleDisk filename\n");
1799 printf(
"TeleDIsk and LIF names can not be the same\n");
1820 printf(
"TeleDisk Can't open: %s\n",LIF->
name);
1859 printf(
"Done LIF image: [%s] wrote: [%04lXh] sectors\n\n",
MEMSPACE FILE * fopen(const char *path, const char *mode)
POSIX Open a file with path name and ascii file mode string.
MEMSPACE int printf(const char *format,...)
int debuglevel
Debug flag - used to log GPIB and emulator messages.
MEMSPACE int MATCH(char *str, char *pat)
Compare two strings.
MEMSPACE int MATCHI(char *str, char *pat)
Compare two strings without case.
Master LIF data structure Contains image file name Volume Structure Current Directory Entry read/writ...
void td0_sectorinfo(td_sector_t *P)
Display TeleDisk sector data.
#define TD_TRACK_SIZE
Size of TeleDisk track header size.
MEMSPACE time_t timegm(tm_t *t)
Convert tm_t structure as GMT time into GMT seconds since 1900. All calculactions are in GMT regardle...
MEMSPACE void lif_str2dir(uint8_t *B, lif_t *LIF)
Convert byte vector into byte vector.
void td0_trackinfo(disk_t *disk, int trackind, int index)
Display TeleDisk track sector values.
uint32_t B2V_LSB(uint8_t *B, int index, int size)
Convert a byte array into a value bytes are LSB ... MSB order.
MEMSPACE int WEAK_ATR strcasecmp(const char *str, const char *pat)
Compare two strings without case.
int putchar(int c)
put a character to stdout See fdevopen() sets stream->put get for TTY devices
sector_t sectors[MAXSECTORS]
int td0_unpack_disk_header(uint8_t *B, td_header_t *p)
Extract TeleDisk image header data in architecture nutral way.
MEMSPACE char * lif_stralloc(char *str)
Allocate and copy a string Displays message on errors.
dst_t dst
DST start and stop in GMT epoch.
MEMSPACE char * asctime_r(tm_t *t, char *buf)
Convert tm_t *t structure into POSIX asctime() ASCII string *buf.
liftel_t liftel
Teledisk liftel analysis and user overrides.
MEMSPACE size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream)
POSIX write nmemb elements from buf, size bytes each, to the stream fd.
uint16_t td0_crc16(uint8_t *B, uint16_t crc, uint16_t poly, int size)
Compute CRC16 of 8bit data.
#define TD_SECTOR_SIZE
Size of TeleDisk sector header size.
MEMSPACE void lif_str2vol(uint8_t *B, lif_t *LIF)
Convert byte vector into LIF volume records.
MEMSPACE int lif_check_volume(lif_t *LIF)
Check Volume Table for values in range.
void td0_init_sectors(disk_t *disk)
Initialize track sector information Optionally decompress the data if decompression is enabled.
#define MAXSECTORS
Maximum number of sectors per track Used for sector data and sorting tables.
disk_t disk
Dave Dunfiled LZSS expander.
MEMSPACE void lif_dir(char *lifimagename)
Display a LIF image file directory.
Master TeleDisk Format Analisis structure We look for the specifications of LIF image stored inside t...
MEMSPACE void lif_dir2str(lif_t *LIF, uint8_t *B)
Convert LIF directory records into byte vector.
int td0_rle(uint8_t *dst, uint8_t *src, int max)
Expand a Run Length encoded TeleDisk sector Notes: the source length is encoded in the source data Cr...
int td0_unpack_track_header(uint8_t *B, td_track_t *p)
Extract TeleDisk track header data in architecture nutral way.
void td0_hexdump(uint8_t *data, int size)
hex listing of data
int td0_unpack_sector_header(uint8_t *B, td_sector_t *p)
Extract TeleDisk sector header data in architecture nutral way.
MEMSPACE size_t WEAK_ATR strlen(const char *str)
String Length.
MEMSPACE char * lif_lifbcd2timestr(uint8_t *bcd)
int td0_unpack_comment_header(uint8_t *B, td_comment_t *p)
Extract TeleDisk comment header data in architecture nutral way.
Common Linux/POSIX time functions.
#define TD_COMMENT_SIZE
Size of TeleDisk comment header.
int Sectors
Parameters of LIf image inside TeleDisk image - AFTER analysis.
MEMSPACE int fclose(FILE *stream)
POSIX close a file stream.
MEMSPACE int atoi(const char *str)
Convert ASCII string to number in base 10.
#define MAXCYL
Maximum number of tracks per disk.
MEMSPACE time_t time(time_t *t)
Return second from epoch - POSIX function.
int td0_open(disk_t *disk, char *name)
Opne TeleDisk image file process header and optional comment block.
#define MAXSIDES
Maximum number of sides per cyinder TeleDisk only trargetted floppies with 2 sides max!
int td0_analize_format(disk_t *disk)
Analize TeleDisk disk sector data Problem: We may have a disk that was reformatted multiple times Eac...
MEMSPACE int lif_check_dir(lif_t *LIF)
Validate Directory record values We only do basic out of bounds tests for this record Purged or EOF d...
void td0_B2S(uint8_t *B, int index, uint8_t *name, int size)
Create a string from data that has no EOS but known size.
void td0_compressed(int flag)
Enable TeleDisk image compression mode.
LIF file utilities - utilities extracted from hp85disk project for stand alone use.
long td0_density2bitrate(uint8_t density)
Convert Denisity to bitrate @We don't care about the density except as a possible filter.
Track Header Contains the Physical Sectors, Cylinder, Side number From the original physical disk use...
int td0_read(void *p, int osize, int size, FILE *fp)
Read TeleDisk image data block Optionally decompress the data if decompression is enabled.
uint32_t time_t
type of EPOCH result.
MEMSPACE void lif_dump_vol(lif_t *LIF, char *msg)
Dump LIF struture data for debugging.
MEMSPACE void * lif_calloc(long size)
Allocate and clear memory Displays message on errors.
MEMSPACE size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream)
POSIX read nmemb elements from buf, size bytes each, to the stream fd.
int td0_read_disk(disk_t *disk)
Read TeleDisk image file and save all sector data.
#define TD_HEADER_SIZE
Size of TeleDisk image header.
int td0_save_lif(disk_t *disk, lif_t *LIF)
save remaining sectors as LIF data
void td0_init_liftel()
TeleDisk image Analisis structure Find attributes of LIF image stored in TeleDisk image.
int td0_save_lif_sector(disk_t *disk, uint8_t *data, int size, lif_t *LIF)
Process all sectors on a track from TeleDisk image.
MEMSPACE void lif_close_volume(lif_t *LIF)
Free LIF structure and close any files.
int td02lif(int argc, char *argv[])
Convert a Teledisk LIF formatted disk image into a pure LIF image.
MEMSPACE void lif_image_clear(lif_t *LIF)
File seek with error message.
Sector Header Contents of the Sector ID fields which preceeded the sector data From the original phys...