HP85 GPIB Disk Emulator
1.0
HP85GPIBDiskEmulator
|
Go to the documentation of this file.
19 #include "user_config.h"
132 printf(
"[SS80 Test Done]\n");
200 static uint8_t B[19];
247 static uint8_t B[13];
396 printf(
"[SS80 Locate and Read at %08lXH(%lXH)]\n",
437 printf(
"[SS80 Disk Read %02XH bytes]\n", len);
444 printf(
"[SS80 Disk Read Error]\n");
461 printf(
"[SS80 GPIB Write Error]\n");
470 total_bytes = total_bytes + len;
477 printf(
"[SS80 Buffered Read DID NOT FINISH]\n");
483 printf(
"[SS80 Buffered Read Total(%lXH) bytes]\n", (
long) total_bytes);
509 int chunk, count, len;
518 printf(
"[SS80 Locate and Write at %08lXH(%lXH)]\n", (
long)Address, (
long)
SS80s->
Length);
567 printf(
"[GPIB Read Error]\n");
598 printf(
"[Disk Write Error]\n");
604 printf(
"[SS80 Locate and Write wrote(%02XH)]\n", len2);
625 printf(
"[SS80 Locate and Write DID NOT FINISH]\n");
631 printf(
"[SS80 Locate and Write Wrote Total(%lxH)]\n", total_bytes);
644 { 2,
"Channel Parity Error or the Loopback command failed." },
645 { 5,
"Illegal Opcode or command not allowed on Unit 15" },
646 { 6,
"illegal Volume or Unit number was specified for this device." },
647 { 7,
"Address Bounds exceeded for this device." },
648 { 8,
"Parameter Bounds error (other than unit, volume, or target address)"},
649 { 9,
"Parameter field wrong length for the opcode preceding it." },
650 { 10,
"Unexpected Secondary. Except for active reject,fault or access errors" },
651 { 12,
"Message Length error" },
652 { 17,
"Unit 15 Cross-unit error" },
653 { 19,
"Controller hardware Fault" },
654 { 22,
"Unit hardware Fault" },
655 { 24,
"Diagnostic failed selftest" },
656 { 30,
"Power Fail, or a new Tape or Flexible disc was loaded." },
657 { 31,
"Re-try preceding transaction" },
658 { 33,
"Uninitialized media" },
659 { 34,
"No Spares Available" },
660 { 35,
"Not Ready, medium has not loaded?" },
661 { 36,
"Write attempt while write protected" },
662 { 37,
"Tapes: read block accessed but not yet written. Disks: Validate key mismatch" },
663 { 40,
"Unrecoverable Data" },
664 { 41,
"Unrecoverable Data P1-P6 will contain the address of first bad block" },
665 { 43,
"End of File End encountered on file structured device." },
666 { 44,
"End of Volume attempted to access past end" },
667 { 51,
"Flexible disc or tape medium is wearing out" },
668 { 52,
"Latency induced bit because of retries" },
669 { 55,
"Device has automatically spared a block." },
670 { 57,
"Too many recoverable data error status messages queued since last request" },
671 { 59,
"Recoverable Data latency was introduced because of retries" },
688 mask = (0x80 >> bit);
689 return((p[
byte] & mask) ? 1 : 0);
705 mask = (0x80 >> bit);
861 printf(
"[SS80 Send Status]\n");
913 printf(
"[SS80 Send Status FAILED]\n");
938 printf(
"[SS80 Describe]\n");
947 printf(
"[SS80 Describe Controller FAILED]\n");
957 printf(
"[SS80 Describe Unit FAILED]\n");
966 printf(
"[SS80 Describe Volume FAILED]\n");
979 if(unit != 0 && unit != 15)
983 printf(
"[SS80 UNIT:%d invalid]\n", (
int) unit);
1001 printf(
"[SS80 Volume:%d invalid]\n", (
int) volume);
1062 printf(
"[SS80 Command State GPIB Read ERROR]\n");
1072 printf(
"[GPIB buffer OVERFLOW!]\n");
1082 if(ch >= 0x20 && ch <= 0x2f)
1096 if(ch >= 0x40 && ch <= 0x4f)
1113 printf(
"[SS80 Locate and Read]\n");
1125 printf(
"[SS80 Locate and Write]\n");
1154 printf(
"[SS80 Set Address:(%08lXH)]\n",
1180 printf(
"[SS80 NO-OP]\n");
1191 printf(
"[SS80 Set RPS NO-OP]\n");
1203 printf(
"[SS80 Set Release NO-OP]\n");
1221 printf(
"[SS80 Set Return Addressing - TODO]\n");
1237 printf(
"[SS80 Locate and Verify - TODO]\n");
1246 printf(
"[SS80 Release NO-OP]\n");
1256 printf(
"[SS80 Release Denied NO-OP]\n");
1277 printf(
"[SS80 Validate Key - TODO]\n");
1287 printf(
"[SS80 Describe]\n");
1306 printf(
"[SS80 Initialize Media TODO]\n");
1324 printf(
"[SS80 Set Status Mask - TODO]\n");
1337 printf(
"[SS80 Door UnLock - TODO]\n");
1347 printf(
"[SS80 Door Lock - TODO]\n");
1357 printf(
"[SS80 Request Status]\n");
1375 printf(
"[SS80 Initiate Diagnostic - TODO]\n");
1381 printf(
"[SS80 Invalid OP Code (%02XH)]\n", ch & 0xff);
1389 printf(
"[SS80 Execute Command, Error at (%d) of (%d) OP Codes]\n",
1463 printf(
"[GPIB Read ERROR]\n");
1473 printf(
"[GPIB buffer OVERFLOW!]\n");
1482 if(ch >= 0x20 && ch <= 0x2f)
1496 printf(
"[SS80 HP-IB Parity Checking - TODO]\n");
1513 printf(
"[SS80 Read Loopback - TODO]\n");
1529 printf(
"[SS80 Write Loopback - TODO]\n");
1568 printf(
"[SS80 Invalid OP Code (%02XH)]\n", ch & 0xff);
1575 printf(
"[SS80 Transparent Command, Error at (%d) of (%d) OP Codes]\n",
1604 printf(
"[SS80 Seek OVERFLOW at %08lXH]\n",
1652 printf(
"[SS80 qstat send FAILED]\n");
1837 if(
gpib_read_str(parity,
sizeof(parity), &status) !=
sizeof(parity))
1840 printf(
"[GPIB Read Error]\n");
1847 printf(
"[Amigo Clear]\n");
1885 printf(
"[SS80 Increment to (%lXH)]\n",
1910 printf(
"[GPIB Error Return - Write ERROR]\n");
1939 printf(
"[SS80 Command State]\n");
1951 printf(
"[SS00 Execute State]\n");
1964 printf(
"[SS80 Report State]\n");
1973 printf(
"[Amigo Clear]\n");
1986 printf(
"[SS80 Transparent]\n");
1992 printf(
"[SS80 SC Unknown: %02XH, listen:%02XH, talk:%02XH]\n",
1998 printf(
"[SS80 Unknown SC: %02XH, listen:%02XH, talk:%02XH]\n",
#define GPIB_RW_STR_TIMING
void SS80_Test(void)
SS80 GPIB function.
MEMSPACE int printf(const char *format,...)
int TD[]
SS80 GPIB test string.
int dbf_open_write(char *name, uint32_t pos, void *buff, int size, int *errors)
Open, Seek, Write data and Close FatFs functions.
void gpib_timer_elapsed_begin(void)
Start measuring time - used with hpib_timer_elapsed_end()
int debuglevel
Debug flag - used to log GPIB and emulator messages.
int SS80_Channel_Independent_Clear(int u)
Channel Independent Clear.
int SS80_test_extended_status(uint8_t *p, int bit)
SS80 test extendend status bits and display them.
Fault bit and Message type.
void gpib_disable_PPR(int bit)
Disable PPR (Parallel Poll Response) for a device.
uint32_t SS80_Bytes_to_Blocks(uint32_t bytes)
SS80 Return current block addresss from bytes.
uint8_t * SS80UnitPack(int *size)
Pack Unit data into bytes.
void Clear_Common(int u)
Universal and Decvice clear code.
void V2B_MSB_Index1(uint8_t *B, int index, int size, uint32_t val)
Initialize SS80 state and bus.
SS80 disk emulator for HP85 disk emulator project for AVR.
#define GPIB_IO_RD(a)
changes pin mode to read, then read
AMIGO disk emulator for HP85 disk emulator project for AVR.
void SS80_Check_Unit(uint8_t unit)
Check unit number and assign.
uint8_t MAXIMUM_INTERLEAVE
#define MAX_DEVICES
Maximum number of emulated devices.
fault_t faults[]
fault messages TODO move these to __memx
int SS80_Report(void)
send QSTAT
int SS80_Amigo_Clear(void)
Amigo Clear.
DeviceType Devices[MAX_DEVICES]
void SS80_display_extended_status(uint8_t *p, char *message)
SS80 Display extended 8 byte status messages for debuging.
int SS80_describe(void)
Send Controler,Unit and Volume description.
int SS80_locate_and_read(void)
SS80 Locate and Read COmmend.
int dbf_open_read(char *name, uint32_t pos, void *buff, int size, int *errors)
Open, Seek, Read data and Close FatFs functions.
MEMSPACE int mmc_wp_status()
MMC Card Write Protect status.
GPIB, AMIGO, SS80 and device defines.
int8_t set_active_device(int8_t index)
Set the Active disk or device pointers Since we can be called multiple times per single GPIB state we...
uint32_t SS80_Blocks_to_Bytes(uint32_t block)
SS80 Return current address in bytes.
uint16_t OPTIMAL_RETRY_TIME
SS80ControllerType CONTROLLER
int SS80_send_status(void)
SS80 send detailed status.
int SS80_Execute_State(void)
SS80 Execute state process.
int SS80_Cancel()
Cancel transaction.
uint8_t gpib_iobuff[GPIB_IOBUFF_LEN]
common IO buffer for gpib_read_str() and gpib_write_str()
High level GPIB command handler for HP85 disk emulator project for AVR.
uint8_t REMOVABLE_VOLUMES
void SS80_init(void)
SS80 nitialize all devices Initialize ALL SS80 devives.
void SS80_set_extended_status(uint8_t *p, int bit)
SS80 set extendend status bits.
#define GPIB_DEVICE_STATE_MESSAGES
int SS80_increment(void)
Increment position Addressy by one block.
uint32_t MAX_BLOCK_NUMBER
int SS80_cmd_seek(void)
Limit tests for disk seek.
int SS80_is_MTA(int address)
Check if SS80 talking address.
int SS80_error_return(void)
Common SS80 Error Return function. Send qstat = 1.
MEMSPACE void sep()
print seperator
#define EOI_FLAG
bus flags
uint8_t * SS80ControllerPack(int *size)
Pack Controller data into bytes.
uint8_t listening
gpib listen address
#define GPIB_DISK_IO_TIMING
int SS80_Selected_Device_Clear(int u)
Selected Device Clear.
int gpib_write_str(uint8_t *buf, int size, uint16_t *status)
Send string to GPIB BUS - controlled by status flags.
uint8_t spoll
gpib serial poll status
void gpib_enable_PPR(int bit)
void gpib_timer_elapsed_end(char *msg)
Display user message and time delta since gpib_timer_elapsed_begin() call.
uint32_t AddressBlocks
Address in Blocks.
int gpib_read_str(uint8_t *buf, int size, uint16_t *status)
Read string from GPIB BUS - controlled by status flags.
int SS80_Transparent_State(void)
(0x70 or 0x72) OP Code processing.
int SS80_is_MLA(int address)
Check if SS80 listening address.
uint8_t talking
GPIB BUS states.
int SS80_Universal_Device_Clear(void)
Universal Device CLear.
GPIB emulator for HP85 disk emulator project for AVR.
uint32_t B2V_MSB(uint8_t *B, int index, int size)
Convert a byte array into a value bytes are MSB ... LSB order.
void SS80_Check_Volume(uint8_t volume)
Check volume number and assign.
SS80DiskType * SS80p
Active SS80 Device.
int estate
Execute state index.
int SS80_locate_and_write(void)
SS80 Locate and Write Commend.
uint8_t * SS80VolumePack(int *size)
Pack Voulme data into bytes.
int SS80_COMMANDS(uint8_t ch)
SS80 COMMANDS States.
uint8_t qstat
Qstat variable.
GPIB emulator hardwware layer for HP85 disk emulator project for AVR.
void V2B_MSB(uint8_t *B, int index, int size, uint32_t val)
Convert Value into byte array bytes are MSB ... LSB order.
uint32_t Length
Length in Bytes.
int SS80_Command_State(void)
Process OP Codes following 0x65 Command State.
uint16_t CONTINUOUS_TRANSFER_RATE