## **GPIB** General Purpose Interface Board > Instruction Manual # Cromemco® GPIB General Purpose Interface Board Instruction Manual CROMEMCO, Inc. 280 Bernardo Avenue Mountain View, CA. 94043 Part No. 023-2007 **April** 1983 Copyright © 1982, 1983 CROMEMCO, Inc. All Rights Reserved This manual was produced using a Cromemco System Three computer with a Cromemco HDD-22 Hard Disk Storage System running under the Cromemco Cromix<sup>®</sup> Operating System. The text was edited with the Cromemco Cromix Screen Editor. The edited text was proofread by the Cromemco SpellMaster™ Program and formatted by the Cromemco Word Processing System Formatter II. Camera-ready copy was printed on a Cromemco 3355B printer. Copyright © 1982, 198 CROMEWCO, Inc. All Rights Reserved #### TABLE OF CONTENTS | TECHNICAL SPECIFICATIONS | ef-r sambly | |-----------------------------------------------------------------|--------------------------| | ABOUT THIS MANUAL | :1-2 aug21<br>:2-2 aug21 | | Chapter 1: INTRODUCTION | 1-0. eldar<br>1-0. eldar | | Chapter 2. Degree and and | Table 3-2: | | Chapter 2: RESET STATE, MEMORY AND HOST I/O | 9 | | 2.1 GPIBB Reset State 2.2 GPIBB Memory 2.3 Host Input/Output | 9<br>10<br>12 | | Chapter 3: GPIBB INPUT/OUTPUT | | | | 21 | | 3.1 Non-LSI Mapped Ports<br>3.2 TMS 9914 GPIB Adapter Registers | 22<br>31 | | Chapter 4: GPIBB INTERRUPT STRUCTURE | 55 | | 4.1 GPIBB to Host Interrupts 4.2 GPIBB Z-80A Interrupts | 55<br>58 | | Appendix A: GPIBB PARTS LIST | 61 | | Appendix B: GPIBB PARTS LOCATION DIAGRAM | 65 | | Appendix C: GPIB MONITOR COMMANDS | 67 | | Appendix D: SAMPLE GPIB PROGRAMS | 75 | | Appendix E: LIMITED WARRANTY | | | GPIBB SCHEMATIC DIAGRAM | | #### LIST OF FIGURES AND TABLES | Figure | 1-1: | GPIBB Block Diagram | 6 | |------------------------------------|--------------|--------------------------------------|----------------------| | Figure<br>Figure | | GPIBB Memory Map<br>GBASE Switch SW2 | 11 | | Table<br>Figure<br>Figure<br>Table | 3-1:<br>3-2: | | 21<br>31<br>40<br>42 | | Figure | 4-1: | S-100 Interrupt Daisy Chain Wiring | 57 | Appendix As CPIEB PARTS HET | TECHNICAL SPECIFICATIONS | | | |--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Applications: | Intelligent IEEE 488 bus to Host S-100 bus interface, or intelligent IEEE 488 stand alone Controller | | | IEEE-488 Functions: | C Controller with Pass Control capability; T, TE, L, LE Talker and/or Listener; SH, AH automatic Source and Acceptor Handshake; DC, DT Device Clear and Device Trigger; SR Service Request; PP Parallel Poll; RL Remote/Local with Remote Lockout | | | Processor: | Z-80A clocked at 4.000 MHz | | | ROM Memory: | Socket space for 4 Kbytes of TI 2516,<br>Intel 2716, or their generic equivalents<br>(user supplied) | | | RAM Memory: | 4 Kbytes of 9124 (lK x 4) static RAM (included) | | | S-100 Bus Interface: | Four 8-bit parallel I/O ports; the GPIE board may issue non-maskable and/or vectored maskable interrupt requests to the Host; the Host may issue maskable interrupt requests to the GPIB board | | | GPIB Bus Interface: | The 24 IEEE 488 bus lines interface to GPIB board connector J2 | | | Utility Interface: | One 8-bit parallel input port, and one 8-bit parallel output port provide a general purpose interface at GPIB board connector J1 | | | LSI Device Types: | Z-80A CPU, TMS 9914 GPIB Adapter | | | Power Requirements: | +8 VDC @ 1.5 Amps (max) | | | Operating Environment: | 0 - 55 degrees Celsius | | | SOL-W seek of had be the sold be and the sold sold sold be sold by the sold be sold by the sold be sold by the sold by the sold be sold by the | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | | | | | . Size IT To perget a toller created and size of the s | | | | | | | | | | | | | | | | | | (xee up. f. f a new us. ) | | | | | | | | #### ABOUT THIS MANUAL This manual provides operating instructions for Cromemco's intelligent GPIB Interface board. Two LSI devices supply most of the interface's capabilities: a Z-80A central processing unit, and a TMS 9914 GPIB Adapter. It's assumed that the reader has technical documentation for these parts (see Mostek publication MK 3880 Central Processing Unit, 1977, and Texas Instruments publication TMS 9914 GPIB Adapter Preliminary Data Manual, 1979), and also that the reader is familiar with Z-80 Assembly Language and the IEEE Std 488-1978. The manual chapters discuss all board functions except internal functions of these two LSI devices. Included are topics such as the board's Reset State, onboard ROM and RAM memory, the I/O mapping of LSI internal registers, and the board's interrupt structure. After reading this manual and the reference documentation, the GPIB Interface user should be able to: - Design and write GPIB interface and host Z-80 software. - Configure the GPIB board. This means: - a. Select the board's GPIB Talk and Listen address with switch SWl; - b. Select the board's S-100 base I/O address with switch SW2; - c. Optionally connect the board to Cromemco's S-100 interrupt priority daisy chain using connector J3; - d. Install the 2516 firmware from step 1 in board sockets ROMO and ROM1; - e. Interface the board to the IEEE 488 instrumentation bus using connector J2. - Test and debug the host software and GPIB resident firmware. Cromemco GPIB Instruction Manual Two conventions will be used consistently throughout the remainder of this manual. First, positive logic is assumed. Reset means logic 0, and set means logic 1 when these terms apply to bit states. Secondly, the acronym GPIBB will denote the GPIB Board itself, and its functions, as opposed to GPIB interface bus functions. ocumentation for these users or notes publication MR 880 Central Processing 11, 1977, and Texas not runents publications 12, 1977, and Texas not runents publications 12, 1914 4918 Adapter reliminary Late Manual, 4914 4914 4915 the reader a lamitar with X-84 Assists rungangs and the ISBE 8td The manual chapters discon as sound functions except internal functions of the 4-arc told devices. Included are topics such as the 5 4 cet State, onboard ROM and RAM memory, the cost of the inardiance of the cost co Atter reading this passed and the reference documentation, the GPIS sale user should be able to: Sorthetes. address with switch Switz . Select the dozes's 5-100 ongs 1/O address with switch smile Optionally, connect the based to Cromemoo's S-109 intended of pro-right datay chain using connector is d. Install the 2214 Criminal Long step 1 in board societs ROMP and White - Interface the Court to the IEEE 48E instrumentation but waing connector 32. Test and debug the host software and CPIB resident Cromemco GPIB Instruction Manual 1. Introduction #### Chapter 1 #### INTRODUCTION The Cromemco General Purpose Interface Bus (GPIB) Board is an intelligent interface between a host system S-100 bus and an IEEE 488 instrumentation bus (see Figure 1-1). Two TI 2516 EPROM sockets (4 Kbytes) supply the GPIBB program store, and 4 Kbytes of RAM memory are supplied for data buffering, scratchpad memory and the Z-80A stack. The firmware program store controls a dedicated Z-80A microprocessor, clocked at 4 MHz, to manage all interface functions. GPIBB connector J2 provides the standard GPIB (IEEE Std 488-1978) interface, and connector J1 supplies a general purpose TTL parallel I/O port (this port is termed the External I/O port throughout the manual). All GPIB interface functions are managed by the Texas Instruments TMS 9914 GPIB Adapter. Figure 1-1: GPIBB BLOCK DIAGRAM The Host communicates with the GPIBB through two S-100 bus parallel I/O ports. DIP switch SW2 locates the GPIBB in the S-100 bus I/O map, while DIP switch SW1 defines the interface's GPIB bus Talk and Listen address. The GPIBB may issue either non-maskable or maskable vectored interrupt requests to the host processer over the S-100 bus, and the interrupt requests may be coordinated among other requests using Cromemco interrupt priority daisy chain connector J3 on the board. When enabled under software control, three sources may issue maskable interrupt requests to the GPIBB Z-80A: - The host processor through bit Int GPIBB of S-100 register Host Control, - 2. An External Input port load strobe, or - 3. TMS 9914 GPIB Adapter pin INT . The GPIBB onboard interrupt priorities are software defined. See Chapter 4 for more information on interrupts. The GPIBB satisfies all requirements of IEEE Std 488-1978, with the exception of the specified maximum (IEEE Std 488-1978 describes a rather data rate. complex interface bus with a large set of uniquely defined signals and states, each with an different Refer to IEEE Standard Digital Interface for acronym. Programmable Instrumentation, 1978, published by The Institute of Electrical and Electronic Engineers, Inc., for a comprehensive description of the standard.) GPIBB can take the part of the System Controller, a Controller In Charge, a Talker, or a Listener. Although designed to be a dedicated peripheral to an S-100 host system, the GPIBB can also operate as a stand alone Controller, needing only power (+8 volts unregulated) and appropriate EPROM firmware. #### Cromemco GPIB Instruction Manual #### Chapter 2 #### RESET STATE, MEMORY AND HOST I/O #### 2.1 GPIBB RESET STATE The GPIBB is reset by any of the following three events: - 1. +8 VDC (unregulated) is applied to the GPIBB. In response, GPIBB circuitry generates a momentary active low level Power On Clear (POC) pulse to reset itself. - An active low level appears on S-100 bus line RESET, pin 75. - A logic 1 followed by a logic 0 is output to bit Reset of S-100 register Host Control. Any one of these three events forces the GPIBB to the following state: - 1. The GPIBB Z-80A is reset, which means: - a. Its program counter is reset to 0000h; - b. Its maskable interrupt request pin is masked (disabled); - c. Its I and R registers are reset to 00h; - d. Interrupt mode IMO is selected. - 2. The GPIB Adapter is reset, which means: - a. All idle states are entered; - b. All Serial Poll Register and Parallel Poll Register bits are reset; - c. All Auxiliary Commands are cleared except Reset, which is set, and thus must be cleared during initialization. - All eight External Output port bits are reset. - 4. Host Status bits RDA and Int Pending are reset; bit TBE is set. - 5. Host Control bits Reset, Int GPIBB, Clr Int and Int Msk are reset. - 6. GPIBB Status bits RDA, Ext Int, GPIB Int and Host Int are reset; bit TBE is set. - 7. GPIBB Control bits NMInt Host Int Msk, GPIB Msk and Host Msk are reset. - 8. The Host Data and GPIBB Data port contents should be considered random until written to for the first time. ### 2.2 GPIBB MEMORY The GPIBB is shipped with 4 Kbytes of RAM memory spanning F000h - FFFFh in the GPIBB Z-80A memory map. This memory would typically be used for data buffering, scratchpad memory, and the Z-80A stack. The board also has socket space for two TI 2516 (or equivalent) EPROM memory devices, which supply the Z-80A program store. Socket ICl0 (ROM0) spans addresses 0000h - 07FFh (2 Kbytes), and socket IC27 (ROM1) spans 0800h - 0FFFh (2 Kbytes) -- see Figure 2-1. Note the board legend arrows which point to pin 1 of each socket. A GPIBB reset causes the Z-80A to automatically begin program execution at 0000h, so the firmware located in socket ROM0 would typically begin with a GPIBB initialization routine. GPIBB hardware automatically inserts one 250 nSec Wait State during each Z-80A M1 (opcode fetch) cycle, but not during any other cycle type. Figure 2-1: GPIBB MEMORY MAP #### 2.3 HOST INPUT/OUTPUT The host processor communicates with the GPIBB through two S-100 bus bidirectional I/O ports: - 1. The host inputs GPIBB status from port Host Status - The host inputs GPIBB data from port Host Input Data - The host outputs GPIBB control bits to port Host Control, and - 4. The host outputs GPIBB data to port Host Output Data. The two host I/O ports are located in the S-100 I/O map with GPIBB switch SW2 which defines the GPIBB I/O Base Address, or Gbase. GPIBB hardware assumes that bit A0 equals logic 0 (this means that only even valued Gbase addresses are permitted). The example switch setting in Figure 2-2 defines Gbase = 5Eh. Figure 2-2: GBASE SWITCH SW2 The two host S-100 ports are mapped with offsets of +00h and +01h relative to Gbase. The correspondence is shown below: | REGIST | ER | | PORT | |------------------------------------------|----|-----------------------|-----------------------------------------------| | Host St<br>Host Co<br>Host In<br>Host Ou | | to Host)<br>to GPIBB) | IN Gbase+0 OUT Gbase+0 IN Gbase+0 OUT Gbase+0 | For example, given the switch setting shown in Figure 2-2, the host would write to port **Host Output Data** by outputting a byte to port 5Fh, and it would poll register **Host Status** by inputting a byte from port 5Eh. The remainder of this section describes the host I/O ports in detail. THE -- Transmit Burten Laptys #### HOST STATUS IN Gbase+00h | D7<br>TBE* | TRANSMIT BUFFER TO GPIBB EMPTY | | |---------------------|------------------------------------|--| | D6<br>RDA** | FROM GPIBB AVAILABLE | | | D5 | NOT USED | | | D4 | NOT USED | | | D3 | NOT USED | | | D2 | NOT USED | | | D1 | NOT USED | | | DO<br>INT<br>PEND** | GPIBB INTERRUPT<br>REQUEST PENDING | | | FEND | *SET BY A 0<br>**RESET BY A 0 | | D7 TBE -- Transmit Buffer Empty. Logic 0 => Host Output Data is full and cannot be loaded without losing the previous output byte. Logic 1 => Host Output Data is empty, so the host may write another byte to the GPIBB. D6 RDA -- Receive Data Available. Logic 0 => no data from the GPIBB is available for reading. Logic 1 => a data byte from the GPIBB is available in the **Host Input Data** register transpose for reading. D5-D1 Not used. DO Int Pend -- GPIBB Interrupt Request Pending. Logic 0 => there is no pending GPIBB interrupt request. Logic 1 => the GPIBB has issued an interrupt request to the host by setting GPIBB Control bit Int Host. Bit Int Pend is initially reset following a GPIBB reset. In normal use, the GPIBB sets GPIBB Control bit Int Host to issue a maskable interrupt request to the host processor. The host processor may either mask (disable) or unmask (enable) the interrupt request with Host Control bit Int Mask. However, the host may poll bit Int Pend to sense a pending interrupt regardless of whether the request is masked or unmasked. After the host polls bit Int Mask set (indicating a pending GPIBB interrupt request), the host resets Int Mask by outputting first logic 1, followed by logic 0, to Host Control bit Clr Int. Note that bit Int Pend is unconditionally held reset while Host Control bit Clr Int is set. #### HOST CONTROL OUT Gbase+00h | D7 | RESET GPIBB | |---------------------|-------------------------------------| | RESET* | increase aged only 240 | | D6 | NOT USED | | lea agrae Lawrence | OPINE Teset. Helican | | D5 | NOT USED | | | | | <b>D4</b> | NOT USED | | | | | D3 . | NOT USED | | D2 | INTERPLIET DEQUEST | | D2<br>INT<br>GPIBB* | INTERRUPT REQUEST<br>TO GPIBB Z-80A | | D1 | | | CLR | CLEAR INTERRUPT REQUEST FROM GPIBB | | INT* | | | D0<br>INT<br>MASK* | GPIBB INTERRUPT REQUEST MASK | D7 Reset -- Reset GPIBB. Logic 0 => no action. Logic 1 => holds GPIBB in reset state. Note that this bit must be reset (inactive) after being set (active). Otherwise, the GPIBB is held in the reset state. D6-D3 Not used. D2 Int GPIBB -- Interrupt Request to GPIBB. Logic 0 => no operation. Logic $l \Rightarrow$ issues an interrupt request to the GPIBB Z-80A. The interrupt request from a set Int GPIBB bit is automatically removed during interrupt acknowledge from the GPIBB Z-80A. Note that any such interrupt request issued by the host may be either masked or unmasked by GPIBB Control bit Host Mask. D1 Clr Int -- Clear Interrupt Request from GPIBB. Logic 0 => no action. Logic 1 => clears any pending interrupt request which the GPIBB has issued by setting GPIBB Control bit Int Host, and inhibits any subsequent requests while bit Clr Int remains set. This bit is initially reset following a GPIBB reset. In normal use, the host interrupt service routine first sets bit Clr Int, and then resets it, to remove a GPIBB interrupt request, and to reset Host Status bit Int Pend. DO Int Mask -- GPIBB Interrupt Request Mask. Logic 0 => masks (disables) GPIBB interrupt requests. Logic 1 => unmasks (enables) GPIBB interrupt requests. The GPIBB cannot drive S-100 bus line INT active low while bit Int Mask is reset. If bit Int Mask is set, then the GPIBB can drive S-100 bus line INT active low, provided Host Control bit Clr Int is reset. S-100 bus line INT goes active low as soon as bit Int Mask is set if a GPIBB interrupt request is pending (GPIBB Control bit Host Int is set). That is, bit Int Mask can hold off GPIBB interrupt requests, but it cannot clear them. HOST INPUT DATA IN Gbase+01h This register buffers the data bytes the GPIBB writes to the host. Host Status bit RDA is set by outputting a byte to its GPIBB Output Data register as the GPIBB loads this register. RDA is reset as the host reads this register. HOST OUTPUT DATA OUT Gbase+01h This register buffers the data bytes the host writes to the GPIBB. Host Status bit TBE is reset as the host writes to this register and TBE is set by inputting a byte from its GPIBB Input Data register as the GPIBB reads this register. Cromemco GPIB Instruction Manual This register buffers the deta byles the best writes to the delens out the lost writes to this register and FOR is set by inputing a byte from its delan inputing a byte from its delan input the delan contains and the delan contains and the delan contains. #### Chapter 3 #### GPIBB INPUT/OUTPUT Most internal GPIBB functions are mapped into I/O ports for GPIBB Z-80A access. These functions fall into three general categories. - 1. Host communication - Interrupt initialization and response - 3. TMS 9914 GPIB Adapter communication Table 3-1 summarizes the GPIBB internal I/O port assignments. | GPIBB REGISTER | PORT | |-----------------------------------|---------| | GPIBB Status | IN 00h | | GPIBB Control | OUT 00h | | GPIBB Input Data (Host to GPIBB) | IN Olh | | GPIBB Output Data (GPIBB to Host) | OUT 01h | | External Input | IN 02h | | External Output | OUT 02h | | GPIB Bus Address | IN 03h | | GPIB Int Status 0 | IN 40h | | GPIB Int Mask 0 | OUT 40h | | GPIB Int Status 1 | IN 41h | | GPIB Int Mask 1 | OUT 41h | | GPIB Address Status | IN 42h | | GPIB Bus Status | IN 43h | | GPIB Auxiliary Commands | OUT 43h | | GPIB Address Register | OUT 44h | | GPIB Serial Poll | OUT 45h | | GPIB Command Pass Through | IN 46h | | GPIB Parallel Poll | OUT 46h | | GPIB Data Input | IN 47h | | GPIB Data Output | OUT 47h | Table 3-1: GPIBB INTERNAL I/O REGISTERS Section 3.1 of this chapter discusses I/O ports 00h - 03h. These ports do not access LSI device internal registers. Section 3.2 discusses TMS 9914 GPIB Adapter mapped I/O registers, ports 40h - 47h. #### 3.1 NON-LSI MAPPED PORTS GPIBB STATUS IN 00h | | D7<br>TBE* | TRANSMIT<br>BUFFER<br>EMPTY | Host communication | |-------|---------------------|---------------------------------------|------------------------------------------------| | | D6<br>RDA** | DATA | | | | D5 | | | | | D4 | | | | 800 t | D2<br>EXT<br>INT** | EXTERNAL INPUT<br>INTERRUPT STATUS | | | | D1<br>GPIB<br>INT** | 9914 GPIB ADAPTER<br>INTERRUPT STATUS | | | | D0<br>HOST<br>INT** | HOST INTERRUPT<br>STATUS | *SET BY A GPIBB RESET **RESET BY A GPIBB RESET | D7 TBE -- Transmit Buffer Empty. Logic 0 => GPIBB Output Data is full and cannot be loaded without losing the previous output byte. Logic 1 => GPIBB Output Data is empty, so the GPIBB may write another byte to the host. D6 RDA -- Receive Data Available. Logic 0 => no data from the host is available for reading. Logic 1 => a data byte from the host is available for reading in register GPIBB Input Data. D5-D3 Not used. D2 Ext Int -- External Input Interrupt Status. Logic 0 => no unmasked External Input interrupt request is pending. Logic 1 => GPIBB Control bit Input Mask is set and data has been strobed into the External Input port; this drives GPIBB Z-80A pin INT active low. Bit Ext Int is typically polled by the GPIBB interrupt service routine to determine the interrupt source. Bit Ext Int is automatically reset after register GPIBB Status is read. D1 GPIB Int -- TMS 9914 Interrupt Status. Logic 0 => no unmasked interrupt request from the TMS 9914 is pending. Logic 1 => GPIBB Control bit GPIB Mask is set and the TMS 9914 has issued a maskable interrupt request by driving GPIBB Z-80A pin INT active low. Bit GPIB Int is typically polled by the GPIBB interrupt service routine to determine the interrupt source. Bit GPIB Int is automatically reset after port GPIBB Status is read. DO Host Int -- Host Interrupt Status. Logic 0 => no unmasked interrupt request from the host is pending. Logic 1 => GPIBB Control bit Host Mask is set and the host has set Host Control bit Int GPIBB; this drives GPIBB Z-80A pin INT active low. Bit Host Int is typically polled by the GPIBB interrupt service routine to determine the interrupt source. Bit Host Int is automatically reset after port GPIBB Status is read. GPIBB CONTROL OUT 00h | | D7 | | |-----------|--------------------------------------------|-------------------------------------------------------------------| | | D6<br>NMINT<br>HOST*<br>D5<br>INT<br>HOST* | NONMASKABLE INTERRUPT TO HOST MASKABLE INTERRUPT REQUEST TO HOST | | | D3 | | | | D2<br>INPUT<br>MASK* | EXTERNAL INPUT INTERRUPT MASK | | | D1<br>GPIB<br>MASK*<br>D0<br>HOST | TMS 9914 INTERRUPT MASK HOST INTERRUPT MASK | | the CPIBB | MASK* | *RESET BY A GPIBB RE | D7 Not used. D6 NMInt Host -- Non-maskable Interrupt To Host. int sire sister source int spin int Logic 0 => no action. Logic 1 => drives S-100 bus line \(\overline{NMI}\) active low on the next falling edge of S-100 bus signal sM1. The active low level is automatically removed on the following sM1 falling edge. S-100 bus signal sM1 is high during the opcode fetch cycle of each instruction executed. D5 Int Host -- Interrupt Request To Host. Logic 0 => no action. Logic 1 => issues a maskable interrupt request to the host. The request drives S-100 bus line INT active low only if Host Control bit Int Mask is set AND Host Control bit Clr Int is reset. D4-D3 Not used. Dl D2 Input Mask -- External Input Interrupt Mask. Logic 0 => disables External Input port interrupts. Logic 1 => enables External Input port interrupts. When bit Input Mask is set, then strobing data into port External Input drives GPIBB Z-80A pin INT active low. The interrupt request is automatically removed during interrupt acknowledge. If data is strobed into the External Input port while bit Input Mask is reset, and Input Mask is subsequently set, then no interrupt request results. GPIB Mask -- TMS 9914 Interrupt Mask. Logic 0 => disables TMS 9914 interrupt requests to the GPIBB Z-80A. Logic $l \Rightarrow$ enables TMS 9914 interrupt requests to the GPIBB Z-80A. When bit GPIB Mask is set, an interrupt request from an active low level on TMS 9914 output pin INT drives GPIBB Z-80A input pin INT active low. The interrupt request is automatically removed during interrupt acknowledge. If TMS 9914 pin INT goes low while bit GPIB Mask is reset, and GPIB Mask is subsequently set, then no interrupt request results. DO Host Mask -- Host Interrupt Mask. Logic $0 \Rightarrow$ disables host interrupt requests to the GPIBB Z-80A. Logic $l \Rightarrow$ enables host interrupt requests to the GPIBB Z-80A. When bit Host Mask is set, then GPIBB Z-80A pin INT is driven active low when the host sets Host Control bit Int GPIBB. The interrupt request is automatically removed during interrupt acknowledge from the GPIBB Z-80A. If Host Control bit Int GPIBB is set while bit Host Mask is reset, and Host Mask is subsequently set, then no interrupt request results. GPIBB INPUT DATA IN 01h Spirit Towns Control This register buffers the data bytes the host writes to the GPIBB. GPIBB Status bit RDA is set by outputting a byte to its Host Output Data register as the host loads this register. RDA is reset as the GPIBB reads this register. GPIBB OUTPUT DATA OUT 01h This register buffers the data bytes the GPIBB writes to the host. GPIBB Status bit TBE is reset as the GPIBB writes to this register, and TBE is set by inputting a byte from its Host Input Data register as the host reads this register. EXTERNAL INPUT IN 02h Eight bits of parallel noninverted data are input from GPIBB connector Jl through this port. An external data source strobes a byte into this port by pulsing Jl pin 23, GATE DATA, momentarily high. The rising edge of this strobe may be armed to issue a GPIBB Z-80A interrupt request by setting GPIBB Control bit Input Mask. If GATE DATA is held high, then the GPIBB may sample the External Input data lines in real time. Jl pin 24, READ STROBE, pulses low as the GPIBB Z-80A inputs the port data. Jl pin 11, WAIT, may be driven low to make the GPIBB Z-80A idle in the Wait State while transferring the data. EXTERNAL OUTPUT OUT 02h The GPIBB outputs eight bits of parallel noninverted data to connector Jl through this port. An external data sink is informed that data has been written to this port by a low pulse on Jl pin 10, DATA VALID. Jl pin 11, WAIT, may be driven low to make the GPIBB Z-80A idle in the Wait State while transferring the data. All External Output bits are reset to logic 0 by a GPIBB reset. IEEE 488 BUS ADDRESS IN 03h This port allows the GPIBB firmware to read the IEEE 488 bus address defined by GPIBB switch SWl. This five bit value is read by the GPIBB Z-80A, and then loaded into port OUT 44h, GPIB Address Register, to define the board's primary address (see below). Figure 3-1 illustrates how SWl would be set to define IEEE 488 bus address ODh. 3. Sugiso Insut/Output Figure 3-1: IEEE 488 BUS ADDRESS SWITCH SW1 #### 3.2 TMS 9914 GPIB ADAPTER REGISTERS GPIBB ports 40h through 47h are mapped to access TMS 9914 internal registers. This section presents register descriptions condensed from Texas Instrument's TMS 9914 GPIB Adapter Preliminary Data Manual, 1979. #### GPIB INTERRUPT STATUS 0 IN 40h | D7<br>INT40 | PORT 40h<br>INTERRUPT | | |-------------|----------------------------------|--| | D6<br>INT41 | PORT 41h<br>INTERRUPT | | | D5<br>BI | TMS 9914 BYTE<br>HAS BEEN INPUT | | | D4<br>BO | TMS 9914 BYTE<br>HAS BEEN OUTPUT | | | D3<br>END | END | | | D2<br>SPAS | SERIAL POLL<br>ACTIVE STATE | | | D1<br>RCC | REMOTE/LOCAL<br>CHANGE | | | D0<br>MAC | MY<br>ADDRESS<br>CHANGE | | Status bits D5 - D0 are latched set as their corresponding source conditions occur, regardless of whether they are masked or unmasked by bits of register GPIB Interrupt Mask O. Status bit D7, INT40, is latched set whenever one or more unmasked (enabled) bits in the D5 - D0 group of register GPIB Interrupt Status O are set. Likewise, status bit D6, INT41, is latched set whenever one or more unmasked (enabled) bits of register GPIB Interrupt Status 1 are set. Status bits D7 and D5 - D0 are reset when register GPIB Interrupt Status O is read, while bit D6 is reset when port GPIB Interrupt Status 1 is read. TMS 9914 output pin INT is active low whenever (INT40) OR (INT41) is true. - D7 INT40 -- Port 40h Interrupt. One or more unmasked (enabled) interrupt sources of register 40h has become active. - D6 INT41 -- Port 4lh Interrupt. One or more unmasked (enabled) interrupt sources of register 4lh has become active. - D5 BI -- a TMS 9914 Byte has been Input. | D4 | s" | BO a TMS 9914 Byte has been Output, or the TMS 9914 is ready to accept the first data byte. | |----|----|---------------------------------------------------------------------------------------------| | D3 | | END an EOI has occurred with ATN false. | | D2 | | SPAS A Serial Poll Active State has occurred with rsv set in the Serial Poll Register. | | Dl | | RLC A Remote/Local State change has occurred. | | D0 | | MAC A My Address Change has occurred. | | | | | | | | | | | | | | | | | | | | | Bits of this registers are set (Asgio 1) to unmask (enable) the corresponding inverse; fource condition to drive TMS 9914 outset pin TWT series icw. Bits are reset (logic 0) so size (Breatte) the corresponding interrupt source. DT-D6 Not used. DS BI -- enable interrupt on Evte Input. D4 BO -- enable interrupt on Syte Input. D3 PMD -- enable interrupt on Syte Input. D3 PMD -- enable interrupt on Serial Poll Active State. D4 BAS -- enable interrupt on Serial Poll Active State. D5 BAS -- enable interrupt on Serial Poll Active State. # GPIB INTERRUPT MASK 0 OUT 40h | | | SPAS A Serial Foll<br>occurred with realest | |-----------|------------|-----------------------------------------------| | ed 'apmad | D6 | | | | D5<br>BI | TMS 9914 BYTE<br>INPUT MASK | | | D4<br>B0 | TMS 9914 BYTE<br>OUTPUT MASK | | | D3<br>END | END INTERRUPT<br>MASK | | | D2<br>SPAS | SERIAL POLL<br>ACTIVE STATE<br>INTERRUPT MASK | | | D1<br>RLC | REMOTE/LOCAL<br>CHANGE<br>INTERRUPT MASK | | | D0<br>MAC | MY ADDRESS<br>CHANGE<br>INTERRUPT MASK | Bits of this register are set (logic 1) to unmask (enable) the corresponding interrupt source condition to drive TMS 9914 output pin INT active low. Bits are reset (logic 0) to mask (disable) the corresponding interrupt source. | D7-D6 | Not used. | |-------|----------------------------------------------------| | D5 | BI enable interrupt on Byte Input. | | D4 | BO enable interrupt on Byte Output. | | D3 | END enable interrupt on EOI with ATN false. | | D2 | SPAS enable interrupt on Serial Poll Active State. | | Dl | RLC enable interrupt on Remote/Local Change. | | D0 | MAC enable interrupt on My Address Change. | GPIB INTERRUPT STATUS 1 IN 41h | D7 | tedeles de la companya company | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GET | GROUP EXECUTE TRIGGER | | D6 | HAMPSHAKE | | ERR | ERROR | | D5 | | | UCG | UNIDENTIFIED<br>COMMAND | | D4 | | | APT | ADDRESS PASS THROUGH | | D3 | | | DCAS | DEVICE CLEAR ACTIVE STATE | | D2 | | | MA | MY ADDRESS | | D1 | | | SRQ | SERVICE<br>REQUEST | | DO | | | IFC | INTERFACE<br>CLEAR | Status bits D7 - D0 are latched set as their corresponding source conditions occur, regardless of whether they are masked or unmasked by bits of register GPIB Interrupt Mask 1. GPIB Interrupt Status 0 bit INT41 is latched set whenever one or more unmasked (enabled) bits of register GPIB Interrupt Status 1 are set. Reading register GPIB Interrupt Status 1 causes all of its eight bits, as well as bit INT41 of GPIB Interrupt Status 0, to be reset. TMS 9914 output pin INT is active low whenever (INT40) OR (INT41) is true. The GET, ERR, UCG, APT, DCAS, and MA events cause an Accept Data State (ACDS) holdoff condition if they are unmasked. This allows the GPIBB Z-80A to respond to the interrupt, recognize the cause by reading the GPIB Interrupt Status 1, and take appropriate action before completing the handshake by loading the release ACDS holdoff Auxiliary Command (see Auxiliary Command Register descriptions below). D7 GET -- a Group Execute Trigger command has been received. | D6 | <pre>ERR an incomplete source handshake error has occurred.</pre> | |----|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | D5 | UCG an Unidentified Command has been<br>received, or a Secondary Command has been<br>received when the Pass Through Next Secondary<br>feature is enabled. | | D4 | APT a Secondary Address has been received in the Extended Addressing mode. | | D3 | DCAS a Device Clear Active State has occurred. | | D2 | MA My Address (MLA or MTA) and not SPMS . | | Dl | SRQ A Service Request has occurred and the TMS 9914 is the Controller In Charge. | | D0 | IFC An Interface Clear has occurred. | Status bite DJ - DO and landhed set as their curresponding sounds chalcher require they are masked on unnessed by bits of register #### GPIB INTERRUPT MASK 1 OUT 41h | D7<br>GET | GROUP EXECUTE<br>TRIGGER INTERRUPT<br>MASK | | |------------|------------------------------------------------|--------------------------------------------------------------------| | D6<br>ERR | HANDSHAKE ERROR<br>INTERRUPT MASK | | | D5<br>ucg | UNIDENTIFIED<br>COMMAND<br>INTERRUPT MASK | | | D4<br>APT | ADDRESS PASS<br>THROUGH<br>INTERRUPT MASK | | | D3<br>DCAS | DEVICE CLEAR<br>ACTIVE STATE<br>INTERRUPT MASK | | | D2<br>MA | MY ADDRESS<br>INTERRUPT MASK | | | D1<br>sra | SERVICE REQUEST<br>INTERRUPT MASK | 200<br>200<br>200<br>200<br>200<br>200<br>200<br>200<br>200<br>200 | | D0<br>IFC | INTERFACE CLEAR INTERRUPT MASK | BOAT | Bits of this register are set (logic 1) to unmask (enable) the corresponding interrupt source condition to drive TMS 9914 output pin INT active low. Bits are reset (logic 0) to mask (disable) the corresponding interrupt source. - D7 GET -- enable interrupt on Group Execute Trigger. - D6 ERR -- enable interrupt on incomplete source handshake. - D5 UCG -- enable interrupt on Unidentified Command or Secondary Command. - D4 APT -- enable interrupt on Address Pass Through. - DCAS -- enable interrupt on Device Clear Active State. - D2 MA -- enable interrupt on My Address. - Dl SRQ -- enable interrupt on Service Request. - DO IFC -- enable interrupt on Interface Clear. #### GPIB ADDRESS STATE IN 42h | D7<br>REM | TMS 9914 IS IN<br>THE REMOTE STATE | |----------------------|-----------------------------------------------------------| | D6<br>LLO | TMS 9914 IS IN<br>THE LOCAL LOCKOUT<br>STATE | | D5<br>ATN | THE IEEE 488<br>ATN LINE IS TRUE | | D4<br>LPAS | TMS 9914 IS IN THE<br>LISTENER PRIMARY<br>ADDRESSED STATE | | D3<br>TPAS | TMS 9914 IS IN THE<br>TALKER PRIMARY<br>ADDRESSED STATE | | D2<br>LADS<br>(LACS) | TMS 9914 IS ADDRESSED<br>TO LISTEN | | D1<br>TADS<br>(TACS) | TMS 9914 IS ADDRESSED<br>TO TALK | | D0<br>ulpa | LSB OF LAST<br>ADDRESS RECOGNIZED<br>BY TMS 9914 | Status bits read from this register sample the current state of the TMS 9914 internal address logic. Set (logic 1) status bits are interpreted as follows: - D7 REM -- the TMS 9914 is in the Remote state. - D6 LLO -- the TMS 9914 is in the Local Lockout state. - D5 ATN -- IEEE 488 bus line ATN is active low. - D4 LPAS -- the TMS 9914 is in the Listener Primary Addressed State. - D3 TPAS -- the TMS 9914 is in the Talker Primary Addressed State. - D2 LADS or LACS -- the TMS 9914 is addressed to Listen. - D1 TADS or TACS -- the TMS 9914 is addressed to Talk. - ulpa -- the LSB of the last address recognized by the TMS 9914. # GPIB BUS STATUS IN 43h | D7<br>ATN | ATTENTION | | |------------|-----------------------|---| | D6<br>DAV | DATA VALID | | | D5<br>NDAC | NOT<br>DATA ACCEPTED | | | D4<br>NRFD | NOT READY<br>FOR DATA | | | D3<br>EOI | END OR IDENTIFY | | | D2<br>SRQ | SERVICE<br>REQUEST | | | D1<br>IFC | INTERFACE<br>CLEAR | 0 | | D0<br>REN | REMOTE<br>ENABLE | | The GPIBB Z-80A samples the current IEEE 488 bus management line states by reading this register. | D7 | ATN Attention | |----|-------------------------| | D6 | DAV Data Available | | D5 | NDAC Not Data Accepted | | D4 | NRFD Not Ready For Data | | D3 | EOI End Or Identify | | D2 | SRQ Service Request | | Dl | IFC Interface Clear | | D0 | REN Remote Enable | Figure 3-2 illustrates the handshake operation of bus lines DAV, NDAC and NRFD assuming one Talker and several Listeners. 40 # AUXILIARY COMMAND REGISTER OUT 43h D7 C /s -- Clear or Set (see text) D6-D5 Not used D4-D0 f4-f0-- Auxiliary Command Select (see text) This register controls many of the TMS 9914 special features. The GPIBB Z-80A issues Auxiliary Commands to the TMS 9914 by outputting a byte to this register, and the bits of the byte determine the command issued as shown in Table 3-2 below. | C*/S | f4 | f3 | f2 | fl | f0 | MNENONIC | FUNCTION | |-----------------------------------------------|--------------------------------------|---------------------|-------------------------------------------|----------------------------|----------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0/1<br>0/1<br>n/a<br>0/1<br>0/1<br>n/a<br>0/1 | 0000000 | 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0 | 0<br>0<br>1<br>1<br>0<br>0 | 0<br>1<br>0<br>1<br>0<br>1 | swrst<br>dacr<br>rhdf<br>hdfa<br>hdfe<br>nbaf<br>fget | Software TMS 9914 Reset Release ACDS Holdoff Release RFD Holdoff Holdoff On All Data Holdoff On EOI Only Set New Byte Available False Force Group Execute Trigger | | 0/1<br>n/a<br>0/1<br>0/1<br>n/a<br>n/a | 0 0 0 | 0 1 1 1 1 1 1 | 0 | 1 0 0 1 1 | 0 1 0 1 0 1 | rtl<br>feoi<br>lon<br>ton<br>gts | Return To Local Send EOI With Next Byte Listen Only Talk Only Go To Standby | | n/a<br>0/1<br>0/1<br>0/1<br>n/a | 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1 | 1 1 1 0 0 0 0 | 1 1 1 0 0 0 | 0 0 1 1 0 0 | 0 1 0 1 0 1 0 1 0 | tcs<br>tca<br>rpp<br>sic<br>sre<br>rqc | Take Control Synchronously Take Control Asynchronously Request Parallel Poll Send Interface Clear Send Remote Enable Request Control | | n/a<br>0/1<br>n/a<br>0/1<br>0/1 | 1 1 1 1 1 | 0 0 0 0 | 0 0 1 1 1 1 | 0 1 0 0 1 | 0 1 0 1 0 | rlc<br>dai<br>pts<br>stdl<br>shdw | Release Control Disable All Interrupts Pass Through Next Secondary Set TI Delay Shadow Handshake | Table 3-2: TMS 9914 AUXILIARY COMMANDS A number of the functions are of the Clear/Set type. If a command is issued with the $\overline{C}$ /S bit set, then the function is selected and remains selected until the same command is issued with the $\overline{C}$ /S bit reset. These commands appear with a 0/1 entry in the $\overline{C}$ /S column. The Talk Only (ton) and Listen Only (lon) commands are of this type. Other commands, such as force EOI (feoi) and release RFD holdoff (rhdf), have a pulsed mode of operation. These commands appear with an n/a (not applicable) entry in the $\overline{C}$ /S column. The Force Group Execute Trigger (fget) and Return To Local (rt1) commands can operate in either Clear/Set or pulsed modes. The following paragraphs describe each of the TMS 9914 Auxiliary Commands. ### Software Reset (swrst) 0/1 X X 0 0 0 0 Writing this command with bit $\overline{C}$ /S set causes all inputs to be ignored and the TMS 9914 returns to the idle state. The Serial Poll Register and Parallel Poll Register are not cleared, and the following TMS 9914 internal states are selected: - SIDS (source idle state) - AIDS (acceptor idle state) - TIDS (talker idle state) - TPIS (talker primary idle state) - LIDS (listener idle state) - LPIS (listener primary idle state) - CIDS (controller idle state) - LOCS (local state) - NPRS (negative poll response state) - PPIS (parallel poll idle state) - SPIS (serial poll idle state). This command is active following a TMS 9914 hardware reset. The TMS 9914 may then be configured, but it is held in the idle condition until the swrst command is written with bit $\overline{C}$ /S reset. # Release DAC Holdoff (dacr) 0/1 X X 0 0 0 0 1 The Data Accepted (DAC) holdoff provides the GPIBB Z-80A time to respond to unrecognized commands, secondary addresses, device trigger or device clear commands. The holdoff is released by the Z-80A when the required action has been taken. Normally the command is loaded with the $\overline{C}$ /S bit reset. When used with the address pass through feature, however, bit $\overline{C}$ /S is set if the secondary address was valid, or reset if the secondary address was invalid. # Release RFD Holdoff (rhdf) n/a X X 0 0 0 1 0 Releases Ready For Data (RFD) holdoff, caused by a hdfa or hdfe. # Holdoff On All Data (hdfa) 0/1 X X 0 0 0 1 1 A Ready For Data (RFD) holdoff occurs on every data byte until the hdfa command is loaded with $\overline{C}$ /S reset. In such cases, the handshake must be completed by issuing the rhdf command. # Holdoff On End (hdfe) 0/1 X X 0 0 1 0 0 An RFD holdoff occurs when an end of data string message (EOI true with ATN false) is received over the interface. Command rhdf releases this holdoff. ### Set New Byte Available False (nbaf) n/a X X 0 0 1 0 1 If a Talker is interrupted before the byte stored in the Data Out Register is sent across the interface, then the byte is normally transmitted as soon as bus line ATN goes false. Issuing command nbaf suppresses transmission of this byte if the interrupt makes it unnecessary. ### Force Group Execute Trigger (fget) 0/1 X X 0 0 1 1 0 Issuing this command with bit $\overline{C}$ /S reset causes TMS 9914 output pin TRIGGER to pulse high for approximately 5 clock cycles (1.25 uSec). Issuing this command with bit $\overline{C}$ /S set causes pin TRIGGER to go high until another fget command is issued with $\overline{C}$ /S reset. No interrupts or handshakes are initiated. #### Return To Local (rtl) 0/1 X X 0 0 1 1 1 If the rtl command is issued with bit $\overline{C}$ /S reset, then GPIB Address Status bit REM is reset, but it may be set at any time by a REN command from the Controller In Charge. If the rtl is issued with bit $\overline{C}$ /S set, then status bit REM is reset, and it cannot be again set until the rtl command is issued with bit $\overline{C}$ /S reset. The rtl command has no effect if the TMS 9914 is in the Local Lockout (LLO) mode. ### Force End Or Identify (feoi) n/a X X 0 1 0 0 0 Sends the **EOI** message with the next data byte. The **EOI** line is then reset. ### Listen Only (lon) 0/1 X X 0 1 0 0 1 Activates the Listener State until the lon command is issued with bit $\overline{\mathbb{C}}$ /S reset. #### Talk Only (ton) 0/1 X X 0 1 0 1 0 Activates the Talker State until the ton command is issued with bit $\overline{\mathbb{C}}$ /S reset. Note that the ton and lon commands are included for use in systems without a Controller. However, when the TMS 9914 is functioning as a Controller, it uses the ton and lon commands to set itself up as a Talker or Listener, respectively. Note that these functions must be reset when sending UNL or OTA. ### Go To Standby (gts) n/a X X 0 1 0 1 1 The Controller In Charge issues this command to force bus line ATN false. ### Take Control Synchronously (tcs) n/a X X 0 1 1 0 0 This command is used by the Controller In Charge to set bus line ATN true after any handshake in progress is completed, and so gain control of the interface. If the Controller is not a true Listener, the shdw (Shadow Handshake) command must be issued with bit C /S set before issuing this command, allowing the Controller to participate in the Listener handshake without exchanging data. ATN is forced true at the end of the byte transfer to insure that the data byte is not lost or corrupted. ### Take Control Asynchronously (tca) n/a X X 0 1 1 0 1 Immediately forces bus line ATN active low. Data loss or corruption may occur if Talker/Listeners are in the process of transferring a data byte. ## Request Parallel Poll (rpp) 0/1 X X 0 1 1 1 0 The Controller In Charge issues this command with bit $\overline{C}$ /S set to send the Parallel Poll command over the interface (the TMS 9914 must be in the Controller Active State for line ATN to be forced true). The poll is completed by reading the Command Pass Through Register to obtain the status bits, then issuing command rpp with bit $\overline{C}$ /S reset. issued and the next byte ceceived (a PRE, or Parallel Poll Enable message) is routed through the Camana-Pass ### Send Interface Clear (sic) 0/1 X X 0 1 1 1 1 The System Controller issues this command with bit $\overline{C}$ /S set to force bus line IFC active low. After observing the IEEE 488 minimum time duration (100 uSec), the System Controller must issue the same command with bit $\overline{C}$ /S reset to force bus line IFC inactive high. The System Controller is then put in the Controller Active State. #### Send Remote Enable (sre) 0/1 X X 1 0 0 0 0 The System Controller issues this command with bit $\overline{C}$ /s set to force bus line **REN** active low to send the Remote Enable message over the interface. Line **REN** is forced inactive high by issuing the same command with bit $\overline{C}$ /S reset. #### Request Control (rgc) n/a X X 1 0 0 0 1 The GPIBB Z-80A issues this command after the TCT command has been recognized. The TMS 9914 then waits for bus line ATN to go inactive high, then enters the Controller Active State (CACS). #### Release Control (rlc) n/a X X 1 0 0 1 0 Releases bus line ATN after a TCT command has been sent passing control to another device. #### Disable All Interrupts (dai) n/a X X 1 0 0 1 1 Disables (floats) TMS 9914 interrupt request output pin INT. Registers GPIB Interrupt Status 0 and GPIB Interrupt Status 1 are not affected, nor are any selected holdoffs. ### Pass Through Next Secondary (pts) n/a X X 1 0 1 0 0 This command remotely configures a Parallel Poll. The Parallel Poll Configure (PPC) message is passed through the TMS 9914 as an unrecognized addressed command, then identified by the GPIBB Z-80A. The pts command is then issued and the next byte received (a PPE, or Parallel Poll Enable message) is routed through the Command Pass Through Register. The GPIBB reads the PPE message, and writes it to the Parallel Poll Register. ### Set Tl Delay (stdl) 0/1 X X 1 0 1 0 1 Issuing this command with bit $\overline{C}$ /S set defines the Tl delay time to be six clock cycles (1.5 uSec). Issuing this command with bit $\overline{C}$ /S reset defines the Tl delay time to be ten clock cycles (2.5 uSec). A ten clock cycle delay is automatically set by a Power On Clear. ### Shadow Handshake (shdw) 0/1 X X 1 0 1 1 0 Issuing this command with bit $\overline{\mathbb{C}}$ /S set enables the Controller In Charge to carry out the Listener handshake without participating in a data transfer. The Data Accepted line (DAC) is forced active low for a maximum of 3 clock cycles after Data Valid (DAV) is received, and Not Ready For Data (NRFD) is allowed to go false as soon as DAV is removed. The shadow handshake function allows the tcs command to be synchronized with the Acceptor Not Ready State (ANRS) so that bus line ATN can be reasserted without causing the loss or corruption of a data byte. The END interrupt can also be received and causes a ACDS holdoff to be generated. Issuing the shdw command with bit $\overline{\mathbb{C}}$ /S reset disables this function. # GPIB ADDRESS REGISTER OUT 44h D7 edpa -- Enable Dual Addressing Mode D6 dal -- Disable Listen Function D5 dat -- Disable Talk Function D4-D0 A5 through Al -- Device Primary Address A Power On Clear or a swrst command with bit $\overline{C}$ /S set puts the TMS 9914 into an idle state. The IEEE 488 Bus Address register (switch SWl) is then read by the GPIBB Z-80A, and written to bits A5 through Al of this register to define the Device Primary Address. Bit edpa is set to enable the TMS 9914 Dual Addressing Mode, and reset to disable it. When enabled, the least significant address bit is ignored by the address comparator, meaning that the TMS 9914 then responds to two consecutive addresses. GPIB Address Status bit ulpa may then be polled to differentiate between the two addresses. The dat and dal bits may be set to disable the Talk and Listen functions, respectively. Two separate devices may then use the same primary address if one only talks, and the other only listens. SERIAL POLL REGISTER OUT 45h This register contains the byte supplied to the Controller In Charge when it is conducting a Serial Poll on the GPIBB. The register is cleared by a hardware Reset but not by a software swrst Auxiliary Command. Bits S8 and S6 through S1 supply device dependent information to the Controller In Charge, while setting bit S7 (rsv) forces bus line SRQ true. When the Controller responds by carrying out a Serial Poll on the GPIBB, the TMS 9914 controlled SRQ output automatically returns to the passive false (high) state. A new Service Request cannot be made until bit rsv is first reset, and then set again. COMMAND PASS THROUGH REGISTER IN 46h The GPIBB Z-80A reads this register to sample the IEEE 488 DIO8 - DIO1 data lines when an unrecognized command or a secondary address condition occurs. These bits are not latched, so the GPIBB Z-80A typically has to read this register in response to an interrupt generated by unmasked GPIB Interrupt Mask 1 bits UCG and/or APT. # PARALLEL POLL REGISTER OUT 46h The contents of this register are placed on the IEEE 488 bus when the Controller In Charge conducts a Parallel Poll. The GPIBB Z-80A must load the register before the Parallel Poll operation occurs (usually during GPIBB initialization). The register may be remotely configured using the pts Auxiliary Command. This register is cleared by a TMS 9914 Reset, but not by a swrst Auxiliary Command. DATA IN REGISTER IN 47h The GPIBB Z-80A reads an Input Byte from the IEEE 488 bus through this register when the TMS 9914 is addressed as a Listener. GPIB Interrupt Status 0 bit BI remains set, and the Not Ready For Data line (NRFD) is held active low until this register is read. Reading this register also causes the TMS 9914 to releases bus line NRFD when reading this register unless either holdoff command hdfa or command hdfe has previously been issued. Issuing Auxiliary Command rhdf forces the NRFD handshake line inactive high, thereby completing the acceptor handshake. DATA OUT REGISTER OUT 47h When the TMS 9914 is functioning in the Talker or Controller modes, this register is transfers data bytes or command bytes from the Z-80A to the IEEE 488 bus. If the TMS 9914 is in the Controller Active State, commands are sent with bus line ATN active low. If the TMS 9914 is in the Talker Active State, device dependent data is sent with bus line ATN inactive high. In both cases the source handshake function is automatically carried out by the TMS 9914. The GPIBB Z-80A may load this register with a new byte whenever GPIB Interrupt Status 0 bit BO is set. Bit BO is set when the TMS 9914 enters the Talker mode to prompt initial loading. Bus line ATN may at times be forced active low by the Controller In Charge after the Data Out Register is loaded but before the data appears on the IEEE 488 bus lines. This byte appears on the bus immediately after bus line ATN goes inactive high, unless Auxiliary Command nbaf is issued before the byte is placed on the bus. Cromemco GPIB Instruction Manual romenco GPIB Instruction Manual . GPIBB Input/Output When the TMS 9916 is fundament in the Talker of Controller modes, this required to tradifier Acts bytes of command bytes from the Action to the 1985 Acts and 1985 Acts bus, if the TMS 9914 is in the Controller Active State, commands are sent with bus line ACT controller Active State, commands in in the Talker Active State, Sevade generated data is sent with bus line ACT could be acted to the source handshake function, is active that the this register by the TMS 9914. The PRISE that the course whenever with the this register is set. Bit BO is not when the TMS 9914 enters the Talker mode to prompt stituted Institut Bus line ATM may at rimas by forced active low by the Controller in Charge afred, the Date Ont Register is loaded but before the dita space of on the IEEE 488 bus lines. This byte appears on the out immediately after bus line ATM goes inactive has a unless Auxiliary Command abaf is issued before the byte is placed on the bus. # Chapter 4 1 210 210 220 22003 2001 #### GPIBB INTERRUPT STRUCTURE #### 4.1 GPIBB TO HOST INTERRUPTS The GPIBB can issue two types of interrupt requests to the host processor over the S-100 bus: non-maskable requests, which the host must acknowledge, and maskable interrupt requests, which the host may, or may not, acknowledge. The GPIBB issues a non-maskable interrupt to the host by setting GPIBB Control bit NMInt Host. This causes S-100 bus line NMI to go active low on the next falling edge of S-100 bus signal sMl. This active low level is automatically removed on the following sMl falling edge. The GPIBB issues a maskable interrupt request to the host by setting GPIBB Control bit Int Host. The host processor may either: - Allow the GPIBB to drive S-100 bus line INT active low, or - Disallow this control, yet sense an interrupt request condition if polling the GPIBB Control bit Int Host indicates that the bit is set. In the first case, the host processor sets Host Control bit Int Mask and resets bit Clr Int. S-100 bus line INT then goes active low when the GPIBB sets GPIBB Control bit Int Host (the GPIBB should have previously defined an interrupt vector value if the host Z-80 is operating in IMO or IM2 -- see below). The host Z-80A then either: - acknowledges the request if its own INT input pin is unmasked (interrupts enabled), or - ignores the request if its INT pin is masked (interrupts disabled). The GPIBB holds S-100 bus line $\overline{\text{INT}}$ active low until either: a host interrupt acknowledge cycle occurs, automatically clearing the request, or Cromemco GPIB Instruction Manual 4. GPIBB Interrupt Structure Host Control bit Clr Int is set removing the request and inhibiting further requests while the bit is set. The GPIBB is required to supply an eight bit interrupt vector during interrupt acknowledge if the host is operating in Interrupt Mode 0 or Interrupt Mode 2. The GPIBB defines the interrupt vector value by writing a byte to port GPIBB Output Data; the contents of this port are gated onto the S-100 bus DI lines during host interrupt acknowledge. In the second case, the host processor resets **Host** Control bits Int Mask and Clr Int. Then as the GPIBB sets GPIBB Control bit Int Host, S-100 bus line INT is unaffected, but the host can sense the interrupt request if polling reveals that the Host Status bit Int Pend is set. The host may then either: - <u>set</u> control bit Int Mask, enabling S-100 bus line INT to be driven active low, or - clear the interrupt request by setting bit Clr Int (removing the current interrupt request and inhibiting further interrupt requests), and then resetting bit Clr Int (allowing further interrupt requests to be sensed). When two or more S-100 bus boards issue maskable interrupt requests to the host processor, their requests are coordinated by Cromemco's S-100 Interrupt Priority daisy chain. The S-100 interrupt daisy chain is controlled by PRIORITY IN and PRIORITY OUT lines provided on the following Cromemco products: - the GPIB Interface at connector J3 - the IOP Input/Output Processor - the PRI line printer interface - the TU-ART serial interface - the 4FDC and 16FDC floppy disk interfaces - the WDI Winchester hard disk interface The board priorities are defined as shown in Figure 4-1. Figure 4-1: S-100 INTERRUPT DAISY CHAIN WIRING The Cromemco Interrupt Priority daisy chain resolves concurrently pending interrupt requests in favor of the highest priority task. After service of an interrupt has begun, regardless of its priority relative to the service routine in progress, any subsequent interrupt request is acknowledged as soon as the host processor enables maskable interrupts. Consequently, S-100 bus maskable interrupt priorities must be managed by the host software working with the S-100 bus daisy chain. For example, the highest priority service routine might not execute an EI instruction until just before returning to the background program, whereas the lowest priority service routine might execute an EI instruction immediately after entry. #### 4.2 GPIBB Z-80A INTERRUPTS Three sources may request interrupt service by driving GPIBB Z-80A pin INT active low: - the host processor through Host Control bit Int GPIBB - 2. an External Input port GATE DATA strobe - TMS 9914 GPIB Adapter output pin INT All of these sources may be masked or unmasked by bits of port GPIBB Control, and interrupt requests from all sources may be polled by reading bits of port GPIBB Status, regardless of the states of their corresponding mask bits. Note that reading the GPIBB Status register resets all interrupt request bits. This allows the GPIBB Z-80A to define interrupt priorities among these sources. Non-maskable interrupts cannot be issued to the GPIBB Z-80A, (because its NMI input pin is tied inactive high). The GPIBB Z-80A should be operated in Interrupt Mode 1 (IM1) since none of the three interrupt sources can supply an interrupt service vector. When operated in IM1, any unmasked interrupt request then causes the GPIBB Z-80A to execute a RST 38h, a one byte CALL instruction to address 0038h, near the beginning of ROMO. The interrupt service routine, starting at 0038h, should poll the GPIBB Status register to pinpoint the interrupt source, and then take appropriate action. Cromemco GPIB Instruction Manual 4. GPIBB Interrupt Structure The host processor issues maskable interrupt requests to the GPIBB Z-80A by setting Host Control bit GPIBB Int. The request is acknowledged if GPIBB Control bit Host Mask is set and Z-80A maskable interrupts are enabled. A maskable interrupt request is issued to the GPIBB Z-80A each time the External Input is loaded by pulsing GATE DATA (Jl pin 23) high. The request is acknowledged if GPIBB Control bit Input Mask is set and Z-80A maskable interrupts are enabled. The TMS 9914 GPIB Adapter issues maskable interrupt requests to the GPIBB Z-80A by driving its INT output pin active low. The request is acknowledged if GPIBB Control bit GPIB Mask is set and Z-80A maskable interrupts are enabled. A TMS 9914 interrupt request is removed by reading port GPIB Interrupt Status 0 and/or GPIB Interrupt Status 1. #### Cromemco GPIB Instruction Manual The request is acknowled to the country bit sents to the certae to the request is acknowled to the certae list for the request is acknowled to the sent and v-80A and v-80A and v-80A and v-80A and v-80A and v-80A and view the fatternal layor is leaded by palaing cars para (a) pin 13; high, we counted by the late to the certae are enabled in certae to the celts are enabled to the celts are enabled to the celts independent are enabled to the celts independent are enabled to the celts independent are enabled to the celts independent and the celts independent are enabled to the celts independent are enabled to control bit celts has the control bit celts has the centure are enabled. A set the centure are enabled as enabled to centure are enabled. A set the centure are enabled as enabled to centure are enabled. Appendix A PARTS LIST | | | Todos esta | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <u>Designation</u> | Description | Cromemco Part No. | | Integrated<br>Circuits | 2001 losgs | | | IC1 IC2 IC3 IC4 IC5 IC6 IC7 IC8 IC9 IC10 IC11 IC12 IC13 IC14 IC15-17 IC18 IC19 IC20 IC21 IC22 IC23 IC24 IC25 IC27 IC28 IC29 IC30 IC31 IC32 IC31 IC32 IC34 IC35 IC34 IC35 IC34 IC35 IC36,37 IC38 IC39-42 IC43,44 IC45 IC46 IC47,48 IC49 IC50-53 | 74LS74 74LS10 (non TI) 74LS04 74LS367 74LS174 74LS244 74LS273 74LS273 74LS245 GPIB Monitor ROM 74LS30 75160 75161 74LS139 74LS74 74CS74 74CS74 74LS10 74LS08 74LS08 74LS02 74LS00 74LS139 (non TI) 74LS04 2716/TMS2516 TMS 9914 (non TI) 74LS04 74LS367 74LS139 74LS139 74LS139 74LS139 74LS139 74LS174 74LS367 74LS174 74LS374 280-A AM9124EPC 7805/340T-5 74LS136 74LS05 74LS136 74LS244 AM9124EPC | 010-0055<br>010-0063<br>010-0066<br>010-0108<br>010-0107<br>010-0100<br>010-0102<br>010-0120<br>502-0070<br>010-0059<br>010-0317<br>010-0316<br>010-0118<br>010-0055<br>010-0104<br>010-0063<br>010-0063<br>010-0064<br>010-0068<br>010-0069<br>010-0118<br>010-0066<br>not supplied<br>011-0057<br>010-0066<br>010-0108<br>010-0108<br>010-0108<br>010-0055<br>010-0108<br>010-0055<br>010-0133<br>011-0010<br>011-0055<br>010-0065<br>010-0055<br>010-0065<br>010-0055<br>010-0055 | | Designation | Description | Cromemco<br>Part No. | | | |---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Diodes | | | | | | Q1 00 110 110 1 | 2N3 90 4 | 009-0001 | | | | Capacitors | | 29.00 | | | | C1,2<br>C3<br>C4<br>C5<br>C6-19<br>C20<br>C21-29<br>C30<br>C31-37<br>C38-40 | .047 uf axial .005 uf disk .001 uf disk .005 uf disk .047 uf axial 47 pf mono .047 uf axial 10 uf tant .047 uf axial | 004-0061<br>004-0025<br>004-0022<br>004-0025<br>004-0061<br>004-0061<br>004-0032<br>004-0061<br>004-0032 | | | | Capacitor<br>Networks<br>CN1,2 | 47 PF, 8 pin | 005-0000 | | | | Resistors | e - ARRESENTATION OF THE PROPERTY PROPE | | | | | R1,2<br>R3,4<br>R5<br>R7<br>R8<br>R9<br>R10<br>R11<br>R12,13<br>R14<br>R15<br>R16<br>R17-19 | 100 K<br>1 K<br>390<br>560<br>270<br>1 K<br>10 K<br>270<br>1 K<br>10 K<br>4.7 K<br>10 K<br>4.7 K | 001-0039<br>001-0018<br>001-0013<br>001-0015<br>001-0011<br>001-0030<br>001-0011<br>001-0018<br>001-0030<br>001-0024<br>001-0030<br>001-0024 | | | | Resistor<br>Networks | 7805/340T-5 01<br>7405/340T-5 01 | | | | | RN1<br>RN2<br>RN3<br>RN4,5<br>RN6 | 4.7 K, 8 pin<br>100 K, 10 pin<br>10 K, 8 pin<br>33, 8 pin<br>10 K, 8 pin | 003-0030<br>003-0035<br>003-0025<br>003-0000<br>003-0025 | | | | Designation | Description | Cromemco Part No. | |----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | RN7<br>RN8<br>RN9-12<br>RN13<br>RN14<br>RN15 | 1 K, 1 pin<br>10 K, 8 pin<br>560, 8 pin<br>33, 8 pin<br>10 K, 8 pin<br>33, 8 pin | 003-0007<br>003-0025<br>003-0006<br>003-0000<br>003-0025<br>003-0000 | | Miscellaneous | | | | | l switch, 6 pos. l switch, 7 pos. l switch, 7 pos. d 6-32 hex nut d #6 lock washer d 6-32X1/2 screw socket, 16 pin socket, 18 pin socket, 20 pin socket, 24 pin socket, 40 pin l socket, 2 pin l large heat sink crystal, 8 mhz | 013-0025<br>013-0033<br>015-0013<br>015-0020<br>015-0044<br>017-0002<br>017-0003<br>017-0004<br>017-0005<br>017-0006<br>017-0009<br>021-0017<br>026-0001 | Cromemco GPIB Instruction Manual Isuns solicities and some more Appendix B rimemoo GPIB Instruction Manual Cromemco GPIB Instruction Manual Parts Location Diagram # Appendix C # GPIB MONITOR COMMANDS The GPIB Monitor is controlled by single and double character commands that may be followed by one or more arguments. This section describes these commands and gives the command format for each. All GPIB Monitor commands must be terminated with a RETURN character. State and the state of #### @ -- EXECUTE BATCH COMMAND STRING The @ command executes a command string located in GPIB Format: Jyd d88 avsigsib avsigsib avsigsib basemoo farif edr starting with the end of the previous DM command; plus 1 (or start a DM command as a DM previously been issued) to the command firm the consecutive bytes beginning at start address. The third The ASCII string, beginning at address in GPIB memory, and ending with either a semicolon or a binary 0, is taken as a list of commands to be executed by GPIBMON. The string may have multiple commands within it. An error message is displayed and control is returned to the GPIBMON command level if an error occurs during command processing. #### DM -- DISPLAY MEMORY The DM command formats and displays the contents of GPIB memory on the console screen. port-address, and displays the data in hexadecimal Formats: dm dm start-address dm start-address end-address sassible days dm start-address S swath dm S swath The letter m is optional in all formats. Cromemco GPIB Instruction Manual C. GPIB Monitor Commands The contents of memory are displayed on the console in both hexadecimal and ASCII. Each display line provides information on up to 16 consecutive bytes of memory. Each line consists of three information fields. The leftmost field is the memory address, displayed in hexadecimal, of the first byte displayed in the center field. The center field contains the hexadecimal values of from 1 to 16 consecutive data bytes. The rightmost field displays the ASCII equivalent characters of each displayed byte. Since the 7-bit ASCII code ignores MSB bit D7, then ASCII character A is displayed for both data byte 41h and C1h. If the data byte is not equivalent to a printable ASCII character, the rightmost field will show a period character. GPIR Monitor Commands Example Display: 0100 41 42 43 44 30 31 32 33 C3 02 55 00 0D 0A 24 FF ABCD0123C.U...\$. The first command format above displays 80h bytes starting with the ending address of the previous DM command, plus 1 (or 4000h if a DM command has not previously been issued). The second format displays 80h consecutive bytes beginning at start-address. The third displays all bytes between start-address and end-address. The fourth displays swath bytes starting with start-address. The last form displays swath bytes, starting with the ending address of the previous DM command, plus 1 (or 4000h if a DM command has not previously been issued). A default value of 80h is assumed in the last two forms if no swath value follows swath character S. #### E -- EXAMINE INPUT PORT The E command reads data from input port number port-address, and displays the data in hexadecimal on the console screen. Format: e port-address Cromemco GPIB Instruction Manual C. GPIB Monitor Commands ### G -- GO TO ABSOLUTE ADDRESS The G command jumps to address in GPIB memory with current GP Z-80A register values. Format: q address This command transfers program control from GPIBMON to the program starting at address in GPIB memory. #### M -- MOVE (COPY) A BLOCK OF MEMORY The M command copies the contents from one block of GPIB memory to another block of GPIB RAM memory. The contents of the original block are unchanged unless the two memory blocks overlap. #### Formats: - m source-address end-address destination-address - m source-address S swath destination-address - m S swath destination The first command format copies all bytes from the source-address byte through the end-address byte to destination-address. The second copies swath bytes from source-address to destination-address. The last copies swath bytes from 4000h to destination-address. After the move, GPIBMON verifies that the two blocks of memory are the same. Discrepancies are formatted on the console as follows: ssss xx yy dddd where ssss is the source address, xx is the source data, yy is the destination data, and dddd is the destination address. The verification process lists discrepancies which are not necessarily errors after certain types of overlapping moves. Displays of this type may be terminated by typing CONTROL-C, CONTROL-Z or ESCAPE. Cromemco GPIB Instruction Manual C. GPIB Monitor Commands #### O -- OUTPUT DATA TO A PORT The O command writes data-byte to output port number port-address. #### Format: o data-byte port-address ### Q -- QUERY MEMORY FOR A STRING OF BYTES The Q command searches GPIBMON memory for a string. #### Formats: q start-address end-address string-of-bytes q start-address S swath string-of-bytes This command searches memory start-address through end-address, or swath bytes starting at start-address, for string-of-bytes. String-of-bytes can have any of the formats allowed by the SM command. If string-of-bytes is found, then 16 bytes are displayed, starting with the first matching byte. ### R -- READ BINARY DATA FROM THE CONSOLE The R command reads unaltered bytes from the current console and writes them to GPIB RAM memory. #### Formats: r start-address end-address r start-address S swath This command reads bytes (all 8 bits) from the current console and sequentially writes them into memory start-address through end-address, or swath bytes starting at start-address, until all bytes are written. This command may be used for loading binary or ASCII data from a Teletype paper tape reader into GPIB RAM memory. Cromemco GPIB Instruction Manual C. GPIB Monitor Commands SM -- SUBSTITUTE MEMORY The SM command changes the contents of GPIB RAM memory. Formats: sm address The character m is optional in both formats. The first command format prompts the user to change memory at the last location changed, plus 1 (4000h if no SM command has previously been issued). The second command form prompts the user to change memory at address. In both cases, GPIBMON prompts the user by displaying memory-address followed by its current-contents. The user has six options: - Type a data-byte value followed by RETURN. This causes data-byte to be stored at memory-address. Memory-address is then incremented and displayed on the next console line. - 2. Type a 'string' value followed by RETURN. This causes the ASCII code for all string characters (between the apostrophes) to be sequentially stored starting at memory-address. Memory-address is then adjusted beyond the last string byte, and is displayed on the next console line. - 3. Any combination of data-bytes and 'strings' may be entered in the same line, separated by SPACEs, with one RETURN terminating the line. Memory-address is then adjusted beyond the last byte stored, and displayed on the next console line. - 4. Type a minus sign. This causes memory-address to decrement with no memory change. The new memory-address is displayed on the next console line. This option is used to "back up" and correct a previous memory-address. - 5. Type a RETURN. This causes memory-address to increment with no memory change, and the new memory-address to be displayed on the next console line. Type a period. This terminates the SM dialogue, 6. and GPIBMON returns to the GPIBMON command level. #### V -- VERIFY A BLOCK OF MEMORY The V command verifies that the contents of two blocks of memory are the same. #### Formats: - v source-address end-address destination-address - v source-address S swath destination-address The first command format verifies that all bytes from source-address through end-address match the same number of bytes starting at destination-address. The second verifies that swath bytes beginning at source-address match swath bytes starting at destination-address. Discrepancies are formatted as follows: sss xx yy dddd where ssss is the source address, xx is the source data, yy is the destination data, and dddd is the destination address. ### W -- WRITE BINARY DATA FROM MEMORY TO THE CONSOLE The W command sequentially writes a block of GPIB memory bytes to the console. - w start-address end-address - w start-address S swath This command sequentially reads bytes from memory start-address through end-address, or swath bytes starting at start-address. The command writes them (all 8 bits) to the current console until all bytes are written. This command may be used for writing GPIB memory to a teletype paper tape punch. ### Z -- ZAP MEMORY WITH A BYTE CONSTANT The ${\bf Z}$ command fills a block of GPIB RAM memory with the same single byte value. #### Formats: z start-address end-address [value] z start-address S swath [value] This command fills GPIB RAM memory start-address through end-address, or swath bytes starting at start-address, with byte value. Value may either be a numeric or character value, e.g., 100., or '?'. If no value is specified, 00h is assumed. 2 -- ZAP MEMORY WITH A BYTE CONSTRUCT The Z command fills a to the Same shade byte value, where Pormates Start-address end-address inclus start-address S awath the date This command fills CPIB RAM COUNTIANT-address end-address, or swath byte counting at startwith byte value. Value to a nurcharacter value, e.g., lbu con the same specified, OOh is assumed. ### Appendix D ### SAMPLE GPIB PROGRAMS ``` TITLE GPIB GPIB Board Monitor SUBTTL *** Initialization and Main Control *** GPIB Version Definitions VERNUM RLSNUM The monitor starts off from here Skip around the user interface portion STARTI ; Skip around user info & RST 1 START: JR The following 6 bytes are for user program reference RLSNUM ; Version # for user reference ; Pointer to console data ; Free space pointer VERNUM, RLSNUM DB When a JSYS is executed, program control transfers to here for further processing ; ORG at RST 1 ; User entry control transfer point START+08H Initialize the monitor RAM and the console, print the signon message, then continue after the RST locations SP,STACK ; Load the SP HL,VARBS ; Clear the variables A,STACK-VARBS-4 ; in high memory ZERO ; Zapl All clean TTYIO OUTSTI ; Print the START1: LD LD CALL CALL CALL ; Print signon message ; Print signon message 'GPIB Monitor' 'VERNUM/10+'0', VERNUM/10+'0', VERNUM/10+'0', RLSNUM/10+'0', RLSNUM/10+'0'; SKip around RST 6 & F DB VERTXT: DB ; Skip around RST 6 & RST 7 If a break instruction (RST 30H) is executed, control will transfer to here, then back to DEBUG, provided it is running START+30H BREAK ; DEBUG break restart transfer ; in high memory More user interface information (otherwise unuseable due to proximity) SETMM1 ; Pointer to SM command (for DEBUG) ; Pointer to INIT single console ; Reserved for future use? If an invalid jump occurs, chances are that the PC will reach and execute an RST 38H instruction: the following will intercept it and display an error message with the bad address, then return control to the monitor START+38H ORG ; Crash trap location ; Get crash PC HL SP,STACK CRASH: POP ; Get crash PC ; Reload SP ; Print error message ; about what happened ; Adjust the PC LD OUTSTI CR, BEL, 'Crash ' DM DEC CALL ; Print it Go to the next line after a message, then initialize hi-segment variables CRLF HL,4000H (SETPNT),HL (DISPNT),HL ; Go to next line ; Set initial pointers to 4000H ; for Substitute Memory command ; and Display Memory command ; Set up JP instruction ; at BREAK to abort ; the job incase DEBUG ; isn't in the system START2: CALL LD LD A,0C3H (BREAK),A HL,CRASH (BREAK+1),HL T.D START3: Main command level: If not a BATCH job, then prompt for a command, and get a command from user If a BATCH job, point to the next command and proceed ; Reload SP; Get BATCH error flag; Are any errors? ; Yes, reset & abort BATCH job; Get BATCH job flag; Get BATCH pointer in case active; Is there a BATCH job active? ; Yes, continue w/o prompt; Print the prompt; Nice & simple REENTE: LD A NZ, REENTX JR A, (BATFLG) DE, (BATPNT) I.D NZ, REENTI CALL OUTSTI '2.' DE,LINBUF DM ; (Nice & simple) ; Point to input buffer ; Get line length ; Get input line A, LINLEN INLINE CALL ``` ``` ; Check first non-space ; Is it end of line? ; Yes, ignore & reset BATCH flags ; Remainder of line a comment? ; Yes, ignore & reset BATCH flags ; Convert command to uppercase ; Too big for "Zap" command? ; Yes, error ; Doodle off ASCII bias ; Oops, not a command type ; *2 for command jump table ; Point to command jump table ; Point to command jump table ; Point to command entry ; Get the command entry ; Get hex command letter ; Get next character ; Get next character ; Convert to uppercase if needed ; Point to re-entry location ; Save it for return trip ; Save the routine address ; Load default argl if needed ; Go to the routine t; nothing at this point REENT1: CALL JR CP Z, REENTX JR CALL CP JR Z, REENTX NC.CMDERR SUB JR ADD C, CMDERR HL. CMDJMP LD ADDH LOADHH DE NTSSCN CALL INC CALL CALL LCUC BC, REENTE LD. PUSH PUSH HL,4000H Come here for absolute job abort; nothing at this point can keep the monitor from going back to the main prompt REENTC: XOR LD JR ; Say no more BREAK in HISEG; Save it now that DEBUG's gone; Cancel whatever else exists (BREAK+2),A Come here if command (or other) error CMDERR: CALL DM OUTSTI BEL,'?\R' ; Print error message ; "<BEL>?<CR><LF>" This part will return to the routine pointed to by XCTADR ONLY if the BREAK jump transfer is not pointing to the monitor, else go back to main command level (no BATCH jobs will survive) If the console is not at the beginning of an output line then print a <CR><LF> sequence ; Reset BATCH flag and ; say no BATCH errors ; Get the current console position ; At beginning of a line? ; No, go there ; Get BREAK's JP address ; Is DEBUG running? ; No, go back to command level ; Yes, get execution return address ; Go back to wherever REENTX: LD LD HL,0 (BATDAT),HL REENTQ: LD OR CALL LD A, (TTYPHP) A, (BREAK+2) OR JR LD JP A Z,START3 HL,(XCTADR) (HL) ; Go back to wherever SUBTTL *** Move & Verify Commands *** Move Memory Command M source S swath dest <CR> M source finish dest <CR> This command moves swath bytes from source to destination (or from source through finish to destination) ; Get arguments ; Save swath ; and destination ; and source ; Boing! New location ; Get back arguments ; for verify routine ; Need length, too ; Go verify MOVE: CALL ARG3Q PUSH PUSH PUSH BC DE HL LDIR HL POP POP POP JR DE BC VERIFX Verify Memory Command V source S swath dest <CR> V source finish dest <CR> This command compares (verifies) swath bytes from source to destination (or from source through finish to destination) and displays any discrepancies VERIFY: CALL ; Get the arguments A, (DE) (HL) Z, VERIFO HEXWO A, (HL) HEXBO ; Get data @ destination ; Is it the same as @ source? ; Yes, check next byte ; No, print source address ; Get source data VERIFX: LD CP JR CALL LD CALL CALL ; Get source data; Print it; Move over; Get destination data; Print it; Gap; Get destination address; Print it; Restore it; New line SPACE LD CALL CALL A, (DE) HEXBO SPACE EX CALL DE.HL HEXWO EX ``` ``` VERIFO: INC DE ; Bump destination pointer; Bump source pointer; Drop count; Did it go; to 0? No, keep checking; Yes. return HL BC A,B INC LD NZ, VERIFX JR RET SUBTTL *** Set Memory Command *** Set (Substitute) Memory Command SM addr <CR> This command will prompt for information to be stuffed into memory (this command kills BATCH jobs due to possible buffer conflicts) The letter M is optional ;; SETMEM: CP ; Is "S" followed by "M"? ; No, just "S" ; Bump past "M" ; Get default argument ; Get address where to start NZ, SETMMO DE HL, (SETPNT) ARGID INC SETMMO: LD CALL SETMM1: XOR ; Get a 0 LD CALL LD CALL CALL (BATFLG),A HEXWO A,(HL) HEXBO ; Abort any current BATCH job ; Print address ; Get current contents Print them SPACE ; Print a space ; Point to line buffer ; Get line length ; Get input line ; Scan for non-space ; Is it to stop? ; Yes, return ; Is it to back up? ; No, do the conversion ; Back pointer up ; Go save it & try again LD LD CALL CALL A, LINLEN INLINE NTSSCN CP RET NZ.SETMM3 SETMM2: DEC JR. SETMM6 INSTR NC,SETMM4 OUTSTI BEL,'?',CR SETMM3: CALL JR CALL ; Convert input line to binary ; If no error, then continue ; Print error message ; "GED:YCCRLF" JR SETMM1 ; & try again XOR ADD JR SETMM4: ; Zap A ; to check count in B ; Not empty, save the data ; Bump pointer ; & try again NZ, SETMM5 INC JR SETMM6 SETMM5: ; Load count in BC ; proper ; Swap pointers ; Shove the data into memory ; Restore pointers EX LDIR DE, HL EX DE, HL SETMM6: LD JR (SETPNT), HL SETMM1 ; Save pointer for later ; & go for more SUBTTL *** Find a String-of-Bytes Command *** Find a String-of-Bytes Command, also known as "Query" Q start S swath string-of-bytes <CR> Q start finish string-of-bytes <CR> This command searches the memory specified from start for swath bytes (or from start through finish) for the specified string-of-bytes; when found, the first 16 bytes are displayed ;; ;; ; Get address and Swath arguments; If none, then error; Save Swath; Get string; Get String; Get Swath back into DE; If error, then abort; Zap A; to check length of entry; Oops! No string there FIND: CALL JR PUSH CALL INSTR POP DE FINDE: C, CMDERR A B Z, CMDERR JP XOR FIND1: ; Save length ; and Swath ; and address ; Point to binary buffer DE PUSH LD HL DE, LINBUF ; Get a byte ; Is it the same? ; No, failure here ; Bump binary pointer ; Bump memory pointer ; Go until all expended LD A, (DE) (HL) NZ,FIND3 DE JR INC INC HL FIND2 When we get to here, the strings are the same ;; ``` ``` ; Get memory pointer back; momentarily; Print 10 bytes; only if the strings matched; Get memory pointer back again; and Swath; and count FIND3: PUSH LD CALL POP Z,DISLIN HL POP ; Bump memory pointer ; Drop Swath ; Did the Swath ; go to 0? ; No, keep looking ; Yes, all done here INC HL LD OR JR RET A,D NZ,FIND1 SUBTTL *** String Input Processing Routine *** Get String of Bytes from (DE) & leave final string at DE in LINBUF with count in reg B Entry: DE points to string Exit: B contains count of bytes DE points to string in LINBUF ; Save HL; Initial count of 0; Point to binary result buffer; Skip spaces; Save BATCH pointer for later; Is it EOL?; Yes, done; Rest of line a comment?; Yes, done; Bump past current character; Is it multi-command?; No. continue INSTR: PUSH B,0 HL,LINBUF NCMSCN LD CALL INSTRI . (BATPNT), DE LD OR JR CP JR Z, INSTRD Z, INSTRD DE MXCHR INC CP JR Bump past current character Is it multi-command? No, continue Yes, save BATCH pointer Say BATCH active, Finish up here Save character in case delimiter Is it single quote? Yes, process string Is it double quote? Yes, process string Repoint to numeric arg Save binary pointer Get argument Get result into A Restore binary pointer If no argument, then error Save argument Bump binary pointer Bump count & go for more data Get the character MXCHR NZ, INSTRC (BATPNT), DE (BATFLG), A INSTRD C, A LD LD INSTRC: CP JR CP JR Z, INSTRS Z, INSTRS DE JR DEC PUSH CALL LD POP JR LD INC HL ARGH A,L HL C,INSTRD (HL),A HL INC JR INSTRI LD INC OR JR INSTRS: ; Get the character Bump past it Is it EOL? A 2, INSTRD Yes, done Is it the delimiter? Yes, end of string Save the character CP JR LD INC Z.INSTR1 (HL),A ; Bump binary pointer ; Bump count ; Go for next character INC JR INSTRS INSTRD: LD POP ; Point to beginning of buffer Restore HL RET ; & return SUBTTL *** Display Memory Command *** Display Memory Command DM start S swath <CR> DM start finish <CR> DM start finish <CR> This command displays the contents of memory beginning at start for swath bytes (or from start through finish) If the start is missing, last DM address is assumed If the swath is missing, 80H is assumed ;; The letter M is optional ; Is "D" followed by "M"?; No, just "D"; Bump past "M"; Bump past "M"; Default swath is 80H bytes; Get default data pointer; Get (new) arguments; Assume line length of 10H; Zap A to; check if near the end; No, continue; Is there less than 10H; bytes to go?; No, still assume 10H; Zap A to check; if Swath 0?; Yes, assume 10H to dump all; Get final amount DISPLY: CP NZ, DISPL1 INC DE BC,80H HL,(DISPNT) ARG2D E,10H DISPLI: LD XOR OR NZ, DISMM2 A, OFH C,DISMM2 XOR OR JR LD ``` ``` Save count to go Load line count Print the line Save data address Get count back DISMM2: PUSH B.E CALL DISLIN (DISPNT),HL LD BC A,C Adjust the count by subtracting the number LD SUB NC.DISMM3 of bytes just printed Did we JR B A,B C NZ,DISMM1 DISMM3: LD OR JR RET run out? No, not done yet ; Yes, return SUBTTL *** Display a line of memory up to 16 bytes *** Display up to 16 bytes of memory on the console Entry: B contains the length HL points to the data ;; Print address Save count Save data pointer 0 bytes printed Check if multiple of 4 bytes printed Yes, print a space Get data byte Print it Bump data pointer Bump byte count Go until all has been dumped Move out to column 58 Go there Get data pointer back & count, too Get character Bump pointer HEXWO BC HL C,0 A,11B C Z,SPACE A,(HL) DISLIN: CALL PUSH PUSH DISLN1: LD AND CALL LD CALL A, (HL) HEXBO INC HL DISLN2: LD CALL DJNZ DISLNI B,58 PRITAB HL BC POP POP A, (HL) DISLN3: LD INC Bump pointer; Print the character; & go until this line done; then goto next line & return DISLN4 DISLN3 CRLF CALL ; Mask off ^7; Is it <DEL>? ; Yes, non-graphic print; Is it graphic? ; Yes, go print it; Get a '.' instead of whatever; & go print it DISLN4: AND CP JR DEL Z,DISLN5 NC, OUTCHR A,'.' DISLN5: LD JP SUBTTL *** Miscellaneous Other Commands *** Execute command string in memory at addr @ addr <CR> This command starts up a BATCH job as a sequence of commands to be executed ;; CALL ; Get the string address ; Save it for BATCH processing ; Say that BATCH ; is active BATCH1: LD LD (BATPNT), HL A,-1 (BATFLG),A RET ; Return Examine input port \tt E port \tt \langle CR \rangle The contents of the input port are displayed on the console ARGIQ C,L A,(C) HEXOUT CRLF ; Get argument where to look ; Load into C ; & get the data ; Print it EXAMIN: CALL LD IN ; New line & return Output data to a port O data port (CR) The data specified is sent to the port specified ; Get data byte ; Save it on the stack ; Get port # ; Load into C ; Get data byte back ; Send it ARGH OUTPUT: CALL ARGH HL ARGIQ C,L HL (C),L PUSH CALL LD POP OUT RET Zap memory with a byte constant Z start S swath byte \langle \text{CR} \rangle Z start finish byte \langle \text{CR} \rangle This command Zaps the memory specified from start for swath bytes (or from start through finish) with the specified byte ``` ``` Get addresses and data byte Save the data byte in memory Copy start address from HL to DE Adjust Swath for first byte Was "S1" specified? Yes, already done Bump destination to next byte ZAP! All done, return CALL LD LD LD ARG30 ZAP: (HL), E D.H DEC A,B LD INC ; All done, return FORM Program Control Transfer; "Go" command G addr <CR> ;; This command jumps to location addr ; Get the address ; Go to HL GOTO: (HL) Send Nulls to the Console N <CR> N number <CR> ;; This command issues number of <NUL> characters to the current console (default number is 16) ; Default # is 16 nulls ; Get the number ; Save count in B ; Get a <NUL> LD CALL NULLS: ARGID B,L A LD XOR NULLS1: CALL DJNZ RET ; Send the null ; Go until all sent ; then return TTYOUT Read Binary Data from the console into memory R start S swath <CR> R start finish <CR> This command reads binary data from the current console into the IOP memory as specified ;; ARG2Q TTYIN (HL),A ; Get start & swath ; Get a byte ; Save it in memory ; Bump pointer & check count READ: READ1: LD CPI ; Done, return ; Keep reading RET READ1 Write Binary Data from memory to the console W start S swath <CR> W start finish <CR> This command writes binary data from the IOP memory specified to the current console Get start & swath WRITE: WRITEL: ARG20 CALL ; Get start & swath ; Get a byte from memory ; Send it ; Bump pointer & check count ; Done, return ; Keep writing CALL CALL CPI RET JR A, (HL) TTYOUT NV WRITEL SUBTTL *** User Operation Processing *** This routine dispatches user operation requests. A "JSYS n" operation is executed by the user, where n is the function code. Control is transferred here and the function code is converted to a routine address. The PC is adjusted around the function code, then the user is sent to the routine they requested. If an invalid function is requested, the job is aborted. The registers are not disturbed. ; Get PC, save HL ; Save current AF ; Get operation code ; Save it for later ; Save PC on stack incase invalid ; Are we out of range? ; Yes, assume we crashed ; Get PC back ; Get original AF back ; Bump past operation code ; Restore PC & HL EX PUSH LD JSYSX: (SP),HL A, (HL) (JSYSOP),A HL JSYSJN T.D PUSH CP JP NC, CRASH HL AF HL (SP), HL POP POP INC The function code has been saved and its range has been checked All registers at this point are back to normal (temporarily) ; Save HL ; Save AF again ; Get the operation code ; *2 for jump table ; Point to jump table ; Point to actual entry ; Get AF back PUSH A, (JSYSOP) A HL, JSYSJP ADD LD CALL POP ADDH AF ; Get routine address; Save it on stack, get HL back; Go to the routine CALL EX RET LOADHH (SP),HL ``` ``` SUBTTL *** General Purpose Subroutines *** ;; Add A to the contents of HL HL=HL+A ADDH: L L,A NC H ADD ; Add L ; Resave it ; Return if no overflow ; Adjust H RET ; & return Convert the ASCII decimal string at DE to a binary value in HL Entry: DE points to string Exit: HL contains value A contains break character ; Skip spaces ; Start with 0 ; Get a character ; Is in numeric? ; No, return ; Bump character pointer ; Convert to binary ; Save BC ; Make copy of ; HL into BC ; *2 ; *4 ; *5 ; *10 ; Restore BC DECIN: CALL LD DECINL: LD NTSSCN HL,0 A,(DE) NUMER CALL RET INC DE '0' BC PUSH LD LD ADD B,H C,L HL,HL HL,HL ADD ADD ADD HL, HL HL, BC HL, HL BC ADDH DECINL POP Restore BC Add in new digit and go for next CALL Check if End Of Line, error if not This routine is also BATCH continuation processor EOLCHK: PUSH CALL ; Save AP; ; Check for non-space; ; Save pointer for BATCH; ; Is it the end? ; Yes, restore AP & return : Is it a comment? ; Yes, restore AF & return : Is it multi-command? : No, error : Yes, bump past it Save new batch pointer Say no BATCH errors Get all 1s Say BATCH job active Get AF back & return Save AF NTSSCN LD OR JR CP JR (BATPNT), DE A Z,EOLCK1 Z, EOLCK1 MXCHR NZ, CMDERR SUB JP INC DE LD LD CPL LD EOLCK1: POP (BATPNT), DE (BATERR), A (BATFLG),A RET ; & return FORM Convert ASCII HEX value in A to binary Entry: A contains character Exit: A contains binary value ;; HBCNV: '0' 10 SUB ; Convert to binary ; Was it "A-F"? ; No, return ; Convert for 10-15 CP RET SUB Verify if character in A is valid ASCII HEX Entry: A contains character adjusted for UPPERCASE Exit: A contains character adjusted for UPPERCASE Carry flag reset if OK, else Carry flag set if not OK ;;;;;; ; Check if numeric ; Yes, return ; Convert to uppercase if alpha ; Is it ""A""; ; Yes, return ; Is it >"p"; ; (Adjust flag) ; Who knows? HEX: NUMER NC LCUC 'A' CALL RET CALL CP RET CP CCF FORM FORM Print a space, then print binary value in A to console as HEX Entry: A contains value Register A gets destroyed :: AF SPACE AF HEXOUT HEXBO: PUSH ; Save HEX value ; Print the space ; Get HEX value back ; & print it CALL JR Convert the ASCII HEX string at DE to a binary value in HL Entry: DE points to string Exit: HL contains value A contains break character ``` ``` NTSSCN HL,0 A,(DE) HEX ; Skip spaces ; Start with 0 ; Get a character ; Valid HEX? HEXIN: HEXINL: LD CALL ; Valid HEX?; No, return; Bump ASCII pointer; Convert character to binary; Make room for new digit; by shifting 4 bits; which is like; multiplying by lOH; Combine new digit; & resave it; Go for next digit RET DE HBCNV HL, HL HL, HL ADD HL, HL HL, HL ADD LD JR HEXINL FORM Print 2 byte binary value in HL as HEX Entry: HL contains value Register A gets destroyed ; Get high byte ; Print it ; Get low byte HEXWO: LD A.L ; & drop to printing it Print binary value in A to console as HEX Entry: A contains value Register A gets destroyed ;; ; Save byte for later ; Get ; left ; side PUSH HEXOUT: AF RRCA RRCA RRCA RRCA ; side ; rybble ; Print it ; Get byte back ; Mask off for right nybble ; Convert to ASCII ; Is it "A-F"? HEXOU1 CALL AF 1111B '0' '9'+1 POP HEXOUl: CP JP ; No, go print it ; Convert to "A-F" ; & print it C, OUTCHR ADD OUTCHR If character in A is lowercase ASCII, then convert to UPPERCASE ASCII ;; 'A'+40Q C 'Z'+41Q ; Is it <"a"?; Yes, return; Is it >"z"?; Yes, no conversion; Convert to uppercase; & return CP RET CP RET LCUC: NC 400 Load HL with that pointed to by HL \mathrm{HL} = (\mathrm{HL}) ; Save AF ; Get low byte ; Bump pointer ; Get high byte ; Shuffle low byte ; Restore AF ; & return LOADHH: PUSH AF A,(HL) HL H,(HL) L,A AF LD INC LD LD POP Skip past TABs & spaces & only 1 comma Entry: DE points to string Exit: DE points past TABs, spaces & comma ; Skip TABs and spaces ; Do we have a comma? ; No, return ; Point past comma ; Drop to look for next non-space CALL CP RET NCMSCN: NTSSCN ΝŹ INC DE Skip past TABs & spaces Do while (DE)=[" "|TAB]: DE=DE+1; Loop Entry: DE points to string Exit: DE points past TABs & spaces ; Get a character ; Is it a space? ; Yes, skip it ; Is it a <TAB>? ; No, return ; Bump pointer ; & keep looking A, (DE) NTSSCN: Z,NTSSC1 TAB JR CP NZ DE NTSSC1: Verify if character in A is valid ASCII numeric Entry: A contains character Exit: A contains character Carry flag reset if OK, else Carry flag set if not OK ``` ``` NUMER: CP RET ; Is it <"0"? ; Yes, return ; Is it >"9"? ; (Adjust flag) ; Who knows? 101 C '9'+1 CP Move print head over to column specified in reg B Entry: B contains column number AF A, (TTYPHP) A, (TTYPHP) A, (TTYPHP) B, (TTYPHP) A, PRITAB: PUSH PRITB1: LD CP CALL Clear a block of memory at HL for length in A Do while A: (HL)=0; HL=HL+1; A=A-1; Loop (HL),0 ; Load a 0 into memory HL ; Bump pointer A ; Check count NZ,ZERO ; & go until done ; then return ZERO: LD JR SUBTTL *** Numeric Argument Processing Routines *** Entry: DE points to argument string, leading spaces & tabs are ignored Certain defaults MAY be allowed in BC and HL, depending on routine called DE points just past argument string, except in the case of ARG3O, then DE contains argument 3 BC contains Swath, if required (argument 2 minus argument 1) HL contains argument 1 A has the character breaking the string for ARGX and ARGXD carry flag SET indicates no argument given ABGxx Get argument(s) xxx1x HL=arg xxx2x HL=arg1, BC=arg2-arg1 xxx2x HL=arg1, BC=swath xxx30 HL=arg1, BC=sorg2-arg1, DE=arg3 xxxx0 If no arg then error xxxx0 If no arg then default xxxx0 or xxxx0 If no EOL then error ARGxx xxxlx ;; Get 1 argument, defaults not allowed ARGID ; Get number NC ; Number given, return CMDERR ; None given, error ARGIQ: CALL ARGCMC: RET ARGCME: JP Get 1 argument, defaults allowed ARGH ; Get (maybe) argument EOLCHK ; & go check for EOL ARGID: CALL ARGEOL: JP Get 2 arguments, defaults not allowed ; Get 2 arguments ; Check if any given ARG2Q: CALL Get 2 arguments, defaults allowed ; Get 2 arguments ; & go check EOL ARG2D: CALL ARGEOL FORM Get 3 arguments, 1st argument default allowed, Swath & 3rd argument defaults not allowed ; Get first 2 arguments ; Error if none given ; Save 1st argument ; Get 3rd argument ; Check for EOL ; Move 3rd argument into place ; Restore 1st argument ; Go check if all args given ARG2 C,ARGCME HL ARGH EOLCHK ARG3Q: CALL PUSH CALL CALL POP ;; Get 2 arguments, defaults allowed, EOL not checked for ARG2: CALL ARGH ; Get 1st argument ; Drop through to get Swath Get Swath operator, default allowed Entry: DE points to string HL contains argument 1 Exit: BC contains Swath (argument 2 minus argument 1) DE points just past string HL contains argument 1 ``` ``` ; Skip to argument ; Check for lowercase ; Is it a true Swath? ; (Save argument 1) ARGS: NCMSCN (Save argument 1) No, generate it artificially Bump past "S" Get the Swath Hey! No fair, "S" with no number Move Swath from HL to BC Restore argument 1 & return PUSH NZ , ARGS1 JR ARGH CALL C, ARGCME B, H C, L JR LD LD ; Restore argument 1; & return ; Get argument 2; None, use default ; Get a copy of ; argument 1 into BC ; Generate Swath by subtracting ; argument 1 from argument 2 ; Adjust Swath for the end points ; Move Swath ; into BC ; Restore argument 1 ; Get breaking character ; Say we got the Swath ; & return ARGSR: HL ARGS1: CALL C, ARGSR BC BC JR POP PUSH OR SBC A HL,BC INC HL B,H C,L HL POP A, (DE) LD OR Numeric Argument Radix Conversion Routine used by Argument Processing Routines Entry: DE points to string HL contains default Exit: DE points just past string HL contains value (or default if none given) A contains break character ; Look for non-space ; Save the pointer ; Save any default ; Check for breaker ; Is it decimal point? ; Restore default ; & pointer ; Get first character ; Yes, it was decimal point ; Check if valid HEX ; No, return with default ; Get new value ; Is it terminated by "H"? ; Yes, skip over the "H" ; Reset cy flag ; & return ; Is first character numeric? ; No, return with default ; Get new decimal value ; Bump past "." ARGH: DE PUSH PUSH CALL HL HEXIN HL DE POP A, (DE) Z, ARGH1 HEX LD JR CALL RET CALL HEXIN CP JR Z,ARGH2 A NUMER ARGH1: CALL CDECIN CALL Bump past "." Get new breaker Reset cy flag INC ARGH2: OR RET ; & return SUBTTL *** Advanced Console I/O Routines *** Input a buffered LINE of characters Entry: DE points to line buffer A contains maximum length Exit: DE points to line buffer A contains actual entered length Line is terminated with binary 0 ;; ; Save BC ; & HL also ; Save maximum length ; Initial length of 0 ; Point HL to BC HL C,A B,O H,D INLINE: PUSH PUSH LD INLING: LD LD Point HL to line buffer Get a character If <NUL), then ignore it Is it Control-E? If so, go to new line then ignore it Le it <CP22 L,E TTYGET Z,INLINL INLINL: CTLE Z,CRLF Z,INLINL CP ; Then ignore it; Is it <CR>?; Yes, end of line; Is it backspace?; Yes, elete a character; Is it <DEL>?; No, check something else; Zap A; To check buffer length; Empty, nothing to delete; Drop pointer; & count; Blank out character; Get what character that was; Was it a control character?; Yes, blank out the """; Go get another character JR CP JR CR Z, INLINB CP BS Z.INLIN1 JR CP JR NZ, INLIN2 INLIN1: XOR OR JR Z, INLINL BACKSP CALL LD CP CALL A, (HL) C, BACKSP ``` ``` INLIN2: PUSH CALL POP AF OUTECH Save character Print it Restore it Is it ^C? Yes, abort the job Is it ^Z? AF CTLC CP Z, INLIN3 CTLZ Z, CRLF Z, REENTC JR ; Yes, abort the job; ; Is it 72; ; Go to next line if so ; Yes, go back to command level ; Is it 70; ; Go to next line if so ; Yes, scrap this line & get another ; Save the character ; Bump pointer ; & count ; Get maximum length ; Are we there yet? ; No, go for another character ; Zap final byte ; Get final length ; Get HL back ; and BC also ; Set length flags ; Go to next line & return CP INLIN3: CALL JP CP CTLU Z,CRLF Z,INLING LD INC (HL),A INC LD CP JR A,C B NZ,INLINL (HL),0 A,B HL BC INLINB: LD LD OR Print a <CR><LF> sequence CRLF: CALL OUTSTI ; Print the following ; <CR> will also make <LF> RET ; Return Print a "<BS><SPACE><BS>" sequence ;; BACKSP: CALL ; Use a short cut ; "<BS> <BS>" DM RET ; Done Echo character from input routine Entry: A contains the character Exit: A gets destroyed ; Check if graphic character; Yes, go print it; Check if (CR); Yes, go print it; Save character; Get ""; Print it; Get character back; Convert to graphic; Print it & return OUTECH: NC, OUTCHR JR CP Z,OUTCHR AF A,'^' OUTCHR JR PUSH LD POP ADD AF 'A'-1 JR OUTCHR Get a processed (echoed) character Exit: A contains the character INCHR: CALL ; Get a character ; Is it <DEL>? ; Yes, don't echo it ; Is it printable? CP RET CP DEL 2 JR CP JR RET NC, OUTCHR CR Z, OUTCHR ; Yes, print it ; Is it <CR>? FORM ;; Print a space A, ' ' SPACE: LD ; Load the space ; & drop to OUTCHR Output a processed character via TTYOUT & check for characters typed. Also adjust console position & check for BATCH errors Entry: A contains character All registers preserved unless output is aborted y Save character & flags; y Mask off parity; y Save HL point to cursor position; Is the character (BEL)? No, check what else; Get the console position; Is it 0? No, this is just another ding; Yes, this means an error; Set error flag; Reload the (BEL); Is it (BS)? No, check for (TAB); Back up cursor pointer; Go print the (BS); Is it (TAB)? No, check for graphic OUTCHR: PUSH AND AF 7 PUSH HL, TTYPHP BEL NZ, OUTCHO LD CP JR LD OR A, (HL) NZ, OUTCHQ (BATERR),A OUTCHO: LD A,BEL BS OUTCHO: NZ, OUTCH1 (HL) OUTCHG JR OUTCH1: CP TAB NZ, OUTCH3 ; No, check for graphic ``` ``` Print a space Load mask for (TAB) position Are we there yet? No, keep printing Yes, return Is it (DEL)? Yes, just print it Is it graphic? No, just print it Yes, Bump cursor pointer Print the character Is it (CR)? No, check if can be aborted Yes, say cursor position at 0 Load a (LF) Echo it also Restore SL OUTCH2: CALL Print a space A,111B (HL) NZ,OUTCH2 OUTCHC LD AND DEL 2,OUTCHG CP C,OUTCHG (HL) TTYOUT CR OUTCHG: CALL CP JR NZ.OUTCHC NI, OUTCHR A, LF OUTCHR HL LF POP OUTCHC: LF NZ, PPRET TTSCAN Z, PPRET TTYGT1 CTLS ; No, restore character & return ; Is anything waiting for us? No, return Get what it was Is it pause? Yes, wait for something Control-C? CTLS Z,TTYGT1 CTLC Z,INLIN2 CTLZ Z,INLIN2 ESC Z,REENTQ ALT Z,REENTQ Control-C? Yes, echo it & go back to command Control-Z? Yes, echo it & go back to command Is it (SEC) to abort? Yes, go back to command level Check for (ALT) Yes, go back to command level Is it printable? No, don't save it Yes, save it for later Restore character & return C, PPRET (CHRBUF), A PPRET: POP Print string pointed to by HL String terminates on either 0 or ~7 Entry: HL points to string ;; OUTSTR: PUSH LD INC AF A,(HL) HL Save AF Get a character Get a character Bump pointer Is it he end? Yes, return Frint the character If -7 then go print more OR JR A Z,OUTST2 CALL JP POP RET OUTCHR P, OUTST1 AF ; If ; Restore AF OUTST2: Print string immediately following CALL String terminates on either 0 or "7 Entry: string is immediately after CALL (SP), HL OUTSTR (SP), HL ; Get string pointer (PC) ; Print the string ; Save PC back on stack ; & return EX OUTSTI: EX FORM single (advance) character A contains the character Save HL Point to character buffer Get whatever Zap the buffer Restore HL Was there anything? Yes, return Get a byte Mask off parity & return TTYGET: PUSH HL, CHRBUF A, (HL) (HL), 0 HL LD LD LD POP A NZ TTYIN OR RET CALL AND RET TTYGT1: Check if advance character ready Exit: A contains 0 if none, 2 flag is set A contains -1 if any, 2 flag is reset SCNCER: LD OR A, (CHRBUF) Get whatever in character buffer Was there anything? Get all ones incase so A,-1 : Yes, return : No, check if hardware ready SUBTTL *** Primitive Console I/O Routines *** Check if byte ready from current console Exit: A contains 0 if none, 2 flag is set A contains -1 if any, 2 flag is reset ``` ``` TTSCAN: IN AND A, HPORT HRDA ; Get status ; Check if anything there ; Nothing, return ; Load all ones RET LD RET ; & return Get a byte from current console Exit: A contains the byte TTYIN: CALL JR TTSCAN ; Check if anything there ; No, keep waiting Z.TTYIN A, HPORT+1 RET ; & return Output a byte to current console Entry: A contains the byte All registers preserved except F TTYIO: TTYOUT: AF A, HPORT HTBE Z,TTYOU1 AF CALL ; Save the character ; Get the status ; Is it ready yet? ; No, wait for ready ; Get character back ; Send the character ; then return IN AND JR POP TTYOU1: HPORT+1,A OUT CONGEN: EQU FORM ;; Command Routine Jump Table CMDJMP: DW BATCH DW CMDERR CMDERR DISPLY DW DW DW EXAMIN CMDERR GOTO CMDERR CMDERR CMDERR CMDERR CMDERR CMDERR MOVE NULLS OUTPUT Output to Port OUTPUT CMDERR FIND READ SETMEM CMDERR Cutput to Port Error Query Memory Read Binary Data Set Memory Error CMDERR VERIFY WRITE ; T - Error ; U - Error ; V - Verify Memory ; W - Write Binary Data ; X - Error ; Y - Error ; Z - Zap Memory CMDERR CMDERR DW ZAP SUBTTL *** JSYS Entry Jump Table *** JSYS Entry Jump Table This table is used for user entry processing; Each of the addresses listed below corresponds to a user function. JSYSJP: DW DW ; Re-enter the monitor ; Input a pure byte ; Check for pure byte ready ; Output a pure byte ; Input a buffered line ; Input a processed character ; Check for character ready ; Output a processed character ; Output a string ; Output in mediate string ; Output immediate string ; Output a (CR><LF) sequence ; Get console hardware info ; Set up a batch job ; Convert a single argument ; Convert two arguments ; Display number in HEX ; Total # of functions REENTE Re-enter the monitor TTYIN TTSCAN TTYOUT DW INLINE INCHR SCNCHR OUTSTR OUTSTI CRLF CONGEN BATCH1 ARGH ARG2 HEXOUT [$-JSYSJP]/2 JSYSJN EQU SUBTTL *** Constants & Lookup Tables *** OFFOOH ; Variables at the top page of RAM VARBS S EOU ; Reference for beginning of variables BREAK: ; DEBUG break transfer (JP nn) JSYSOP: DS 1 ; Current JSYS operation code DISPNT: DS SETPNT: DS ; Last DM command address ; Last SM command address ``` Cromemco GPIB Instruction Manual ``` ; Current console # ; If minus then Host else ; if 040H then CSP else ; is Quadart channel number ; Console print position ; Advance console character buffer ; Temporary storage for console # CONNUM: DS TTYPHP: DS CHRBUF: DS CONTMP: DS ; Return execution address 2 XCTADR: DS ; Reference for batch data block ; Indicates batch job in progress ; Indicates error occurred ; Batch command line pointer BATDAT EQU BATFLG: DS BATERR: DS BATPNT: DS ; File operations abort inhibit flag DS ; Console input line length ; Console input line buffer LINLEN EQU LINBUF: DS LINLEN+1 OFFEOH ; Where to load Stack Pointer STACK EQU ; User available free space XXXXXX EQU STACK SUBTTL *** Equates *** I/O Port Equates ;; HPORT ; Host Receive Data Available ; Host Transmitter Buffer Empty ; LsB/MSB 11 HRDA HTBE EQU 011 Square Binary FORM ASCII Equates ;; ; Control-C for job abort ; Control-E for physical <CR><LF>; Bell ; Backspace ; Horizontal Tab ; Line Feed ; Carriage Return ; Control-S for pause ; Control-U for delete line ; Control-Z for job abort ; Escape 003 005 007 008 009 010 CTLC CTLE BEL BS TAB LF CR CTLS CTLU CTLZ ESC MXCHR ALT DEL 013 019 021 026 027 '\\' ; Escape ; Multiple command terminator ; Altmode ; Delete character START ``` ``` GPIB Down Loader *** Setting Things Up & Doing The Transfer *** GPIBLD NAME 10-Nov-80 12:00 VERNUM RLSNUM 01 08 ; Version # ; Release # ; Start at standard TPA ; Skip the following ORG ; GPIB Control Port ; CROMIX version ID code ; Actual version number IPORT: DB DB RLSNUM, VERNUM Main signon message DB 'GPIB Down Loader - version ' DB VERNUM/10+'0', VERNUM%10+'0','.' DB RLSNUM/10+'0', RLSNUM%10+'0', \\R\S' SIGNON: Set up stack & print signon LD HL,(ENTRY+1) LD SP,HL LD DE,SIGNON START: LD ; Point to highest user RAM ; User it for stack ; Point to signon message ; CDOS: Print a String ; Print the signon message C, CFNSTR CALL Set up variables in case restarted DE, CMDS ; Copy constant command DE, CMDS ; string into variables HL, KCMDS ; incase of restart ; Copy made LD LD Get & set disk specs LD C,CFNGDX CALL ENTRY ; CDOS: Get current disk ; Petch ; Save it for the return trip ; Sour it of specified disk ; Get it for later ; Right now zap it out ; Was there one given? ; CDOS: Set new disk ; Yes, go set it up LD (CURDSK),A HL,TFCB E,(HL) (HL),0 DEC C, CFNSDX P, ENTRY CALL Misc. initialization CALL INIT ; Grab the GPIB's attention ; Set up the load address ADRSET FORM Look for & set up the file LD A,(TFCB+1) CP '?' FILE1: ; Get 1st character of filename; Is it wild? ; Load error message just in case; Yes, print message & abort; CDOS: Lookup a file; Point to FCB DE, ILWERM Z, EXITP C, CFNLKU DE, TFCB ; Point to FCB; ; Go get it; ; Is it there? ; Yes, continue; ; Get lst character of extension; ; Is there one? ; Error message just in case; ; Yes, no retries allowed; ; Default extension 3 characters; ; Point to where extension goes; ; Point to constant extension; ; Copy it in; ; Go try to get the file again ENTRY CALL NZ, FILE2 A, (TFCB+9) DE, FNF ERM NC, EXITP BC, 3 DE, TFCB+9 HL, KEXT LD JR ; Copy it in ; Go try to get the file again ; Get the # of records ; Are there any? ; Error message incase empty ; No, print message & abort FILEL JR LD A, (TFCB+15) FILE2: OR LD JR FORM DE, EMPERM Z, EXITP Transfer the disk file to the GPIB LD C,CFNRD ; CDOS: Read a record LD DE,TTCB ; Point to FCB CALL ENTRY ; Get the record OR A ; End of file? LD LD CALL OR JR LD LOOP: ; Get the record; ; End of file? ; Yes, stop ; Get the load address ; Save it for later ; Check if running ; into system memory ; Get load address back ; Load error message just in case ; Yes, print message & stop ; Point to command string ; Get high load address ; Convert to byte to ASCII ; Get low load address ; Convert to ASCII ; Point to next block ; to be loaded ; Save it for next time ; Get command string length ; Point to command string A NZ, EXIT HL, (LDADDR) PUSH HL DE, OFFOOH HL, DE HL DE, FTLERM LD JR NC, EXITP DE, CMDS1 A, H HEXASC LD LD CALL LD CALL LD A,L HEXASC DE,80H HL,DE (LDADDR),HL B,KCMDSL HL,CMDS ADD ``` ``` LD INC CALL CALL A,(HL) HL SEND Get a character Bump pointer Send the character LOOP1: Catch any echo Go until all string sent Point to data buffer Get a byte Send it to the GPIB BUCKET LOOP1 HL, TBUF A, (HL) SEND DJNZ LOOP2: LD CALL ; Bump pointer ; Go until end of buffer ; Catch prompt echo ; Go get next record INC NZ,LOOP2 BUCKET LOOP JR SUBTTL *** Special Subroutines *** set up address from TFCB2 DE,TFCB2+1 ; HL,DEFLDA ; ? Point to TPCB #2 ASCII ; Pefault load address ; Go get the address ; Save it for later ; Broke with a space? ; Yes, return ; Bad address argument ; Drop through to print message ADRSET: LD CALL LD HEXIN (LDADDR),HL CP RET ADRST1: LD '+1 DE, ILAERM Exit routines ; CDOS: Print a String; Print the whatever; Get command disk; CDOS: Set Disk; Save disk in E; Set it up in CDOS; Stop the job LD CALL LD C,CFNSTR ENTRY A,(CURDSK) C,CFNSDX EXITP: EXIT: LD LD CALL JP E, A ENTRY ABORT the GPIB , Get the GPIB address ; Save it in C ; Make sure at least 1 bit is 0 ; Get GPIB status ; Is there an GPIB there? ; Load message just in case ; No GPIB, error ; Attention retry count ; Send a C(R) ; to initialize ; Delay a full byte ; to allow the GPIB ; to respond ; Get the GPIB status ; Check if anything ready ; No, Try again ; Point to GPIB data port ; Get whatever ; Point to status port again ; Mask off, parity ; Is it a C(R)? ; Yes, we got it, ignore the rest ; Drop retry count & try again ; Error, GPIB not responding ; Print error & stop job Initialize communications with the GPIB LD A, (IPORT) ; Get ti LD C,A ; Save i IN A, (C) ; Get GI CP - 1 ; Is the ÍNIT: CP LD DE, NOSERM JR Z, EXITP B, 24 A, CR SEND INIT1: XOR DEC INIT2: NZ.INIT2 JR IN AND JR INC A, (C) RDA Z, INITC C A, (C) C ~^7 IN AND CP CR Z,BUCKET INIT1 JR DJNZ INITC: LD JR DE. ITOERM EXITP byte to the GPIB SEND: ; Save BC (use B for timeout) PUSH Save byte Timeout of 256 retries PUSH AF B. 0 Timeout of 256 retries Get GPIB status port Save it in C Get the GPIB status Is it ready for a byte? Yes, send it & return No, check timeout count Oops, GPIB crashed Print error message & abort Get byte back Point to data port Send the byte Restore BC & return A, (IPORT) C, A A, (C) TBE SEND1: IN AND NZ.SEND2 NZ,SEND2 SEND1 DE,ITOERM EXITP AF C DJNZ SEND2: POP OUT (C),A GPIB byte bucket LD A,(IPORT) LD C,A LD A,200 ; Get the GPIB status port ; Save it in C ; Delay 200 loops ; to allow the GPIB ; to bounce back ; Get the GPIB status ; Is anything there? ; No, return ; Point to data port ; Get & ignore what's there ; Point to status port again ; Go for next byte BUCKET: LD LD LD BUCKE1: DEC A NZ, BUCKEL JR IN A,(C) RDA AND A, (C) IN DEC BUCKET ``` ``` SUBTTL *** General Purpose Routines *** HBCNV: Verify if character in A is valid ASCII HEX Cy reset indicates OK, else error CALL NUMER ; Is numeric HEX: ; Is numeric? ; Is numeric? ; Yes, OK, return ; Is <"A"? ; Yes, return ; Is > "F"? ; Adjust flag ; Return w/ answer RET NC A RET CP CCF C 'F'+1 RET Convert byte in A to ASCII HEX string at DE PUSH AF , Save byte for right nybble RRCA ; Move left , nybble RRCA ; into RRCA ; into RRCA ; place CALL HEXAS1 ; Print left nybble POP AF ; Get byte back AND lillB ; Isolate right nybble ADD '0' ; Convert to ASCII CP '9'+1 ; Is it ASCII numeric? JR C,HEXAS2 ; Yes, Save it ADD 7 ; Adjust for A-F LD (DE), A ; Save the character RET ; Bump the pointer Return HEXASC: PUSH RRCA RRCA RRCA POP HEXAS1: AND HEXAS2: LD INC Convert ASCII HEX string at DE to binary number in HL LD A,(DE) CALL HEX HEXIN: ; Get a character ; Valid ASCII HEX? ; No, return w/ default ; Start with all 0s CALL LD HL.O ; Start with all 0s ; Get a character ; Valid ASCII HEX? ; No, finished ; Bump character pointer ; Convert character to binary ; Multiply HL ; times 16 to ; make room for ; the new nybble ; Add the nybble in ; Resave the lower byte ; Go for next digit HEXIN1: LD CALL RET A, (DE) HEX DE INC HBCNV ADD ADD ADD ADD HL, HL ADD Verify if character in A is valid ASCII numeric Cy reset indicates OK, else error CP '0' ; Is <"0"? RET C ; Yes, return CP '9'+1 ; Is >"9"? Adjust flag RET ; Return w/ answ ; NUMER: ; Yes, return ; Is >"9"? ; Adjust flag ; Return w/ answer SUBTTL *** Constants & Text *** ; Command string to the GPIB monitor KCMDS: DB 'R S80',CR ; "RxxxxS80<CR>" KCMDSL BQU S-KCMDS ; Length of string ; Error messages NOSERM: DB 'No GPIB in System\R\N$' ITOERM: DB 'GPIB Not Responding - Timeout\R\N$' ILAERM: DB 'Illegal Load Address\R\N$' ILWERM: DB 'Wild File Specification Illegal\R\N$' FTLERM: DB 'File Too Large\R\N$' EMPERM: DB 'File is Empty\R\N$' FNFERM: DB 'File Not Found - Check For Extension ".' KEXT: DB 'GPB"\R\NS' ; Secondary file extension SUBTTL *** Variables & Equates *** ; Misc. Small Variables CURDSK: DS 1 ; Command disk # ; Current load address 1 2 LDADDR: DS ; Command String Storage - "RxxxxS80<CR>" CMDS: DS 1 ; "R" CMDS1: DS 8 ; "xxxx8 ; "R" ; "xxxxS80<CR>" CDOS Location Equates EQU 0000H EQU 0005H EQU 005CH ABORT ; Program abort location ; CDOS CALL entry point ; Transient FCB #1 ; Transient FCB #2 ; Transient disk buffer ENTRY TFCB TFCB2 EQU EQU EQU TFCB+10H 0080H TBUF ``` ``` GPIB Processor Communicator *** Setting Things Up *** GPIBC TITLE SUBTTL NAME 12:00 10-Nov-80 VERNUM ; Version # ; Release # RLSNUM ORG JP ; Start at standard TPA ; Skip the following START 080H 082H 'D'-40H 0EDEDH RLSNUM, VERNUM IPORT: ; GPIB base address IPORTI: DB IPORTI: DB DEFTRM: DB DW DW ; Default terminator ; CROMIX version ID code ; Actual version number Main Signon message DB 'GPIB/HOST Communicator version' DB VERNUM/10+'0',VERNUM%10+'0','.' DB RLSNUM/10+'0',RLSNUM%10+'0','. SIGNON: Text to go to next line DB '\R\N$' CRLFM: DB ; " <CR> <LF>$" Set up stack & print signon message LD SP,(CDOS+1) ; Load SP as top of user area LD DE,SIGNON ; Point to the signon message CALL PRINT ; Print the signon message START: Determine terminator character ; Get the default terminator; Save it in D for later; Get lst character of default FCB; Is it a space; If so, use default terminator; Is specified terminator < "A"? Error if so, print message & abort; Is specified terminator > """? Error if so, print message & abort; Is specified terminator > """?; Error if so, print message & abort; Is the terminator < """?; Yes, assume OK; Is terminator now < "T"?; Yes, that's an illegal range; Zap ASCII bias to get Control CHR; Save the terminator in D; Get the GPIB address; Save it in C for general use A, (DEFTRM) D, A A, (TFCB+1) LD LD CP JR CP JR CP JR CP Z,DEFX2 C,BADTRM NC, BADTRM C, DEFX1 C,BADTRM 40H D,A A,(IPORT) C,A A,(IPORTI) E,A SUB LD LD DEFX1: DEFX2: LD LD ; Get a copy of the terminator in A ; Was the terminator "^"? ; Save the terminator around INIT ; Initialize communications if not ; Get the terminator back LD A,D CP PUSH CALL POP NZ, INIT SUBTTL *** Do The Actual Communications Transfers *** This loop processes characters from the HOST to the GPIB ECHO1: PUSH ; Save GPIB address C,CFNTTS CDOS ; Save GPB address; CDOS: Check for character ready; Petch; Is there anything?; CDOS: Get a character (no echo); Yes, get host character; Get back GPIB address; CNULYS: CALL OR LD CALL C, CFNTTI NZ, CDOS BC POP OR JR CP JR LD LD LD PUSH CALL POP LD JR A Z,ECHO2 D Z,EXITCR 'Y'-40H ; <NUL>? ; Yes, nothing there ; Abort in the middle? ; Yes, stop the job NZ, EC1 B, E E, C C, B DE INIT A,0DH EC2 'X'-40H NZ,EC2 EC1: B,E E,C C,B LD LD A, ODH B, A A, (C) TBE Z, ECHO2 LD Save the character Get the GPIB status Ready to receive? No, this character is lost Point to the GPIB data port Send the data to the GPIB Point to status port again EC2: IN AND (C),B ``` ``` This loop processes characters from the GPIB to the HOST ; Get GPIB status ; Anything there? ; No, check host ; No, point to the GPIB data port ECHO2: A, (C) AND Z,ECHO1 PUSH E, (C) Get the GPIB data IN ; Get the GPIB data; Point to status port again; Save GPIB address; CDOS: Output a character; Send it to the host; Get back GPIB address BC PILSH LD CALL POP POP BC DE ; Now go check host ECH01 This part ignores file commands from the GPIB (so GPIB will "Timeout" instead of hang) HL.15000 ECHO3: LD ECHO3A: DEC : Delay long ; enough so ; the GPIB ; gets the HL A,H LD L NZ, ECHO3A JR message JR ; then proceed as normal SUBTTL *** Termination & Print Routines *** Bad terminator error Print error message then stop ; Point to error message ; Drop through to print it BADTRM: LD Exit routines EXITP: CALL PRINT ; Print whatever string ; Point to new-line text ; Print it ; Abort the job DE, CRLFM EXITCR: LD CALL PRINT JP Print string pointed to by DE C,CFNOST CDOS ; CDOS: Print a string ; Print the string & return PRINT: LD SUBTTL *** Getting Aquainted With The GPIB *** Initialize communications with the GPIB This has the same effect as typing <CR> and waiting for a response ; Get GPIB status ; Make sure at least 1 bit is 0 ; Is an GPIB there? ; Load message in case not ; No, print message & stop A, (C) A, (C) INTT: CP DE, NISERM Z,EXITP A,080H (C),A JR DEC JR OUT INITO: NZ, INITO (C),A B,24 ; Initialize attention retry cour; Save retry count; Timeout of 256 status retries; Read the status port; Is it ready for a character? Yes, send it and return; No, check timeout count; Print error message and abort; Restore retry count; Load a <CR); Point to data port; Send the <CR); Point back to status port; Delay a full byte; To allow the GPIB; To respond; Get the GPIB status; Check if a character is ready; No, try again ; Initialize attention retry count LD INIT1: PUSH LD B,0 A, (C) TBE NZ, INIT3 INIT2: JR D.TNZ INIT2 INIT2 INITE BC A,CR C (C),A JR POP INIT3: LD INC OUT C A A NZ, INIT4 A, (C) RDA JR IN AND ; Check if a character is ready; No, try again; Point to data port; Get character; Point back to status port; Mask off parity bit; Is it a <CR?? Yes, we got it, return; Drop retry count and try again; Error, GPIB not responding Z, INITC A, (C) C_7 AND CR CP RET DJNZ LD JR INITC: INITE: DE, ITOERM EXITP SUBTTL *** Error Messages *** 'Illegal Terminator - Must be "A" through "^"\R\N' '("P" through "S" not allowed)$' 'No GPIB In System$' 'GPIB Not Responding - Timeout$' ILTERM: DB NISERM: DB ``` | | SUBTTL | *** Misc | EQUates | *** | | | |--------------------------------------|-------------------|--------------------------|---------|-----|--------------------------------------------------------------------------------------------------|--| | ABORT<br>CDOS<br>TFCB | EQU<br>EQU | 0000H<br>0005H<br>005CH | | | ; Abort back to CDOS<br>; CDOS CALL entry point<br>; Transient FCB | | | CFNOCH<br>CFNOST<br>CFNTTS<br>CFNTTI | EQU<br>EQU<br>EQU | 002<br>009<br>011<br>128 | | | ; Output a CHaracter<br>; Output a STring<br>; TTy Scan for character<br>; TTy Input a character | | | RDA<br>TBE | EQU<br>EQU | ^6<br>^7 | | • | ; Receive Data Available<br>; Transmitter Buffer Empty | | | CR | UQB | 013 | | | ; Carriage Return | | | | END | CTADE | | | | | Cromemco GPIB Instruction Manual #### Appendix E ### LIMITED WARRANTY Cromemco, Inc. ("'Cromemco") warrants this product against defects in material and workmanship to the original purchaser for ninety (90) days from the date of purchase, subject to the following terms and conditions. ### What is Covered By This Warranty: During the ninety (90) day warranty period Cromemco will, at its option, repair or replace this Cromemco product or repair or replace with new or used parts any parts or components, manufactured by Cromemco, which prove to be defective, provided the product is returned to an Authorized Cromemco ### How To Obtain Warranty Service: You should immediately notify IN WRITING your Authorized Cromemco Dealer or Cromemco of problems encountered during the warranty period. In order to obtain warranty service, first obtain a return authorization number by contacting the Authorized Cromemco Dealer from whom you purchased the product. Then attach to the product: - 1. Your name, address and telephone number, - 2. the return authorization number. - a description of the problem, and - proof of the date of retail purchase. Ship or otherwise return the product, transportation and insurance costs prepaid, to the Authorized Cromemco Dealer. If you are unable to receive warranty repair from the Authorized Cromemco Dealer from whom you purchased the product, you should contact Cromemco Customer Support at: Cromemco. Inc., 280 Bernardo Ave., Mountain View, Ca. 94043. ### What Is Not Covered By This Warranty: Cromemco does not warrant any products, components or parts not manufactured by Cromemco. This warranty does not apply if the product has been damaged by accident, abuse, misuse, modification or misapplication; by damage during shipment; or by improper service. This product is not warranted to operate satisfactorily with peripherals or products not manufactured by Cromemco. Transportation and insurance charges incurred in transporting the product to and from the Authorized Cromemco Dealer or Cromemco are not covered by this Warranty. ### Exclusion of Liability, Damages, and Other Warranties: THIS WARRANTY IS IN LIEU OF ALL OTHER WARRANTIES, WHETHER ORAL OR WRITTEN, EXPRESS OR IMPLIED. ANY IMPLIED WARRANTIES, INCLUDING IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE LIMITED IN DURATION TO NINE-TY (90) DAYS FROM THE DATE OF PURCHASE OF THIS PRODUCT. IF THIS PRODUCT IS NOT IN GOOD WORKING ORDER AS WARRANTED ABOVE, YOUR SOLE REMEDY SHALL BE REPAIR OR REPLACEMENT AS PROVIDED ABOVE. CROMEMCO SHALL NOT BE LIABLE FOR INCIDEN-TAL AND/OR CONSEQUENTIAL DAMAGES FOR THE BREACH OF ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING DAMAGE TO PROPERTY AND, TO THE EXTENT PERMITTED BY LAW, DAMAGES FOR PERSONAL INJURY, EVEN IF CROMEMCO HAS BEEN ADVISED OF THE POSSIBIL-ITY OF SUCH DAMAGES. THE AGENTS, DEALERS, AND EMPLOYEES OF CROMEMCO ARE NOT AUTHORIZED TO MAKE MODIFICATIONS TO THIS WARRANTY, OR ADDITIONAL WARRANTIES BINDING ON CROMEMCO ABOUT OR FOR PRODUCTS SOLD OR LICENSED BY CROMEMCO. ACCORDINGLY, ADDITIONAL STATEMENTS WHETHER ORAL OR WRITTEN EXCEPT SIGNED WRITTEN STATEMENTS FROM AN OFFICER OF CROMEMCO DO NOT CONSTITUTE WARRANTIES AND SHOULD NOT BE RELIED UPON. SOFTWARE, TECHNICAL INFORMATION AND FIRM-WARE ARE LICENSED ONLY BY A SEPARATE AGREEMENT ON AN "AS IS" BASIS. ### Limitation on Statute of Limitation and Transferability: This warranty and the statute of limitations shall run concurrently with any acceptance period. This warranty is not transferable. No suit, litigation, or action shall be brought based on the alleged breach of this warranty or implied warranties more than one year after the date of purchase in those jurisdictions allowing such a limitation, otherwise no such action shall be brought more than one year after the expiration of this warranty #### Other Important Provisions: Some states do not allow the exclusion or limitation of incidental or consequential damages or limitations on how long an implied warranty lasts, so the above limitation or exclusion may not apply to you. This warranty shall not be applicable to the extent that any provision of this warranty is prohibited by any federal, state or municipal law which cannot be preempted. This warranty gives you specific legal rights, and you may also have other rights which 7/82 Cromemco GPIB Instruction Manual Cromemoo GPTB Instruction Manual Landilly and a man growth in the control of con and parties of components, manufactured by Gromemon, which prelater as an form below: tou should immediately nearly RV WRITING your Authorized Cromemoo to obtain warranty service; lest octon a reum aeticorzation number of roer name, address and releptone number. The return authoropsion number, a description of the problem, and no ne objetante return the product. Mensportation and insurance costs be rerepair from the Authorized Cromenica Deater from whom you purphases of 280 Semando Avie - Meumain View, Ca. 940.e.3 Transmice Joes not warren any probucts, components or parts not make the secretary does not apply if the product has been damaged by according source. Yes improper service. This product is not war arted to operate salisfacturily with the contraction of the product of the contraction. on and insurance charges incurred in transporting the product to and to formity. Authority, Datesges, and Other Warranites. THIS WARRANTY IS IN LIEU OF ALL OTHER WARRANTIES, WHET WICLUDING IMPLIED WARRANTIES OF MERCHASE OF THIS AND ITY (90) DAYS FROM THE DATE OF PURCHASE OF THIS AND ASSOVE. YOUR SOLEREMEDY SHALL BE REPAIR OR REAL AND/OR CONSEQUENTIAL DAMAGES FOR THE BREALLIED WID, TO THE EXTENT PERMITTED BY LAW, DAMAGES IN HEAD ITY OF SUCH DAMAGES. THE AGENTS. DEALERS, AND THE ACCORDINGLY OR ADDITIONAL WARRANTIES BRICING ALS SECONDINGLY ADDITIONAL WARRANTIES BRICING AND SECONDINGLY ADDITIONAL WARRANTIES BRICING AND SECONDINGLY. ACORDINALT, ADUTEDIAL STATEMENTS WHETHER ORALS ROMEMOD DO NOT CONSTITUTE WARRANTIES AND STODI ARE ARE LICENSED ONLY BY A SEPARATE AGREEMENT O meation on Statute of Limitation and Transferability: his warrance and the statute of landlations shall rup denoumently with say, half be brought based on the alleged breach of this warranty se inglised towing such a faultation, otherwise no such action shall be brodget man | 現在の1821年10月2日 日本10月4日 1944 ve limitation of exclusion may not apply to you. This warranty shall not be applicable to the extent that any provision of this warranty tasts, so the federal, state or municipal law which cannot be preempted. This warranty gives you specific tegal lights, and you may also have other riphie which from state to state. 1 98 @, monitor command, 67 apt, mask bit, 37 apt, status bit, 36 atn, bus line, 39 atn, status bit, 38 auxiliary command register, 41 bi, mask bit, 34 bi, status bit, 32 block diagram, 5 bo, mask bit, 34 bo, status bit, 33 clr int, control bit, 17 command pass through register, 50 dacr, aux command, 43 dai, aux command, 46 daisy chain, cromemco interrupt priority, 56 dal, control bit, 48 dat, control bit, 48 data in register, ieee 488, 52 data out register, ieee 488, 53 data valid, external output, 29 dav, bus line, 39 host int, status bits dcas, mask bit, 37 dcas, status bit, 36 device primary address, 48 dm, monitor command, 67 e, monitor command, 68 edpa, control bit, 48 end, mask bit, 34 end, status bit, 33 eoi, bus line, 39 err, mask bit, 37 err, status bit, 36 ext int, status bit, 23 external input port, 28 external output port, 29 feoi, aux command, 44 fget, aux command, 44 g, monitor command, 691 Jugal Islands moul Jugaledal gate data, external input, 28 gbase address switch, 13 get, mask bit, 37 get, status bit, 35 gpib address register, 48 gpib address state port, 38 gpib bus status port, 39 gpib control port, 24 gpib int, status bit, 23 gpib interrupt mask 0 port, 34 gpib interrupt mask 1 port, 37 gpib interrupt status 0 port, 32 gpib interrupt status 0 port, 32 gpib interrupt status 1 port, 35 gpib mask, control bit, 25 gpib status port, 22 gpibb input data port, 26 gpibb input/output, 21 gpibb memory, 10 gpibb output data port, 27 gpibb, term definition, 4 gts, aux command, 45 handshake, ieee 488, 40 hdfa, aux command, 43 hdfe, aux command, 43 host control port, 16 host i/o, 12 host input data port, 18 host int, status bit, 23 host mask, control bit, 25 host output data port, 19 host status port, 14 ieee 488 bus address port, 30 ieee 488 bus address switch, 31 ieee std 488-1978, 7 ifc, bus line, 39 ifc, mask bit, 37 ifc, status bit, 36 initialization, gpibb, 9 input mask, control bit, 25 int gpibb, control bit, 16 int host, control bit, 24 int mask, control bit, 17 int pend, status bit, 15 int40, status bit, 32 int41, status bit, 32 interrupt mode, gpibb z-80A, 58 interrupt priority daisy chain, 56 interrupt, from external input port, 59 interrupt, from host, 59 interrupt, from tms 9914, 59 interrupt, to host, 55 interrupt, vector to host, 56 interrupts, gpibb, 55 lacs, status bit, 38 lads, status bit, 38 llo, status bit, 38 lon, aux command, 44 lpas, status bit, 38 m, monitor command, 69 ma, mask bit, 37 ma, status bit, 36 mac, mask bit, 34 mac, status bit, 33 monitor commands, 67 nbaf, aux command, 44 ndac, bus line, 39 nmint host, control bit, 24 nrfd, bus line, 39 o, monitor command, 70 parallel poll register, 51 power on clear, 9 pts, aux command, 46 q, monitor command, 70 r, monitor command, 70 ram memory, 10 rda, status bit, 14, 22 read strobe, external input, 28 rem, status bit, 38 ren, bus line, 39 reset state, 9 reset, control bit, 16 rhdf, aux command, 43 rlc, aux command, 46 rlc, mask bit, 34 rlc, status bit, 33 rom memory, 10 rom0, rom1, 10 rpp, aux command, 45 rqc, aux command, 46 rsv, command bit, 49 rtl, aux command, 44 mac, status bit, 33 serial poll register, 49 shdw, aux command, 47 sic, aux command, 46 sm, monitor command, 71 sml, S-100 bus signal, 24 spas, mask bit, 34 spas, status bit, 33 sre, aux command, 46 srq, bus line, 39 srq, mask bit, 37 srq, status bit, 36 stdl, aux command, 47 switch swl, 31 switch sw2, 13 swrst, aux command, 42 tacs, status bit, 38 tads, status bit, 38 tbe, status bit, 14, 22 tca, aux command, 45 tcs, aux command, 45 technical specifications, 1 tms 9914 registers, 31 ton, aux command, 44 tpas, status bit, 38 ucg, mask bit, 37 ucg, status bit, 36 ulpa, status bit, 38 v, monitor command, 72 w, monitor command, 72 wait line, 28, 29 z, monitor command, 73