HP85 GPIB Disk Emulator
1.0
HP85GPIBDiskEmulator
|
Go to the documentation of this file.
18 #include "user_config.h"
136 #ifdef SYSTEM_ELAPSED_TIMER
166 #ifdef SYSTEM_ELAPSED_TIMER
180 printf(
"[%s: %ld.%06ld]\n", msg, seconds,useconds);
193 #ifndef SYSTEM_ELAPSED_TIMER
287 printf(
"[GPIB BUS_INIT]\n");
393 printf(
"[GPIB STATE INIT]\n");
418 if(bit < 0 || bit > 7)
420 printf(
"gpib_enable_PPR: bit %d out of range\n", (
int) bit);
426 printf(
"[EPPR bit:%d, mask:%02XH]\n",0xff & bit , 0xff &
ppr_reg());
438 if(bit < 0 || bit > 7)
440 printf(
"gpib_disable_PPR: bit %d out of range\n", (
int) bit);
446 printf(
"[DPPR bit:%d, mask:%02XH]\n",0xff & bit, 0xff &
ppr_reg());
494 printf(
"[PPR:%02XH, PIN:%02XH, DDR:%02XH]\n",
495 0xff &
ppr_reg(), 0xff & pins, 0xff & ddr );
507 printf(
"gpib_detect_PP: ATN=0 EOI=0\n");
520 printf(
"gpib_detect_PP: IFC\n");
554 printf(
"gpib_unread: error, can only be called once!\n");
582 uint16_t control = 0;
603 uint16_t control = 0;
679 printf(
"gpib_write_byte: KEY state=%d\n", tx_state);
698 printf(
"gpib_write_byte: IFC state=%d\n", tx_state);
727 printf(
"gpib_write_byte: ATN = 0 while waiting for NRFD LOW state =%d\n",tx_state);
735 printf(
"<gpib_write_byte timeout waiting for NRFD==1 && NDAC == 0>\n");
768 printf(
"<gpib_write_byte timeout waiting for NRFD==1 && NDAC == 0>\n");
794 printf(
"<gpib_write_byte timeout waiting for NDAC==1>\n");
815 printf(
"<GPIB TX TIMEOUT>\n");
879 uint16_t bus, control, control_last;
927 printf(
"gpib_read_byte: state=%d\n", rx_state);
945 printf(
"gpib_read_byte: IFC state=%d\n", rx_state);
1050 if(control_last != control)
1053 control_last = control;
1087 fprintf(fo,
"==============================\n");
1088 fprintf(fo,
"GPIB bus state\n");
1089 fprintf(fo,
"HH . AESRPITB gpib\n");
1090 fprintf(fo,
"HH = Hex value of Command or Data\n");
1091 fprintf(fo,
" . = ASCII of XX only for 0x20 .. 0x7e\n");
1097 fprintf(fo,
" P = Parallel Poll seen\n");
1099 fprintf(fo,
" B = BUS_ERROR\n");
1100 fprintf(fo,
" GPIB commands\n");
1139 uint8_t bus = status & 0xff;
1147 uint8_t printable =
' ';
1148 if( !(status &
ATN_FLAG) && (bus >= 0x20 && bus <= 0x7e) )
1150 sprintf(str,
"%02X %c ", (
int)bus & 0xff, (
int)printable);
1228 if(cmd >= 0x020 && cmd <= 0x3e)
1229 sprintf(tmp,
" MLA %02Xh", cmd & 0x1f);
1230 else if(cmd >= 0x040 && cmd <= 0x4e)
1231 sprintf(tmp,
" MTA %02Xh", cmd & 0x1f);
1232 else if(cmd >= 0x060 && cmd <= 0x6f)
1233 sprintf(tmp,
" MSA %02Xh", cmd & 0x1f);
1317 printf(
"gpib_read_str: size = 0\n");
1336 printf(
"gpib_read_str(ind:%d): ATN %02XH unexpected\n",ind, 0xff & val);
1361 printf(
"[gpib_read_str read(%d) expected(%d)]\n", ind , size);
1406 printf(
"gpib_write_str: size = 0\n");
1420 printf(
"gpib_write_str: ATN = 1 at start\n");
1433 printf(
"<gpib_write_str timeout waiting for ATN = 1>\n");
1450 printf(
"<BUS waiting for DAV==1>\n");
1459 ch = buf[ind++] & 0xff;
1461 if( (*status &
EOI_FLAG) && (ind == size ) )
1487 printf(
"[gpib_write_str sent(%d) expected(%d)]\n", ind,size);
uint16_t gpib_handshake_pin_read()
Read GPIB handshake lines only FIXME: V2 boards can only read pins enabled for read by the SN75162 FI...
void gpib_timer_task()
Main GPIB timer task called by low level interrup hander.
#define GPIB_RW_STR_BUS_DECODE
#define GPIB_PPR_DDR_RD()
read full port direction register state Optional - see gpib_detect_PPR
int uart_keyhit(uint8_t uart)
Do we have receive characters waiting ?.
#define sprintf(s, format, args...)
volatile uint8_t down_counter_done
#define GPIB_PPR_RD()
We attempt to detect PPR states for logging only PPR is handled in hardware - but useful if we can de...
MEMSPACE int printf(const char *format,...)
@ GPIB_TX_WAIT_FOR_NDAC_HI
void listen_cleanup()
Called when the listen address changes.
void gpib_timer_elapsed_begin(void)
Start measuring time - used with hpib_timer_elapsed_end()
uint16_t gpib_control_pin_read()
Read GPIB control lines only FIXME V2 boards can only read pins enabled for read by the SN75162 FIXME...
int debuglevel
Debug flag - used to log GPIB and emulator messages.
#define DAV_FLAG
handshake flasg used in tracing
uint8_t listening
gpib listen address
void gpib_disable_PPR(int bit)
Disable PPR (Parallel Poll Response) for a device.
@ GPIB_TX_WAIT_FOR_NRFD_OR_NDAC_LOW
GPIB command mapping to printable strings.
void ppr_bit_set(uint8_t bit)
Enable hardware PPR response for a given device.
MEMSPACE WEAK_ATR char * strcat(char *dest, const char *src)
Append string.
void gpib_decode_header(FILE *fo)
Displays help for gpib_decode() function.
#define GPIB_PIN_FLOAT_UP(a)
changes pin mode to read
#define GPIB_BUS_WR(val)
changes to state of full 8bit port to out then write
SS80 disk emulator for HP85 disk emulator project for AVR.
MEMSPACE int fprintf(FILE *fp, const char *format,...)
fprintf function Example user defined printf function using fputc for I/O This method allows I/O to d...
AMIGO disk emulator for HP85 disk emulator project for AVR.
#define GPIB_IO_HI(a)
changes pin mode to write then set hi
#define GPIB_BUS_OR_CMD_BYTE_MESSAGES
@ GPIB_TX_WAIT_FOR_NRFD_HI
void ppr_init()
Reset PPR enable register - all disable..
gpib_token_t gpib_tokens[]
#define PP_FLAG
BUS state flags.
GPIB, AMIGO, SS80 and device defines.
#define HTIMEOUT
This is the default BUS timeout of 0.5 Seconds in Microseconds.
#define GPIB_BUS_LATCH_WR(val)
writes GPIB port latch without changing to write direction
uint16_t gpib_write_byte(uint16_t ch)
Send 1 byte and control line states to GPIB BUS.
#define GPIB_BUS_IN()
changes to state of full 8bit port to in
MEMSPACE void clock_elapsed_begin()
Store current struct timespec in __clock_elapsed.
uint8_t talking_last
gpib last talk address
uint8_t gpib_iobuff[GPIB_IOBUFF_LEN]
common IO buffer for gpib_read_str() and gpib_write_str()
@ GPIB_RX_WAIT_FOR_DAV_LOW
MEMSPACE size_t WEAK_ATR strlen(const char *str)
String Length.
@ GPIB_RX_WAIT_FOR_DAV_HI
High level GPIB command handler for HP85 disk emulator project for AVR.
volatile uint32_t elapsed
void talk_cleanup()
Called when the GPIB talk address changes.
#define GPIB_DEVICE_STATE_MESSAGES
void gpib_decode(uint16_t ch)
Calls gpib_decode_str() and dosplays the result.
void gpib_timeout_set(uint32_t time)
Set GPIB timeout timer in units of GPIB_TASK_TIC_US.
void gpib_rx_init(uint8_t busy)
Initialize GPIB Bus control lines for READ.
uint8_t gpib_bus_read()
Read GPIB data BUS only.
uint8_t listening_last
gpib last listen address
uint16_t lastcmd
gpib current and last command
#define EOI_FLAG
bus flags
#define GPIB_BUS_SETTLE()
MEMSPACE time_t time(time_t *t)
Return second from epoch - POSIX function.
int gpib_write_str(uint8_t *buf, int size, uint16_t *status)
Send string to GPIB BUS - controlled by status flags.
FILE * gpib_log_fp
GPIB log file handel.
uint16_t gpib_read_byte(int trace)
read 1 byte and control line status from GPIB BUS
uint8_t secondary
gpib secondary
void gpib_tx_init()
Initialize GPIB Bus control lines for WRITE.
#define GPIB_PP_BUS_STATUS
void gpib_enable_PPR(int bit)
#define GPIB_BUS_RD()
changes to state of full 8bit port to in then read
#define GPIB_PIN_TST(a)
checks the pin state without changing read/write mode
void gpib_timer_elapsed_end(char *msg)
Display user message and time delta since gpib_timer_elapsed_begin() call.
uint8_t gpib_unread_f
gpib_unread() flag
int gpib_read_str(uint8_t *buf, int size, uint16_t *status)
Read string from GPIB BUS - controlled by status flags.
uint8_t talking
gpib talk address
void ppr_bit_clr(uint8_t bit)
Disbale hardware PPR response for a given device.
GPIB emulator for HP85 disk emulator project for AVR.
uint8_t gpib_detect_PP()
Attempt to detect the Parallel Poll Reposnse state Used only for debugging - it is unlikely that we w...
void gpib_user_task()
user task called in GPIB read/write byte functions
uint16_t gpib_unread(uint16_t ch)
GPIB ungets one character and all status states.
uint8_t gpib_timeout_test()
Test GPIB timeout timer for timeout condition.
GPIB emulator hardwware layer for HP85 disk emulator project for AVR.
void gpib_bus_init()
Initialize/Release GPIB Bus control lines Used for Power ON, Reset or IFC LOW reset conditions.
void gpib_trace_display(uint16_t status, int trace_state)
decode/display all control flags and data on the GPIB BUS
volatile uint32_t down_counter
uint8_t ppr_reg()
Return PPR enable register.
MEMSPACE void clock_elapsed_end(char *msg)
Subtract and display time difference from clock_elapesed_begin().
MEMSPACE int puts(const char *str)
put a string to stdout See fdevopen() sets stream->put get for TTY devices
#define GPIB_IO_LOW(a)
changes pin mode to write then set low
uint8_t spoll
gpib serial poll status
void gpib_timer_reset(void)
Reset elapsed and timeout timers Elapses and Timeout Timers.
uint16_t gpib_unread_data
gpib_unread() data
void gpib_state_init(void)
Reset GPIB states and related variables.
#define GPIB_BUS_OUT()
changes to state of full 8bit port to out