# Interfacing the DP8344 to Twinax

### OVERVIEW

The DP8344, or **Biphase Communications Processor** from National Semiconductor's Advanced Peripherals group brings a new level of system integration and simplicity to the IBM® connectivity world. Combining a 20 MHz RISC architecture CPU with a flexible multi-protocol transceiver and remote interface, the BCP is well suited for IBM 3270, 3299 and 5250 protocol interfaces. This Application Note will show how to interface the BCP to twinax, as well as provide some basics about the IBM 5250 environment.

# 5250 ENVIRONMENT

The IBM 5250 environment encompasses a family of devices that attach to the IBM System/34, 36 and 38 mid-size computer systems. System unit model numbers include the 5360, 5362, 5364, 5381, and 5382, and remote controller models 5294 and 5251 model 12. The system units have integral work station controllers and some may support up to 256 native mode twinax devices locally. Native mode twinax devices are ones that connect to one of these host computers or their remote control units via a multi-drop, high speed serial link utilizing the 5250 data stream. This serial link is primarily implemented with twinaxial cable but may be also found using telephone grade twisted pair. Native mode 5250 devices include mono-chrome, color and graphics terminals, as well as a wide range of printers and personal computer emulation devices.

# TWINAX AS A TRANSMISSION MEDIA

The 5250 environment utilizes twinax in a multi-drop configuration, where eight devices can be "daisy-chained" over a total distance of 5000 ft. and eleven splices, (each physical device is considered a splice) see *Figure 1*. Twinax can be routed in plenums or conduits, and can be hung from poles between buildings (lightning arrestors are recommended for this). Twinax connectors are bulky and expensive, but are very sturdy. Different sorts may be purchased from IBM or a variety of third party vendors, including Amphenol. Twinax should not be spliced; to connect cables together both cables should be equipped with male connectors and a quickdisconnect adapter should be used to join them (Amphenol #82-5588). National Semiconductor Application Note 516 Thomas J. Quigley March 1988



Twinaxial cable is a shielded twisted pair that is nearly  $\frac{1}{2}$  of an inch thick. This hefty cable can be either vinyl or teflon jacketed and has two internal conductors encased in a stiff polethylene core. The cable is available from BELDEN (type  $\frac{9}{2}$ 9307) and other vendors, and is significantly more expensive than coax.

The cable shield must be continuous throughout the transmission system, and be grounded at the system unit and each station. Since twinax connectors have exposed metal connected to their shield grounds, care must be taken not to expose them to noise sources. The polarity of the two inner conductors must also be maintained throughout the transmission system.

The transmission system is implemented in a balanced current mode; every receiver/transmitter pair is directly coupled to the twinax at all times. Data is impressed on the transmission line by unbalancing the line voltage with the driver current. The system requires passive termination at both ends of the transmission line. The termination resistance value is given by:

- $R_t = Z_{O/2}$ ; where
- Rt: Termination Resistance
- Zo: Characteristic Impedance

In practice, termination is accomplished by connecting both conductors to the shield via 54.9 $\Omega$ , 1% resistors; hence the characteristic impedance of the twinax cable of 107 $\Omega$  ±5% at 1.0 MHz. Intermediate stations must not terminate the line; each is configured for "pass-through" instead of "terminate" mode. Stations do not have to be powered on to pass twinax signals on to other stations; all of the receiver/ transmitter pairs are DC coupled. Consequently, devices must never output any signals on the twinax line during power-up or down that could be construed as data, or interfere with valid data transmission between other devices.

#### WAVEFORMS

The bit rate utilized in the 5250 protocol is 1 MHz  $\pm 2\%$  for most terminals, printers and controllers. The IBM 3196 dis-



# nterfacing the DP8344 to Twinax

play station has a bit rate of 1.0368 MHz  $\pm$  0.01%. The data are encoded in biphase, NRZI (non-return to zero inverted) manner; a "1" bit is represented by a positive to negative transition, a "0" is a negative to positive transition in the center of a bit cell. This is opposite from the somewhat more familiar 3270 coax method. The biphase NRZI data is encoded in a pseudo-differential manner; i.e. the signal on the "A" conductor is subtracted from the signal on "B" to form the waveform shown in Figure 2. Signals A and B are not differentially driven; one phase lags the other in time by 180°. Figures 3 and 4 show actual signals taken at the driver and receiver after 5000 ft. of twinax, respectively.

The signal on either the A or B phase is a negative going pulse with an amplitude of -0.32V  $\pm 20\%$  and duration of 500  $\pm 20$  ns. During the first 250  $\pm 20$  ns, a predistortion or pre-emphasis pulse is added to the waveform yielding an amplitude of  $-1.6V \pm 20\%$ . When a signal on the A phase is considered together with its B phase counterpart, the resultant waveform represents a bit cell or bit time, comprised of two half-bit times. A bit cell is 1  $\mu s$   $\pm 20$  ns in duration and must have a mid bit transition. The mid bit transition is the synchronizing element of the waveform and is key to maintaining transmission integrity throughout the system.





TL/F/9635-3 FIGURE 3. Signal at the Driver



TL/F/9635-4

FIGURE 4. Signal at the Receiver

The signal shown was viewed in the same manner as Figure 3. The severe The signal shown was taken with channel 1 of an oscilloscope connected to phase B, channel 2 connected to A, and then channel 2 inverted and added to channel 1.

attenuation is due to the filtering effects of 5000 ft. of twinax cable.

As previously mentioned, the maximum length of a twinax line is 5000 ft. and the maximum number of splices in the line is eleven. Devices count as splices, so that with eight devices on line, there can be four other splices. The signal 5000 ft. and eleven splices from the controller has a minimum amplitude of 100 mV and a slower edge rate. The bit cell transitions have a period of 1  $\mu$ s  $\pm$ 30 ns.

# 5250 BIT STREAM

The 5250 Bit stream used between the host control units and stations on the twinax line consists of three separate parts; a bit synchronization pattern, a frame synchronization pattern, and one or more command or data frames. The bit sync pattern is typically five one bit cells. This pattern serves to charge the distributed capacitance of the transmission line in preparation for data transmission and to synchronize receivers on the line to the bit stream. Following the bit sync or line quiesce pattern is the frame sync or line violation. This is a violation of the biphase, NRZI data mid bit transition rule. A positive going half bit, 1.5 times normal duration, followed by a negative going signal, again 1.5 times normal width, allows the receiving circuitry to establish frame sync.

Frames are 16 bits in length and begin with a sync or start bit that is always a 1. The next 8 bits comprise the command or data frame, followed by the station address field of three bits, a parity bit establishing even parity over the start, data and address fields, and ending with a minimum of three fill bits (fill bits are always zero). A message consists of a bit sync, frame sync, and some number of frames up to 256 in total. A variable amount of inter-frame fill bits may be used to control the pacing of the data flow. The SET MODE command from the host controller sets the number of bytes of zero fill sent by attached devices between data frames. The zero fill count is usually set to zero. The number of zero fill bits injected between frames by the BCP is set by the Fill Bit select register {FBR}. This register contains the one's complement of the number of BITS sent, not bytes.

Message routing is accomplished through use of the threebit address field and some basic protocol rules. As mentioned above, there is a maximum of eight devices on a given twinax line. One device is designated the controller or host and the remaining seven are slave devices. All communication on the twinax line is host initiated and half duplex. Each of the seven devices is assigned a unique station address from zero to six. Address seven is used for an End Of Message delimiter, or EOM. The first or only frame of a message from controller to device must contain the address of the device. Succeeding frames do not have to contain the same address for the original device to remain selected, although they usually do.

The last frame in a sequence must contain the EOM delimiter. For responses from the device to the controller, the responding device places its own address in the address field in frames 1 to (n - 1),where n  $\leq$  256, and places the EOM delimiter in the address field of frame n. However, if the response to the controller is only one frame, the EOM delimiter is used. The controller assumes that the responding devices was the one addressed in the initiating command.

Responses to the host must begin in 60  $\pm$ 20  $\mu$ s, although some specifications state a 45  $\pm$ 15  $\mu$ s response time. In practice, controllers do not change their time out values per device type so that anywhere from 30  $\mu$ s to 80  $\mu$ s response times are appropriate.

# DRIVER CIRCUITS FOR THE DP8344

The transmitter interface on the DP8344 is sufficiently general to allow use in 3270, 5250, and 8-bit transmission systems. Because of this generality, some external hardware is needed to adapt the outputs to form the signals necessary to drive the twinax line. The chip provides three signals: DATA-OUT DATA-DLY and TX-ACT DATA-OUT is biphase serial data (inverted). DATA-DLY is the biphase serial data output (non-inverted) delayed one-quarter bit-time. TX-ACT, or transmitter active, signals that serial data is being transmitted when asserted. DATA-OUT and DATA-DLY can be used to form the A and B phase signals with their three levels by the circuit shown in Figure 5. TX-ACT is used as an external transmitter enable. The BCP can invert the sense of the DATA-OUT and DATA-DLY signals by asserting TIN [TMR[3]]. This feature allows both 3270 and 5250 type biphase data to be generated, and/or utilization of inverting or non-inverting transmitter stages.



The current mode drive method used by native twinax devices has both distinct advantages and disadvantages. Current mode drivers require less power to drive properly terminated, low-impedance lines than voltage mode drivers. Large output current surges associated with voltage mode drivers during pulse transition are also avoided. Unwanted current surges can contribute to both crosstalk and radiated emission problems. When data rate is increased, the surge time (representing the energy required to charge the distributed capacitance of the transmission line) represents a larger percentage of the driver's duty cycle and results in increased total power dissipation and performance degradation.

A disadvantage of current mode drive is that DC coupling is required. This implies that system grounds are tied together from station to station. Ground potential differences result in ground currents that can be significant. AC coupling removes the DC component and allows stations to float with respect to the host ground potential. AC coupling can also be more expensive to implement.

Drivers for the 5250 environment may not place any signals on the transmission system when not activated. The poweron and off conditions of drivers must be prevented from causing noise on the system since other devices may be in operation. *Figure 5* shows a "DC power good" signal enabling the driver circuit. This signal will lock out conduction in the drivers if the supply voltage is out of tolerance.

Twinax signals can be viewed as consisting of two distinct phases, phase A and phase B, each with three levels, off, high and low. The off level corresponds with 0 mA current being driven, the high level is nominally 62.5 mA,  $\pm 20\% - 30\%$ , and the low level is nominally 12.5 mA,  $\pm 20\% - 30\%$ . When these currents are applied to a properly terminated transmission line the resultant voltages impressed at the driver are: off level is 0V, low level is 0.32V  $\pm 20\%$ , high level is 1.6V  $\pm 20\%$ . The interface must provide for switching of the A and B phases and the three levels. A bi-modal constant current source for each phase can be built that has a TTL level interface for the BCP.

An integrated solution can be constructed with a few current mode driver parts available from National and Texas Instruments. The 75110A and 75112 can be combined to provide both the A and B phases and the bi-modal current drive required as in *Figure 5*. The external logic used adapts the coax oriented BCP outputs to the twinax interface circuit, and prevents spurious transmissions during power-up or down. The serial NRZ data is inverted prior to being output by the BCP by setting TIN, {TMR[3]}.

#### **RECEIVER CIRCUITS**

The pseudo-differential mode of the twinax signals make receiver design requirements somewhat different than the coax 3270 world. Hence, the analog receiver on the BCP is not well suited to receiving twinax data. The BCP provides both analog inputs to an on-board comparator circuit as well as a TTL level serial data input, TTL-IN. The sense of this serial data can be inverted by the BCP by asserting RIN, {TMR[4]}.

The external receiver circuit must be designed with care to ensure reliable decoding of the bit-stream in the worst environments. Signals as small as 100 mV must be detected. In order to receive the worst case signals, the input level switching threshold or hysteresis for the receiver should be nominally 29 mV  $\pm$  20%. This value allows the steady state, worst case signal level of 100 mV 66% of its amplitude before transitioning.

To achieve this, a differential comparator with complementary outputs can be applied, such as the National LM361. The complementary outputs are useful in setting the hysteresis or switching threshold to the appropriate levels. The LM361 also provides excellent common mode noise rejection and a low input offset voltage. Low input leakage current allows the design of an extremely sensitive receiver, without loading the transmission line excessively.

In addition to good analog design techniques, a low pass filter with a roll-off of approximately 1 MHz should be applied to both the A and B phases. This filter essentially conducts high frequency noise to the opposite phase, effectively making the noise common mode and easily rejectable.

Layout considerations for the LM361 include proper bypassing of the  $\pm$ 12V supplies at the chip itself, with as short as possible traces from the pins to 0.1  $\mu F$  ceramic capacitors. Using surface mount chip capacitors reduces lead inductance and is therefore preferable in this case. Keeping the input traces as short and even in length is also important. The intent is to minimize inductance effects as well as standardize those effects on both inputs. The LM361 should have as much ground plane under and around it as possible. Trace widths for the input signals especially should be as wide as possible; 0.1 inch is usually sufficient. Finally, keep all associated discrete components nearby with short routing and good ground/supply connections.

Design equations for the LM361 in a 5250 application are shown here for example. The hysteresis voltage,  $V_h$ , can be expressed the following way:

where

V<sub>h</sub> — Hysteresis Voltages, Volts

- R<sub>in</sub> Series Input Resistance, Ohms
- R<sub>f</sub> Feedback Resistance, Ohms
- Cin Input Capacitance, Farads
- Vrio-Receiver Input Offset Voltage, Volts
- Voh-Output Voltage High, Volts
- Vol Output Voltage Low, Volts

The input filter values can be found through this relationship:

 $V_{cin} = V_{in1} - V_{in2/1} + jwC_{in} (R_{in1} + R_{in2})$ 

where  $R_{in1} = R_{in2} = R_{in}$ :

Fro = 
$$W/2\pi$$
  
Fro =  $1/(2\pi \times \text{Bin} \times \text{Cin})$ 

$$FIO = I7(2\pi \times H_{in} \times O_{in})$$

 $m C_{in}=$  1/(2 $\pi imes
m R_{in} imes
m Fr$ o)

where

 $V_{\text{in1}}, V_{\text{in2}}-\!\!-$  Phase A and B signal voltages, Volts

V<sub>cin</sub> — Voltage across C<sub>in</sub>, or the output of the filter, Volts

 $R_{in1}$ ,  $R_{in2}$ — Input resistor values,  $R_{in1} = R_{in2}$ , Ohms

Fro — Roll-Off Frequency, Hz

W - Frequency, Radians

The roll-off frequency, Fro, should be set nominally to 1 MHz to allow for transitions at the transmission bit rate. The transition rate when both phases are taken together is 2 MHz, but then  $R_{in1}$  and  $R_{in2}$  must be considered, so:

$$\begin{split} &\text{Fro2} = 1/(2\pi\times(\text{R}_{\text{in1}}+\text{R}_{\text{in2}})\times\text{C}_{\text{in}})\\ &\text{or,}\\ &\text{Fro2} = 1/(2\pi\times2\times\text{R}_{\text{in}}\times\text{C}_{\text{in}})\\ &\text{where Fro2} = 2\times\text{Fro, yielding the same results.} \end{split}$$

The following table shows the range of values expected:

| TABLE I           |            |            |            |       |           |  |  |  |  |  |
|-------------------|------------|------------|------------|-------|-----------|--|--|--|--|--|
| Value             | Maximum    | Minimum    | Nominal    | Units | Tolerance |  |  |  |  |  |
| R <sub>IN</sub>   | 4.935E+03  | 4.465E+03  | 4.700E+03  | Ω     | 0.05      |  |  |  |  |  |
| R <sub>F</sub>    | 8.295E+05  | 7.505E+05  | 7.900E+05  | Ω     | 0.05      |  |  |  |  |  |
| C <sub>IN</sub>   | 4.4556E-11 | 2.6875E-11 | 3.3863E-11 | F     |           |  |  |  |  |  |
| V <sub>OH</sub>   | 5.250E+00  | 4.750E+00  | 5.000E+00  | V     |           |  |  |  |  |  |
| V <sub>OL</sub>   | 4.000E-01  | 2.000E-01  | 3.000E-01  | V     |           |  |  |  |  |  |
| V <sub>IN+</sub>  | 1.920E+00  | 1.000E-01  |            | V     |           |  |  |  |  |  |
| V <sub>IN</sub> - | 1.920E+00  | 1.000E-01  |            | V     |           |  |  |  |  |  |
| V <sub>RIO</sub>  | 5.000E-03  | 0.000E+00  | 1.000E-03  | V     |           |  |  |  |  |  |
| R                 | 6.533E-03  | 5.354E-03  | 5.914E-03  | Ω     |           |  |  |  |  |  |
| Fro               | 1.200E+06  | 8.000E+05  | 1.000E+06  | Hz    | 0.2       |  |  |  |  |  |
| V <sub>H</sub>    | 3.368E-02  | 2.691E-02  | 2.880E-02  | V     |           |  |  |  |  |  |
| Xc                | 7.4025E+03 | 2.9767E+03 | 4.7000E+03 | Ω     |           |  |  |  |  |  |

The BCP has a number of advanced features that give designers much flexibility to adapt products to a wide range of IBM environments. Besides the basic multi-protocol capability of the BCP, the designer may select the inbound and outbound serial data polarity, the number of received and transmitted line quiesces, and in 5250 modes, a programmable extension of the TX-ACT signal after transmission.

The polarity selection on the serial data stream is useful in building single products that handle both 3270 and 5250 protocols. The 3270 biphase data is inverted with respect to 5250.

Selecting the number of line quiesces on the inbound serial data changes the number of line quiesce bits that the receiver requires before a line violation to form a valid start sequence. This flexibility allows the BCP to operate in extremely noisy environments, allowing more time for the transmission line to charge at the beginning of a transmission. The selection of the transmitted line quiesce pattern is not generally used in the 5250 arena, but has applications in 3270. Changing the number of line quiesces at the start of a line quiesce pattern may be used by some equipment to implement additional repeater functions, or for certain inflexible receivers to sync up.

The most important advanced feature of the BCP for 5250 applications is the programmable TX-ACT extension. This feature allows the designer to vary the length of time that the TX-ACT signal from the BCP is active after the end of a transmission. This can be used to drive one phase of the

twinax line in the low state for up to 15.5 µs. Holding the line low is useful in certain environments where ringing and reflections are a problem, such as twisted pair applications. Driving the line after transmitting assures that receivers see no transitions on the twinax line for the specified duration. The transmitter circuit shown in Figure 5 can be used to hold either the A or B phase by using the serial inversion capability of the BCP in addition to swapping the A and B phases. Choosing which phase to hold active is up to the designer; 5250 devices use both. Some products hold the A phase, which means that another transition is added after the last half bit time including the high and low states, with the low state helf for the duration, see Figure 6. Alternatively, some products hold the B phase. Holding the B phase does not require an extra transition and hence is inherently auieter.



TL/F/9635-6

The signal was viewed in the same manner as *Figures 3* and 4. The lefthand portion of the signal is a transmitting device utilizing line hold on phase A. The right hand side shows the IBM style (phase B) line hold.

To set the TX-ACT hold feature, the upper five bits of the Auxilliary Transceiver Register, {ATR [3–7]}, are loaded with one of thirty-two possible values. The values loaded select a TX-ACT hold time between 0  $\mu$ s and 15.5  $\mu$ s in 500 ns increments.

#### SOFTWARE INTERFACE

The BCP was designed to simplify designing IBM communications interfaces by providing the specific hardware necessary in a highly integrated fashion. The power and flexibility of the BCP, though, is most evident in the software that is written for it. Software design for the BCP deserves careful attention.

When designing a software architecture for 5250 terminal emulation, for example, one concern the designer faces is how to assure timely responses to the controller's commands. The BCP offers two general schemes for handling the real time response requirements of the 5250 data stream: interrupt driven transceiver interface mode, and polled transceiver interface mode. Both modes have strengths that make them desirable. The excellent interrupt response and latency times of the BCP make interrupts very useful in most 5250 applications.

Although factors such as data and instruction memory wait states and remote processors waiting BCP data memory accesses can degrade interrupt response times, the minimum latency is 2.5 T-states. The BCP samples all interrupt sources by the falling edge of the CPU clock; the last falling edge prior to the start of the next instruction determines whether an interrupt will be processed. When an interrupt is recognized, the next instruction in the present stream is not executed, but its address is pushed on the address stack. A two T-state call to the vector generated by the interrupt type and the contents of {IBR} is executed and [GIE] (Global Interrupt Interrupt request or if the current instruction is longer than 2 bytes, the interrupt latency is extended.

Running in an interrupt driven environment can be complex when multiple sessions are maintained by the same piece of code. The software has the added overhead of determining the appropriate thread or session and handling the interrupt accordingly. For a multi-session 5250 product, the transceiver interrupt service routines must determine which session is currently selected through protocol inferences and internal semaphores to keep the threads separate and intact.

In a polled environment, the biggest difficulty in designing software is maintaining appropriate polling intervals. Polling too often wastes CPU bandwidth, not polling frequently enough loses data and jeopardizes communication integrity. Standard practice in servicing polled devices is to count CPU clock cycles in the program flow to keep track of when to poll. A program change can result in lengthy recalculations of polling intervals and regualifications of program functionality. Using the programmable timer on board the BCP to set the polling interval alleviates the need to count instructions when code is changed or added. In both polled or interrupt environments, the latency effects of remote processors waiting memory accesses must be limited to a known length of time and figured into both polling intervals and worst case interrupt latency calculations. Using the programmable timer on the BCP makes both writing and maintaining polled software easier.

# SOFTWARE ARCHITECTURE FOR 5250 EMULATION

The 5250 data rate is much lower than that of the 3270 data stream, hence it is possible for the BCP to emulate all seven 5250 sessions with a CPU frequency of 8 MHz. Choosing a 16 MHz crystal allows the transceiver to share the CPU clock at OCLK/2, eliminating an extra oscillator circuit. The 8 MHz rate yields a 125 ns T-state, or 250 ns for most instructions. Interrupt latency is typically one instruction (assuming no wait states or remote accesses) which is suitable for 5250 operation. If more speed is desired, the CPU could be switched to 16 MHz operation.

#### A MULTI-MODE TRANSCEIVER

The BCP provides two 5250 protocol modes, promiscuous and non-promiscuous. These two modes afford the designer a real option only when the end product will attach to one 5250 address at a time. The non-promiscuous mode is configured with an address in the  $\{ATR\}$  register and only re-

ceives messages whose first frame address matches that address, or an error occurs in the first frame of the message. Filtering out unwanted transmissions to other addresses leaves more CPU time for other non-protocol related tasks, but limits the device to one address at a time. The promiscuous mode allows messages to any and all addresses to be received. Resetting the transceiver during a message destined to another device forces the transceiver to begin looking for a start sequence again, effectively discarding the entire unwanted message. Because of its flexibility, the promiscuous mode is used in this illustration.

# REAL TIME CONSIDERATIONS

Choosing a scheme for servicing the transceiver is basic to the design of any emulation device. The BCP provides both polled and interrupt driven modes to handle the real time demands of the chosen protocol. In this example, the interrupt driven approach is used. This implies the extra overhead of setting up interrupt vectors and initializing the interrupt masks appropriately. This approach eliminates the need to figure polling intervals within the context of other CPU tasks.

#### **5250 CONFIGURATION**

Configuring a complex device like the BCP can be difficult until a level of familiarity with the device is reached. To help the 5250 product designer through an initial configuration, a register by register description follows, along with the reasons for each configuration choice. Certainly, most applications will use different configurations than the one shown here. The purpose is to illustrate one possible setup for a 5250 emulation device.

There are two major divisions in the BCP's configuration registers: CPU specific and transceiver specific ones.

# CPU SPECIFIC CONFIGURATION REGISTERS:

{DCR}—Device Control Register—This register controls the clocks and wait states for instruction and data memory. Using a value of H#A0 sets the CPU clock to the OCLK/2 rate, the transceiver to OCLK/2, and no wait states for either memory bank. As described above, the choice of a 16 MHz crystal and configuring this way allows 8 MHz operation now, with a simple software change for straight 16 MHz operation in the future.

{ACR}—Auxiliary Control Register—Loading this register with H#20 sets the timer clock source to CPU-CLK/2, sets [BIC], the Bidirectional Interrupt Control to configure BIRQ as an input, allows remote accesses with [LOR] cleared, and disables all maskable interrupts through [GIE] low. When interrupts are unmasked in {ICR}, [GIE] must be set high to allow interrupts to operate. [GIE] can be set and cleared by writing to it, or through a number of instructions including RET and EXX.

(IBR)—Interrupt Base Register—This register must be set to the appropriate base of the interrupt vector table located in data RAM. The DP8344 development card and monitor software expect [IBR] to be at H#1F, making the table begin at H#1F00. The monitor software can be used without the interrupt table at H#1F00, but doing so is simplest for this illustration.

{ICR}—Interrupt Control Register—This register contains both CPU and transceiver specific controls. From the CPU point of view, the interrupt masks are located here. In this illustration, the system requires receiver, transmitter, BIRQ, and timer interrupts, so that in operation those interrupt bits should be unmasked. For initialization purposes, though, interrupts should be masked until their vectors are installed and the interrupt task is ready to be started. Therefore, loading [ICR] with H#7F is prudent. This also sets the receiver interrupt source, but that will be discussed in the next section.

# TRANSCEIVER CONFIGURATION REGISTERS:

[TMR]-Transceiver Mode Register-This register controls the protocol selection, transceiver reset, loopback, and bit stream inversion. Loading this register with H#0D sets up the receiver in 5250 promiscuous mode, inverts serial data out, does not invert incoming serial data, does not allow the transmitter and receiver to be active at the same time, disables loopback, and does not reset the transceiver. Choosing to set [RIN] low assumes that serial data will be presented to the chip in NRZI form. Not allowing the receiver and transmitter to operate concurrently is not an issue in 5250 emulation, since there is no defined repeater function in the protocol as in 3270 (3299). Bits [B5, 6], [RPEN] and [LOOP] are primarily useful in self testing, where [LOOP] routes the transmitted data stream into the receiver and simultaneous operation is desirable. Please note that for loopback operation, [RIN] must equal [TIN]. [TRES] is used regularly in operation, but should be left off when not specifically needed.

{TCR}-Transceiver Command Register-This register has both configuration and operation orientated bits, including the transmitted address and parity bits. For this configuration, the register should be set to H#00 and the specific address needed summed into the three LSBs, as appropriate. The [SEC] or Select Error Codes bit is used to enable the {ECR} register through the {RTR} transceiver FIFO port, and should be asserted only when an error has been detected and needs to be read. [SLR], or Select Line Receiver is set low to enable the TTL-IN pin as the serial data in source. The BCP's on chip comparator is best suited to transformer coupled environments, and National's LM361 high speed differential comparator works very well for the twinax line interface. [ATA], or Advance Transmitter Active is normally used in the 3270 modes to change the form of the first line guiesce bit for transmission. Some twinax products use a long first line quiesce bit, although it is not necessary. The lower four bits in {TCR} are used to form the frame transmitted when data is written into {RTR}, the transceiver FIFO port. Writing into {RTR} starts the transmitter and/or loads the transmit FIFO. The least significant three bits in {TCR} form the address field in that transmitted frame, and B3, [OWP] controls the type of parity that is calculated and sent with that frame. [OWP] set to zero calculates even parity over the eight data bits, address and sync bit as defined in the IBM 5250 PAI.

{ATR}—Auxilliary Transceiver Register—Since this application is configured for promiscuous mode, the {ATR} register serves only to set the line hold function time. In non-promiscuous mode, the three least significant bits of this register are the selected address. Setting this register to H#50 allows a 5  $\mu$ s hold time and clears the address field to 0, since promiscuous mode is used.

{FBR}—Fill Bit Register—This register controls the number of biphase zeros inserted between concatenated frames when transmitting. This register should be set upon reception of the SET MODE instruction from the host. {FBR} contains the one's complement of the number of inter-frame fill bits so that H#FF sends no extra fill bits.

{ICB}-Interrupt Control Begister-As discussed in the CPU configuration section, this register sets [RIS] or Receiver Interrupt Select as well as the interrupt mask. Setting the register to H#7F selects [DA + ERR], Data Available or transceiver ERRor, as the interrupt source. This interrupt is asserted when either a valid frame has been clocked into the receive FIFO or an error has occurred. Other interrupt options are available including: [RA], Receiver Active; and [RFF + ERR], Receive FIFO Full or transceiver ERRor. For 5250 protocols the [DA + ERR] is most efficient. The [RFF + ERR] interrupt will not assert until the FIFO is full ... regardless of whether the incoming message is single or multi-frame. [RA] provides plenty of notice that a frame is incoming, but due to the speed of the BCP, this advanced warning is not generally needed. [DA + ERR] provides a notification just after the parity bit has been decoded from the incoming frame which is almost 3 µs prior to the end of the frame. With the CPU running at 8 MHz, that allows typically nine instructions ([(4 \* 3) - 3)]) for interrupt latency, trap and bank switch after interrupting.

# MULTI-SESSION POWER

Handling multiple sessions in software is not trivial, and making the receiver service routines interrupt driven complicates the task further. The BCP is so fast, that at 8 MHz handling a multi-frame message by interrupting on the first frame and polling for succeeding frames is very inefficient. To maximize bandwidth for non-protocol related tasks, the CPU should handle each frame separately on interrupt and exit. To do this, a number of global state variables must be maintained. Since the alternate B register bank is primarily used for transceiver functions anyway, dedicating the other registers in that bank permanently as state variables is acceptable in most cases; doing so speeds and simplifies access to them. Defining the following registers as: enables the software to keep track of the various states the protocol must handle.

The active address bits in GP5' allow individual addresses to be active, or any combination of addresses. When interrupted by a message to a non-selected address, [TRES] is toggled to reset the receiver until the beginning of the next message is detected. [B7] is used to determine if any particular address is "selected" and in the process of receiving data. The selected flag is set and cleared according to specific protocol rules set up in the IBM PAI.

Register GP6' contains the selected address storage [B0-2], where the address of the device expecting at least one other frame is stored when exiting the interrupt service routine, so that upon interruption caused by the reception of that frame, the address is still available. The received\_EOM flag, [B3] is set when a message is decoded that contains B#111 or EOM delimiter. It is stored in this global status register to allow the protocol to determine the end of a transmission. In most multi-byte transmissions, the number of data frames expected is dictated by the protocol. However, ACTIVATE WRITE commands to printers can have any number of data frames associated with them up to 256. In this situation, the activated flag, [B4] is set to signal a variable length stream. Certain host devices also concatenate commands within messages, obscuring the determination of end of message. This scheme allows the software to keep track during such scenarios. The multi-count bits. [B6-7] are used in addition to the EOM delimiter to determine the end of a transmission. The number of additional frames expected in a given multi-byte command is written into these bits (note that a maximum of three bytes can be planned for in this way). When the count is terminated and no EOM delimiter is present, the algorithm then assumes a multi-command message is in progress. [B5] is unused. Register GP7' is used to store the received data or error

code for passage to other routines. The data can be passed on the stack, but dedicating a register to this function simplifies transactions in this case. Keeping track of received data is of utmost importance to communications devices.



# **RECEIVER INTERRUPT**

The receiver interrupt algorithm handles any or all seven addresses possible on the twinax line. The same code is used for each address by utilizing a page oriented memory scheme. Session specific variables are stored in memory pages of 256 bytes each. All session control pages, or SCPs are on 256-byte even boundaries. By setting the high order byte of a BCP index register to point to a particular page or SCP, the low order byte then references an offset within that page. Setting up data memory in such a way that the first SCP begins at an address of B#xxxx x000 0000 0000 further enhances the usefulness of this construct. In this scheme, the high byte of the SCP base pointer can be used to set the particular SCP merely by summing the received or selected address into the lower three bits of the base register.

# NORMAL OPERATION

In normal operation, the configuration described thus far is used in the following manner: After initializing the registers, data structures are initialized, and interrupt routines should be activated. This application utilizes the receiver, transmitter, timer, and bi-directional interrupts. Since {IBR} is set to H#1F, the interrupt table is located at H#1F00. A LJMP to the receiver interrupt routine should be installed at location H#1F104, the transmitter interrupt vector at H#1F08, the BIRQ interrupt vector at H#1F10, and the Timer interrupt vector at H#1F14. Un-masking the receiver interrupt and BIRQ at start up allows the device to come on-line.

When interrupt by the receiver, the receiver interrupt service routine first checks the [ERR] flag in {TSR [B5]}. If no errors have been flagged, the received\_EOM flag is either set or cleared. This is accomplished by comparing {TSR [B0-2] } with the B#111 EOM delimiter. A test of the selected flag, {GP5' [B7]} determines if any of the active addresses are selected. Assuming that the system is just coming on line, none of the devices would be selected. If the frame is addressed to an active device, the SCP for that device is set, and the command is parsed. Parsing the command sets the appropriate state flags, so that upon exiting, the interrupt routine will be prepared for the next frame. Once parsed, the command can be further decoded and handled. If the command is queue-able, the command is pushed on the internal command queue, and the receiver interrupt routine exits. If the command requires an immediate response, then the response is formulated, the timer interrupt is setup, and the routine is exited.

The timer interrupt is used in responding to the host by waiting an appropriate time to invoke the transmit routine. The typical response delay is 45  $\pm 15~\mu s$  after the last valid fill bit received in the command frame. Some printers and terminals are allowed a full 60  $\pm 20~\mu s$  to respond. In either case, simply looping is very inefficient. The immediate response routine simply sets the timer for the appropriate delay and unmasks the timer.

In the transmit routine, the data to be sent is referenced by a pointer and an associated count. The routine loads the appropriate address in the three LSBs of  $\{TCR\}$ , and writes the data to be sent into  $\{RTR\}$ . This starts the transmitter. If the data count is greater than the transmit FIFO depth (three bytes), the Transmit FIFO Empty interrupt [TFE] is

setup. This vectors to code that refills the FIFO and re-enables that interrupt again, if needed. This operation must be carried out before the transmitter is finished the last frame in the FIFO or the message will end prematurely.

The last frame transmitted must contain the EOM delimiter. It can be loaded into  $\{TCR\}$  and data into  $\{RTR\}$  while the transmitter is running without affecting the current frame. In other words, the transmit FIFO is 12 bits wide, including address and parity with data; the address field is clocked along with the data field. In this way, multi-byte response may be made in efficient manner.

### ERROR HANDLING

In 5250 environments, the time immediately after the end of message is most susceptible to transmission errors. The BCP's receiver does not detect an error after the end of a message unless transitions on the line continue for a complete frame time or resemble a valid sync bit of a multiframe transmission. If the twinax line is still active at the end of what could be an error frame, the receiver posts the LMBT error. For example, if noise on the twinax line continues for up to 11  $\mu$ s after the three required fill bits, the receiver will reset without flagging an error. If noise resembles a start bit, the receiver now expects a new frame and will post an error if a loss of synchronization occurs. If the noisy environment is such that transitions on the receiver's input continue for 11  $\mu$ s, or the receiver really has lost sync on a real frame, the error is posted.

Basically, the receiver samples [LA] in addition to the loss of synchronization indication to determine when to reset or to post an error. After a loss of synchronization in the fill bit portion of a frame, if the [LA] flag's time-out of 2  $\mu$ s is reached prior to the end of what could be the next frame, the receiver will reset. If the transitions prevent [LA] from timing out for an entire 11  $\mu$ s frame time, a LMBT error is posted. This method for resetting the receiver is superior in that not only are the spurious loss of mid bit errors eliminated, the receiver performs better in noisy environments than other designs.

### SUMMARY

The IBM 5250 twinax environment is less understood and in some ways more complex than the 3270 environment to many developers. This application note has attempted to explain some basics about twinax as a transmission medium, the hardware necessary to interface the DP8344 to that medium, and some of the features of the BCP that make that task easier. Schematics are included in this document to illustrate possible designs. Details of the twinax waveforms were discussed and figures included to illustrate some of the more relevant features. Also, some different software approaches to handling the transceiver interface were discussed.

#### REFERENCES

5250 Information Display to System/36 and System/38 System Units Product Attachment Information, IBM, November 1986.

*Transmission Line Characteristics*, Bill Fowler, National Semiconductor Application Note AN-108.

*Basic Electromagnetic Theory*, D.T. Paris, F.K. Hurd McGraw-Hill Inc., 1969.

# APPENDIX A: EXAMPLE CODE

The following code was assembled with the HILEVEL assembler. Table II shows the correlation between HILEVEL mnemonics and the mnemonics used in National data sheets for the DP8344V.

|                                                                                                                                   | TABLE II                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HILEVEL                                                                                                                           | National Semiconductor                                                                                                                                                       |
| MOVE Rs,Rd<br>LD Ptr,Rd{,Mde}<br>ST Rs,Ptr{,Mde}<br>LDAX Ptr,Rd<br>STAX Rs,Ptr<br>LDNZ n,Rd<br>STNZ Rs,n<br>LDI n,Rd<br>STI n,Ptr | MOVE Rs,Rd<br>MOVE [mIr],Rd<br>MOVE Rs,[mIr]<br>MOVE EIr + A],Rd<br>MOVE EIr + A],Rd<br>MOVE Rs,[Ir + A]<br>MOVE EIZ + n],rd<br>MOVE rs,[IZ + n]<br>MOVE n,rd<br>MOVE n,[Ir] |
| ADD Rs,Rd                                                                                                                         | ADDA Rs,Rd                                                                                                                                                                   |
| ADDRI Rs,Ptr(,Mde)                                                                                                                | ADDA Rs,[mIr]                                                                                                                                                                |
| ADDI n,Rsd                                                                                                                        | ADD n,rsd                                                                                                                                                                    |
| ADC Rs,Rd                                                                                                                         | ADCA Rs,Rd                                                                                                                                                                   |
| ADCRI Rs,Ptr(,Mde)                                                                                                                | ADCA Rs,[mir]                                                                                                                                                                |
| SUBT Rs,Rd                                                                                                                        | SUBA Rs,Rd                                                                                                                                                                   |
| SUBRI Rs,Ptr{,Mde}                                                                                                                | SUBA Rs,[mIr]                                                                                                                                                                |
| SUBI n,Rsd                                                                                                                        | SUB n,rsd                                                                                                                                                                    |
| SBC Rs,Rd                                                                                                                         | SBCA Rs,Rd                                                                                                                                                                   |
| SBCRI Rs,Ptr(,Mde)                                                                                                                | SBCA Rs,[m]r]                                                                                                                                                                |
| AND Rs,Rd                                                                                                                         | ANDA Rs,Rd                                                                                                                                                                   |
| ANDRI Rs,Ptr{,Mde}                                                                                                                | ANDA Rs,[m]r]                                                                                                                                                                |
| ANDI n,Rsd                                                                                                                        | AND n,rsd                                                                                                                                                                    |
| OR Rs,Rd                                                                                                                          | ORA Rs,Rd                                                                                                                                                                    |
| ORRI Rs,Ptr{,Mde}                                                                                                                 | ORA Rs,[mIr]                                                                                                                                                                 |
| ORI n,Rsd                                                                                                                         | OR n,rsd                                                                                                                                                                     |
| XOR Rs,Rd                                                                                                                         | XORA Rs,Rd                                                                                                                                                                   |
| XORRI Rs,Ptr(,Mde)                                                                                                                | XORA Rs,[mIr]                                                                                                                                                                |
| XORI n,Rsd                                                                                                                        | XOR n,rsd                                                                                                                                                                    |
| CMP Rs,n                                                                                                                          | CMP rs,n                                                                                                                                                                     |
| CPL Rsd                                                                                                                           | CPL _Rsd                                                                                                                                                                     |
| BIT Rs,n                                                                                                                          | BIT rs,n                                                                                                                                                                     |
| SRL Rsd,n                                                                                                                         | SHR Rsd,b                                                                                                                                                                    |
| SLA Rsd,n                                                                                                                         | SHL Rsd,b                                                                                                                                                                    |
| ROT Rsd,n                                                                                                                         | ROT Rsd,b                                                                                                                                                                    |

TL/F/9635-9

10

JMP n JMP n LJMP n LJMP nn JMP Rs JMPR Rs JMPI Ptr LJMP [Ir] JRMK Rs,b,m JRMK Rs,n,m JMPB Rs,s,p,n LJMP Rs,p,s,nn JMP f,s,n Jcc n - opt. syntax for JMP f-JMPF s,f,n CALL n CALL n LCALL n LCALL nn CALLB Rs,s,p,n Rs,p,s,nn LCALL RET (g (,rf)) RETF f,s,(,(g) (,rf)) RET (g(,rf)) RETF s,f(,g(,rf)) Rcc  $\{g(rf)\}$  - opt. syntax -EXX  $a,b\{,q\}$ EXX ba, bb, (,g) TRAP n {,gU} TRAP n{,g} Table 2. Line Addr REL 1 2 TAB 8 WIDTH 132 3 LIST 4 S,F TITLE RXINT 5 -----6 7 RXINT - 9/21/87 ; 8 ; 9 pseudo code ; 10 ţ selected; /\* station is selected 11 ;bool /\* address of selected station 12 byte seladdr; /\* number of frames in this multi 13 multicount; :bvte 14 ;bool activated; /\* command has been activated 15 ; ;rxint() 16 /\* data storage 17 ;byte data; /\* received EOM 18 rx\_eom; :bool 19 ;bool lta; /\* line turn around flag ;{ 20 if (error) { 21 ; 22 if (logerror()== true) return; /\* receiver errors ; 23 ; } 24 else { ï 25 ; else rx\_eom = false; 26 ; 27 ; if (!selected) { ţ 28 TL/F/9635-10

|   | 29 ;            | if (active) {                                                  |
|---|-----------------|----------------------------------------------------------------|
|   | 30 ;            | if (!rx_eom) {                                                 |
|   | 31 ;            | seladdr = (TSR * EDM);                                         |
|   | 32 ;            | IZ = (SCPBASE + seladdr); /* set SCP to appropriate session */ |
|   | 33 ;            | data = rtr;                                                    |
|   | 34 ;            | else (                                                         |
|   | 35 ;            | proto_error(); /* should not get here                          |
|   | 36 ;            | reset_xcvr();                                                  |
|   | 37 ;            | return();                                                      |
|   | 38 ;            | }                                                              |
|   | 39 ;            | }                                                              |
|   | 40 ;            | else {                                                         |
|   | 41              | reset_xcvr(); /* not of interest                               |
|   | 42 ;            | return();                                                      |
|   | 43              | ) · ·                                                          |
|   | 44 ;            | if (multiframe) { /* activate write, etc                       |
|   | 45 :            | multicount = parse(data); /* set number of frames */           |
|   | 46 :            | selected = true: /* only way to select */                      |
|   | 47              | sueve(data):                                                   |
|   | 49              | }                                                              |
|   | 49 :            | else { /# not multi                                            |
|   | 50 .            | if ((var = sinn)e dernde(data)) == meable)                     |
|   | 51              | nuouo(data).                                                   |
|   | 52              | oleo if (var == iemod) immodiato(data).                        |
|   | 57 .            | erse in type immediate (data),                                 |
|   |                 | i (# colortad */                                               |
|   | 04 j            |                                                                |
|   | , 55            | 12 = (5070HSE + 501ador);                                      |
|   | Adda Line DVTNT |                                                                |
|   | Addr Line Kiini |                                                                |
|   | -               |                                                                |
|   |                 | gata = rtr                                                     |
|   | 5/;             | 1† (activated) ( /* in the middle of transmission              |
|   | 58;             | act_data(data);                                                |
|   | 59 ;            | if (rx_eom) { /# end of message                                |
|   | 60 ;            | selected = false;                                              |
|   | 61 ;            | activated = false;                                             |
|   | 62 ;            | }                                                              |
|   | 63;             | return();                                                      |
|   | 64 ;            | }                                                              |
|   | 65 ;            | if (multicount > 0) {                                          |
|   | 66 ;            | queue(data);                                                   |
|   | 67 ;            | if (multicount-= 0) {                                          |
|   | 68 ;            | if (rx_eom) selected = false;                                  |
|   | 69 ;            | }                                                              |
|   | 70 ;            | }                                                              |
|   | 71 ;            | else {                                                         |
|   | 72 ;            | if (multiframe) {                                              |
|   | 73 ;            | <pre>multicount = parse(data);</pre>                           |
| ļ | 74 ;            | queue(data);                                                   |
|   | 75 ;            | )                                                              |
|   | 76 ;            | else (                                                         |
|   | 77 ;            | if ((var = single_decode(data)) == queable)                    |
|   | 78 ;            | queue (data) ;                                                 |
|   |                 | TI /E/0625 11                                                  |
| ļ |                 | IL/F/9033-11                                                   |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
| ļ |                 |                                                                |
|   |                 |                                                                |
|   | 1               |                                                                |

|      | 79<br>DA |                                             | else 1† (Var == 1mmed) 1mmedlate(data);<br>if (ry erm) colorted = false: |              |
|------|----------|---------------------------------------------|--------------------------------------------------------------------------|--------------|
|      | 6V<br>Q1 |                                             | <pre>if ((x_ebm) selected ~ (arse, }</pre>                               |              |
|      | 82       | •                                           | ,                                                                        |              |
|      | 83       |                                             |                                                                          |              |
|      | 84       | ; )                                         |                                                                          |              |
|      | 85       | ; )                                         |                                                                          |              |
|      | 86       | ; return();                                 |                                                                          |              |
|      | 87       | ;}                                          | и.<br>С                                                                  |              |
|      | 98       | ;logerror()                                 |                                                                          |              |
|      | 89       | ;{<br>                                      |                                                                          |              |
|      | 90       | ; bool result;                              |                                                                          |              |
|      | 71<br>07 | ; Switch (erfor_type/ t                     |                                                                          |              |
|      | 93       | <pre>, case nois result = err rdis():</pre> | /* receiver diabled while active                                         |              |
|      | 94       | : break:                                    |                                                                          |              |
|      | 95       | ; case LMBT:                                |                                                                          |              |
|      | 96       | ; result = err_lmbt();                      | /* loss of midbit error                                                  |              |
|      | 97       | ; break;                                    |                                                                          |              |
|      | 98       | ; case PARR:                                |                                                                          |              |
|      | 99       | ; result = err_parr();                      | /* parity error                                                          |              |
|      | 100      | ; break;                                    |                                                                          |              |
|      | 101      | ; case UVF:                                 | It encourse EIER evenes                                                  |              |
|      | 102      | ; result = err_ovr();                       | /* receive: riru uverrun                                                 |              |
|      | 103      | ; ureak;<br>• default:                      |                                                                          |              |
|      | 105      | : result = err unknown():                   | /* strange error handler                                                 |              |
|      | 106      | ; break;                                    |                                                                          |              |
|      | 107      | ; )                                         |                                                                          |              |
|      | 108      | ; return(result);                           |                                                                          |              |
|      | 109      | ; )                                         |                                                                          |              |
|      | 110      | 5                                           |                                                                          |              |
| Addr | Line R   | INT                                         |                                                                          |              |
|      | 111      | ;err lmbt()                                 |                                                                          |              |
|      | 112      | ;{<br>                                      |                                                                          |              |
|      | 113      | ; if (!DA && !selected && !delay(LA         | <ol> <li>return(false); /* delay of 6 usec</li> </ol>                    |              |
|      | 114      | ; else {                                    |                                                                          |              |
|      | 115      | ; log();                                    | /* bump error counters                                                   |              |
|      | 116      | ; return(true);                             | /# admit deteat                                                          |              |
|      | 117      | ; ;                                         |                                                                          |              |
|      | 110      | ; /                                         |                                                                          |              |
|      | 120      | ,<br>: name: RXINT                          |                                                                          |              |
|      | 121      | ; description: receiver interr              | upt handler                                                              |              |
|      | 122      | ,                                           |                                                                          |              |
|      | 123      | ; received datum is sent                    | to other routines thru gp7'                                              |              |
|      | 124      | ; SCP is set appropriate)                   | iy in IZ                                                                 |              |
|      | 125      | ; GP5P - active addresses                   | stbits 0-6                                                               |              |
|      | 126      | ; selected flag:                            | bit /                                                                    |              |
|      | 127      | ; bror - #ulticount;                        | 011 /~D<br>hit 5                                                         |              |
|      | 120      | ; unused:                                   | ore 5                                                                    |              |
|      |          |                                             |                                                                          | TL/F/9635-12 |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |
|      |          |                                             |                                                                          |              |

129 activated: bit 4 ; 130 rx\_eom flag: bit 3 ; bits 2-0 131 seladdr: ţ 132 6P7P - received data ï 133 ţ 134 entry: DA interrupt, GP5', GP6' ; ACC',6P7' ARE DESTROYED 135 exit: ; 136 history: tjq 9/16/87 create ; 137 -----÷ PUBLIC REVRINT 138 139 EXTRN PARSE, QUEUE, IMMEDECODE, RESXCVR 140 MIDERRL, MIDERRH, OVFERRL, OVFERRH, PARERRL, PARERRH 141 EXTRN RXERRL, RXERRH, RSPCTL, RSPCTH, BASESCP, IESERRL, IESERRH 142 EXTRN 143 144 145 SELERR: EQU B#01000000 ; select the error register 146 RXEOM: EQU B#00001000 ; rxeom flag 147 EOM: EQU B#00000111 ; EDM delimeter B#11000000 MULTI: EQU 148 ; multicount ; selected flag 149 SELECT: EQU B#10000000 150 LTA: EQU B#101 B#00000010 ; CARRY FLAG 151 CFLAS: EQU 152 RCVRINT: 00000 153 EXX MA,AB,DI ; SET APPROPRIATE BANK 154 00000 AEE8 154 NS,RERR,NOERROR 00001 D500 155 JMPF RXERROR ; ERROR IN FRAME 00002 CC00 CALL 156 S,C,EXIT 00003 D900 157 JMPF ; ABORT 00004 D900 158 NOERROR: EOM, ACC 159 LDI ; LOAD MASK 00004 8078 160 AND TSR, GP7 ; FORM ADDRESS 160 00005 F165 CMP GP7,EDM 161 ; TEST 00006 307B 161 JMPF 00007 D000 162 NS,Z,C1RXINT ; IF NOT EQUAL, JUMP Line RXINT Addr 0000B 508A 163 ORI RXEOM, GP6 ; ELSE SET EDM FLAG 00009 CB00 JNP C2RXINT 164 ; 0000A CB00 C1RXINT: 165 0000A 4F7A ; CLEAR IT 166 ANDI RXEOM\*,6P6 167 ţ ; DECIDE IF WE'RE ALREADY SELECTED 168 169 0000B 170 C2RXINT: JMPB 6P5, S, B7, DEVSELECT ; IF ALREADY SELECTED 171 0000B BDE9 171 0000 20000 171 172 ; NOT SELECTED...DECIDE IF ADDRESS IS ACTIVE, IE; VALID FOR US 173 TL/F/9635-13

| 0000D     | 174<br>175<br>176 | ;<br>DEVTABLE:<br>JRMK | TSR.ROT6.MSK3        | ; ELSE, SEE IF ACTIVE<br>: JUMP BASED ON THE ADDRESS FIELD*4 |
|-----------|-------------------|------------------------|----------------------|--------------------------------------------------------------|
| 0000D B3C | 5 176             | UNUN                   | i on gina ro gina no |                                                              |
|           | 177               | JMPB                   | GP5,NS,B0,RSTRX      | X ; ADDR 0 - IF NOT ACTIVE, RESET RX                         |
| 0000E BC0 | 9 177             |                        |                      |                                                              |
| 0000F 000 | 0 177             |                        | 1000000              | ACTIVE DENICE SET or                                         |
| 00010 000 | 1/5               | LJAP                   | LUADSUP              | ; ALITYE DEVICE, DEI SCP                                     |
| 00011 000 | 0 178             |                        |                      |                                                              |
|           | 179               | JMPB                   | 6P5,NS,B1,RSTRX      | X ; ADDR 1 - IF NOT ACTIVE, RESET RX                         |
| 00012 BC2 | 9 179             |                        |                      | · · ·                                                        |
| 00013 000 | 0 179             |                        |                      |                                                              |
| ****      | 180               | LJMP                   | LOADSCP              | ; ACTIVE DEVICE, SET scp                                     |
| 00014 LEU | 0 180<br>0 180    |                        |                      |                                                              |
| 00013 000 | 181               | JMPB                   | GP5.NS.B2.RSTRX      | X : ADDR 2 - IF NOT ACTIVE. RESET RX                         |
| 00016 BC4 | 9 181             |                        | ,,,                  | ,,,                                                          |
| 00017 000 | 0 181             |                        |                      |                                                              |
|           | 182               | LJMP                   | LOADSCP              | ; ACTIVE DEVICE,                                             |
| 00018 CE0 | 0 182             |                        |                      |                                                              |
| 00019 000 | 182               | 1800                   | SPS NO BT RETRY      | Y . ADDD T - IF NOT ACTIVE                                   |
| 0001A 8C6 | 9 183             | <b>0</b> :11 <b>D</b>  | 0.01401001101        |                                                              |
| 0001B 000 | 0 183             |                        |                      |                                                              |
|           | 184               | LJMP                   | LOADSCP              | ; ACTIVE DEVICE,                                             |
| 0001C CE0 | 0 1 <b>84</b>     |                        |                      |                                                              |
| 0001D 000 | 0 184             | 1907                   |                      |                                                              |
| 00015 000 | 183               | JULA                   | 5P3,N5,84,K51K1      | X ; ADUR 4 - IF NUI ACHIVE,                                  |
| 0001E 000 | ) 185<br>0 185    |                        |                      |                                                              |
|           | 186               | LJMP                   | LOADSCP              | ; ACTIVE DEVICE,                                             |
| 00020 CEO | 0 186             |                        |                      |                                                              |
| 00021 000 | 0 186             |                        |                      |                                                              |
| 00000 000 | 18/               | JULR                   | 6P5,N5,85,851HX      | X; ADDR 5 - IF NUT ACTIVE,                                   |
| 00022 BCH | 0 187             |                        |                      |                                                              |
|           | 198               | LJMP                   | LOADSCP              | ; ACTIVE DEVICE,                                             |
| 00024 CE0 | 0 198             |                        |                      |                                                              |
| 00025 000 | 0 188             |                        |                      |                                                              |
|           | 189               | JMPB                   | GP5,N5,B6,RSTRX      | X ; ADDR 6 - IF NOT ACTIVE,                                  |
| 00026 BCC | 9 189             |                        |                      |                                                              |
| Addr      | Line R            | XINT                   |                      |                                                              |
| 00027 000 | 0 189             |                        |                      |                                                              |
|           | 190               | LJMP                   | LOADSCP              | ; ACTIVE DEVICE,                                             |
| 00028 CE0 | 0 190             |                        |                      |                                                              |
| 00029 000 | 0 190             | L CALL                 | DECYCUD              | • ADDR 7 - REPETUED FOR NE'DE NOT INTEDECTED                 |
| 0002A CE8 | 0 191             | LUNCL                  | NEOXOVIN             | , HUN / RECEIVED EDN THE RE ROT INTEREDIED                   |
| 0002B 000 | 0 191             |                        |                      |                                                              |
| 0002C CB0 | 0 192             | JNP                    | EXIT                 | ; QUIT                                                       |
|           |                   |                        |                      | TL/F/9635–14                                                 |
|           |                   |                        |                      |                                                              |
|           |                   |                        |                      |                                                              |
|           |                   |                        |                      |                                                              |
|           |                   |                        |                      |                                                              |
|           |                   |                        |                      |                                                              |
|           |                   |                        |                      |                                                              |
|           |                   |                        |                      |                                                              |

|            | 193<br>194 | ;<br>; LOAD THE SCP | POINTER, 12   |                                   |              |
|------------|------------|---------------------|---------------|-----------------------------------|--------------|
|            | 195        | ;                   | ·             |                                   |              |
| 00020      | 196        | LOADSCP:            |               |                                   |              |
|            | 197        | XOR                 | ACC, ACC      | ; CLEAR                           |              |
| 00020 F908 | 197        |                     | ,             |                                   |              |
|            | 198        | MOVE                | ACC.ZLD       | : LOW BYTE                        |              |
| 0002E FF4R | 198        |                     | ,             | ,                                 |              |
| 002E ROOR  | 199        | 101                 | RASESCP ACC   | SET UP UPPER RYTE OF SCP POINTER  |              |
|            | 200        | MOUE                | ACC 7H1       | ·                                 |              |
| 00070 EE10 | 200        | nuvc                | H66,2111      | 3                                 |              |
| 00030 FE88 | 200        | 1.0.1               |               | . FOM MACK                        |              |
| 00031 8018 | 201        | LUI                 | LUN, ALL      |                                   |              |
| 00030 FINE | 202        | AND                 | ISK, HLL      | ; LEAVE IN ALL                    |              |
| 00032 1105 | 202        |                     |               |                                   |              |
|            | 203        | ADD                 | ZH1,ZH1       | ; ADD INTU Z PUINTER              |              |
| 00033 E273 | 203        |                     |               |                                   |              |
|            | 204        | ;                   |               |                                   |              |
|            | 205        | ; DECODE THE C      | ommand frame  |                                   |              |
|            | 206        | ;                   |               |                                   |              |
| 00034      | 207        | DECODE:             |               |                                   |              |
|            | 208        | MOVE                | RTR,GP7       | ; GET RX DATA                     |              |
| 00034 FD64 | 208        |                     |               |                                   |              |
|            | 209        | JMPB                | GP7.S.B0.MUL  | TIFRM; IF MULTIFRAME              |              |
| 00035 8D0B | 209        |                     |               | ,                                 |              |
| 00036 0000 | 209        |                     |               |                                   |              |
|            | 210        | I CALL              | IMMEDECODE    | : ELSE, INMEDIATE ACTION REQUIRED |              |
| 00037 CEB0 | 210        | LUNEL               | THEFEODE      | , cost, income north Accord       |              |
| 00039 0000 | 210        |                     |               |                                   |              |
| 00030 0000 | 210        | THD                 | EV17          |                                   |              |
| 00037 6800 | 211        |                     | CALL          |                                   |              |
| 0003H CB00 | 212        | NULIIPKN:           |               | AFT MULTI ABUNT                   |              |
| *****      | 215        | LUALL               | PARSE         | ; SEI MULTI CUUNT                 |              |
| 0003A CE80 | 213        |                     |               |                                   |              |
| 0003B 0000 | 213        |                     |               |                                   |              |
| 0003C 5809 | 214        | ORI                 | H#80,6P5      | ; SELECTED = TRUE                 |              |
| 0003D 4F8A | 215        | ANDI                | EOM*,6P6      | ; CLEAR SELECTED ADDRESS          |              |
| 0003E B07B | 216        | LDI                 | EOM, ACC      | ; MASK ADDRESS                    |              |
|            | 217        | AND                 | TSR,ACC       | ; LEAVE IN ACC                    |              |
| 0003F F105 | 217        |                     |               |                                   |              |
|            | 218        | OR                  | 6P6,6P6       | ; SET NEW ADDRESS                 |              |
| 00040 F54A | 218        |                     |               |                                   |              |
|            | 219        | LCALL               | QUEUE         | : PLACE ON QUEUE                  |              |
| 00041 CE80 | 219        |                     |               |                                   |              |
| 00042 0000 | 219        |                     |               |                                   |              |
| 00043 CR00 | 220        | IMP                 | FXIT          | :                                 |              |
|            | 221        |                     |               | ,                                 |              |
|            | 700        | . THIS COME 10      | BRANCHED TO T | THE DEVICE IS SELECTED            |              |
|            | 222        | ; INTO CODE TO      | CET CPB DACED | AN PEIERTEN ANNDERG               |              |
|            | 223        | ;                   | DEI DUR BHOED | ON SELECTED RODRESS               |              |
| Addr       | Line F     | XINT                |               |                                   |              |
|            | 221        |                     |               |                                   |              |
|            | 224<br>00F |                     |               |                                   |              |
| VVV94      | 225        | DEVSELEUI:          | 100 100       |                                   |              |
|            | 226        | XOR                 | ACC,ACC       | ; CLEAR ALC                       |              |
|            |            |                     |               |                                   | TL/F/9635-15 |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |
|            |            |                     |               |                                   |              |

| 00044 F908             | 226         |            |                |                 |          |                               |              |
|------------------------|-------------|------------|----------------|-----------------|----------|-------------------------------|--------------|
|                        | <b>2</b> 27 | ł          | IOVE           | ACC,ZLO         | ţ        | CLEAR LOW BYTE OF POINTER     |              |
| 00045 FE48             | 227         |            |                |                 |          |                               |              |
| 0046 B008              | 228         | L          | DI             | BASESCP, ACC    | ;        | BASE OF SESSION CONTROL PAGE  |              |
|                        | 229         | ł          | HOVE           | ACC,ZHI         | ;        | UPPER BYTE                    |              |
| 0047 FE68              | 229         |            |                |                 |          |                               |              |
| 0048 B078              | 230         | L          | DI             | EOM, ACC        | ;        | MASK ADDRESS                  |              |
|                        | 231         | 4          | AND            | SP6.ACC         | :        | LEAVE IN ACC                  |              |
| 0049 F10A              | 231         |            |                |                 |          |                               |              |
|                        | 232         | 4          | ADD            | ZH1.ZH1         | :        | FORM SCP POINTER              |              |
| 00046 F273             | 232         |            |                |                 | ,        |                               |              |
| ///H L2/0              | 202         |            |                |                 |          |                               |              |
|                        | 200<br>774  | • NON DEC  | THE AR         | NUT MULTIFRAME  | PNS      | STRUCTURS                     |              |
|                        | 237         | , 100 DEC  |                |                 |          | JUDICI / ICO                  |              |
|                        | 200         | ,<br>,     | INVE           | RTR GP7         |          | GET DATA                      |              |
| 0040 EB44              | 230         |            |                | ATTA DE 7       | ,        |                               |              |
| 1040 1004<br>1040 0000 | 230         |            | 51             | WHETT APP       |          | WHITT MACY                    |              |
| 1046 BLVC              | 2070        | L.         | .UI<br>NNR     | RULTI HUU       | ;        | RULLI RHON                    |              |
|                        | 238         | ŀ          | HND            | 676,HLL         | ļ        | COUNT IN UPPER NIBBLE         |              |
| 0040 FIVA              | 238         |            |                | 100 0071        |          | CONTINUE AUCO MINDE           |              |
|                        | 239         | 5          | OKL            | ALC, KUIS       | ;        | PUSITION IN LOWER NIBBLE      |              |
| 004E C8C8              | 239         | -          | MAR            |                 |          |                               |              |
| 004F D800              | 240         | ]          | HPF            | 5,2,NEWCOMM     | ţ        | NUL IN A MULTIBYTE            |              |
|                        | 241         | Ĺ          | CALL           | QUEUE           | ;        | MULTI, SO PUSH ON QUEUE       |              |
| 0050 CEB0              | 241         |            |                |                 |          |                               |              |
| 0051 0000              | 241         |            |                |                 |          |                               |              |
| 00052 2018             | 242         | 5          | UBI            | H#01,ACC        | ;        | DECREMENT MULTICOUNT          |              |
| 0053 D800              | 243         | 3          | IMPF           | S,Z,TERMULTI    | ;        | IF ZERD, MULTI HAS TERMINATED |              |
|                        | 244         | ;          |                |                 |          |                               |              |
|                        | 245         | ; MULTI S  | STILL I        | N PROGRESS      |          |                               |              |
|                        | 246         | ;          |                |                 |          |                               |              |
| 0054 43FA              | 247         | Á          | NDI            | MULTI*,6P6      | ;        | CLEAR OUT OLD COUNT           |              |
|                        | 248         | E          | SLA            | ACC, ROT6       | ;        | REPOSITION COUNT              |              |
| 0055 6948              | 248         |            |                | ,               | Ś        |                               |              |
|                        | 249         | 0          | )R             | 6P6.6P6         | :        | SUM INTO STATUS               |              |
| 0056 F54A              | 249         |            |                |                 | ,        |                               |              |
| 0057 CR00              | 250         | 3          | MP             | EXIT            |          |                               |              |
|                        | 251         | •          |                |                 |          |                               |              |
|                        | 252         | • MULTICO  | HINT HA        | S REACHED ZERD  | sn       | TERMINATE                     |              |
|                        | 253         |            |                | o nenoneo teno, | 00       | ENTRACE                       |              |
| 0050                   | 255         | IFRMIN TT- |                |                 |          |                               |              |
| 10030<br>10050 A7EA    | 254         | Δ          | NDT            | MINITTA COL     |          | PLEAD OLD POUNT TO TEDD       |              |
| NATE OFAN              | 255         | ה<br>ז     | INDD           | CDL NC DT PITE  | у<br>рм. | IE NOT EON                    |              |
|                        | 2057        | u          | nir D          | 000,00,00,00    | ки;      | ir Nul Eun,                   |              |
| NUDY BLOA              | 230<br>257  |            |                |                 |          |                               |              |
| 0000A 0000             | 200         |            | LINT           | CELECTY COE     |          |                               |              |
| JUU38 4/FY             | 237         | A          | (NU) 1<br>(ND) | SELELI*, 573    | ;        | ELDE, DELELI = MALSE          |              |
| 1005E EB00             | 238         | 017004     | inr            | K21K1           | ;        | REAL! THE TRANSCEIVER         |              |
| 0005D CB00             | 259         | UT IERN:   |                |                 |          |                               |              |
| )005D CB00             | 260         | J          | MP             | EXIT            |          |                               |              |
|                        | 261         | ;          |                |                 |          |                               |              |
|                        | 262         | ; NEW COM  | IMAND; I       | MULTI OR SINGLE |          |                               |              |
|                        | 263         | ;          |                |                 |          |                               |              |
| )005E                  | 264         | NEWCOMM:   |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               | TL/F/9635-16 |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |
|                        |             |            |                |                 |          |                               |              |

| Addr              | Line RXINT   |               |                 |                                        |               |
|-------------------|--------------|---------------|-----------------|----------------------------------------|---------------|
|                   | 265          | JMPB          | 6P7,NS,B0,3IN6  | SLE; IF NEW COMMAND IS NOT MULTI,      |               |
| 0005E 8C08        | 265          |               |                 | •                                      |               |
| 0005F 0000        | 265          |               |                 |                                        |               |
|                   | 266          | I CALL        | PARSE           | : IS MULTI. SET COUNT                  |               |
| 0060 0590         | 266          |               |                 | ,                                      |               |
| 0000 CCC0         | 266          |               |                 |                                        |               |
| 0001 2000         | 200          | LCALL         | DUEUE           | . DICH AN AUCHE                        |               |
|                   | 267          | LUHLL         | ROLOC           | ; rash on accor                        |               |
| 0062 CE80         | 267          |               |                 |                                        |               |
| 0063 0000         | 267          |               |                 |                                        |               |
| 0064 CB00         | 268          | JMP           | EXIT            | ; QUIT, IL NEXT FRAME                  |               |
|                   | 269 ;        |               |                 |                                        |               |
|                   | 270 ;        | NEW COMMAND 1 | IS SINGLE AND/O | { NEEDS IMMEDIATE RESPONSE             |               |
|                   | 271 ;        |               |                 |                                        |               |
| 0065              | 272 SI       | NGLE:         |                 |                                        |               |
|                   | 273          | LCALL         | IMMEDECODE      | ; SINGLEGO DO IT                       |               |
| 0065 CE80         | 273          |               |                 |                                        |               |
| 0066 0000         | 773          |               |                 |                                        |               |
|                   | 274          | JMPB          | GP6.NS.BJ.EXI   | T : IF NOT EON                         |               |
| 0017 0018         | 274          | •             |                 | ,                                      |               |
| 0010 000H         | 274          |               |                 |                                        |               |
| 0000 0000         | 275          | ANTAT         |                 | · FIEAR CELEFTER RIT                   |               |
| VU67 4/17         | 27J<br>27/ P | HRUI          | DELEGITIOFJ     | , GEERA SELECTED DIT                   |               |
| WV6A 4/FY         | 2/6 KG       |               | 66080U0         | DEPET OF TAD BATA OUT                  |               |
|                   | 2//          | LUALL         | KEBALYK         | ; RESET, LLEAK DATA DUT                |               |
| 006A CE80         | 2//          |               |                 |                                        |               |
| 006B 0000         | 277          |               |                 |                                        |               |
| 0000 3400         | 278 E        | (17:          |                 |                                        |               |
| 006C AFB0         | 279          | RET           | RI,RF           | ; RETURN GRACEFULLY                    |               |
|                   | 280          |               |                 |                                        |               |
|                   | 281 ;-       |               |                 | *****                                  |               |
|                   | 282 ;        | name:         | RXERR           | OR                                     |               |
|                   | 283 ;        | descrip       | ption: recei    | ver ERROR handler                      |               |
|                   | 284 :        |               |                 |                                        |               |
|                   | 285 :        | entry:        | DA +            | ERR interrupt, GP5', GP6'              |               |
|                   | 286          | evit.         | ACC 1           | SP7' ARE DESTROYED                     |               |
|                   | 200 ,        | histor        | v tin           | 9/16/R7 create                         |               |
|                   | 207 ,        |               | y               |                                        |               |
|                   | 100 ;        |               |                 |                                        |               |
|                   | 207 ;        |               |                 |                                        |               |
|                   | 290 ;        | RELEIVER ERN  | ON NHAVLEN      |                                        |               |
|                   | 291 ;        |               |                 |                                        |               |
| 0050              | 292 R        | KERNUR:       |                 |                                        |               |
| 0060 5406         | 293          | ORI           | SELERR, ICR     | ; SET ECR BIT                          |               |
|                   | 294          | MOVE          | RTR, SP7        | ; GET ERROR TYPE                       |               |
| 006E FD64         | 294          |               |                 |                                        |               |
| 006F 48F6         | 295          | ANDI          | SELERR*,TCR     | ; RESET TCR                            |               |
|                   | 295          | JNPB          | GP7,S,B1,LMBT   | ERR; LOSS OF MIDBIT                    |               |
| 0070 <b>BD</b> 2B | 296          |               |                 |                                        |               |
| 0071 0000         | 296          |               |                 |                                        |               |
|                   | 297          | JMPR          | SP7.S.B3.PARE   | RR : PARITY                            |               |
| 0077 0040         | 207          | 47.1 P        |                 | ···· • • • • • • • • • • • • • • • • • |               |
| AATT AAAA         | 207          |               |                 |                                        |               |
| 0075 0000         | 277          | 1905          |                 | DD . DUCCCI DH                         |               |
|                   | 298          | 1010          | 0F/,3,54,UVFC   | RR ; UVERFLUW                          | TI (5/0005 47 |
|                   |              |               |                 |                                        | IL/F/9635-17  |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |
|                   |              |               |                 |                                        |               |

| 00074 8 | BD8B  | 298        |          |        |                      |          |     |                                        |              |
|---------|-------|------------|----------|--------|----------------------|----------|-----|----------------------------------------|--------------|
| 00075 0 | 0000  | 298<br>299 | ILLEGAL: |        |                      |          |     |                                        |              |
| 00076 E | 8008  | 300        |          | LDI    | ILLEGAL              | ,ACC     | ļ   | ; WHAT ERROR IS THIS?                  |              |
| Addr    |       | Line R     | IXINT    |        |                      |          |     |                                        |              |
| 00077 ( | CBOO  | 301        | INDICOD. | JMP    | BUMPERR              |          | ;   | ; SHOULD NOT GET HERE!!                |              |
| 00078 1 | LB00  | 30Z<br>707 | LABIERK  | INPE   | s na rii             | FARC     |     | : IF DA. THEN NO ERROR                 |              |
| 000701  |       | 304        |          | JMPB   | 6P5.5.B              | 7.LOGIT  | :   | : IF SELECTED. POST                    |              |
| 00079   | 8DE9  | 304        |          |        | u. u, -, -           |          | ,   | ,                                      |              |
| 0007A ( | 0000  | 304        |          |        |                      |          |     |                                        |              |
| 0007B ( | 0033  | 305        |          | CALL   | SDLY                 |          | ;   | ; DELAY FOR 6 USEC                     |              |
|         |       | 306        |          | JMPB   | NCF,NS,              | B5,CLEAR | С;  | RC; IF NOT ACTIVE - DISCARD, ELSE POST |              |
| 0007C   | 8CA1  | 306        |          |        |                      |          |     |                                        |              |
| 0007D ( | 0000  | 306        |          |        |                      |          |     |                                        |              |
| 0007E   | 0000  | 307        | LOGIT:   |        |                      |          |     |                                        |              |
| 0007E I | B008  | 308        |          | LDI    | MIDERRL              | ,ACC     | ;   | ; LOSS OF MIDBIT                       |              |
| 0007F   | CBOO  | 309        |          | JMP    | BUMPERR              |          | ;   | ; INCREMENT COUNTER                    |              |
| 00080   | CB00. | 310        | PARERR:  |        |                      |          |     |                                        |              |
| 08000   | B008  | 311        |          | LDI    | PARERRL              | ,ACC     | ;   | ; PARITY                               |              |
| 00081   | CB00  | 312        |          | JMP    | BUMPERR              |          |     |                                        |              |
| 00082   | CBOO  | 313        | OVFERR:  |        |                      |          |     |                                        |              |
| 00082 1 | B008  | 314        |          | LDI    | DAFEKKT              | , ACC    | ;   | ; UVERFLUWVERY BAD:                    |              |
| 00083   | 8008  | 315        | BUMPERR  | 477    |                      |          |     | CON NEW COINTED                        |              |
|         |       | 316        |          | ADD    | 2LU,YLU              |          | ;   | ; FURM NEW PUINIER                     |              |
| 00083   | E212  | 316        |          |        |                      |          |     |                                        |              |
| 00084   | 8018  | 517        |          |        | H#V1,HU              | L<br>,   | ;   | ; INUKERENI<br>- FETTOL DUD. POUNT     |              |
| 00005   |       | 318        |          | LV     | PIRT, OF             | 0        | ;   | ; FEICH DLD COUNT                      |              |
| 00085   | COCA  | 318        |          |        | 00/ 070              | V DODTO  |     | . UDITE OUT NEW                        |              |
| 0000/   | ****  | 517        |          | AUVKI  | 676,718              | 1,70510  | ;   | , #KILE UUI NE#                        |              |
| 00007   | AU4A  | 319        |          | INDE   | NCCDY                |          |     |                                        |              |
| 00087   | 0100  | 320        |          | JULL   | NO, C, NA<br>DTDV CD |          | 1   | , DEI UUI<br>. EETRU HDDED DVTE        |              |
| 00000   | CODA  | 321        |          | LU     | rikt,or              | 0        | ,   | ; FEICH OFFER DIE                      |              |
| ~~~~    | LVLH  | 321        |          | ADDDI  | CD4 DTD              | v        |     |                                        |              |
| 00089   | 8008  | 322        |          | HUVILL | broșrin              | 1        | ,   | ,                                      |              |
| 00084   | 5020  | 322        |          | 0R1    | CELAG. C             | CR       |     | . SET CARRY                            |              |
| 00088   | 5020  | 374        | RYFYIT:  | 0111   | or choijo            | un       | ,   |                                        |              |
| OOORR   | AFRO  | 325        | MACA1 (  | RFT    |                      |          | :   | : DR NOT restore flags                 |              |
| 00080   | AFBO  | 326        | CLEARC:  |        |                      |          | ,   |                                        |              |
| 00080   | 4FD0  | 327        |          | ANDI   | CFLAG*.              | CCR      | :   | : CLEAR CARRY                          |              |
| 0008D   | CBOO  | 328        |          | JMP    | RXEXIT               |          | ,   | ,                                      |              |
|         |       | 329        | <b>;</b> |        |                      |          |     |                                        |              |
|         |       | 330        | ;        | name:  |                      | SDLY     |     |                                        |              |
|         |       | 331        | ;        | descri | otion:               | delay r  | ou  | routine, MULTIPLES OF 4.8usec,         |              |
|         |       | 332        | ;        |        |                      | 1.4 use  | 2C  | ec OVERHEAD, MAX OF 410usec            |              |
|         |       | 333        |          | entry: |                      | delay c  | ou  | count on stack                         |              |
|         |       | 334        | ;        | exit:  |                      | acc des  | str | strayed                                |              |
|         |       | 335        | ;        | WARNIN | i:                   | DONT CA  | ILL | ALL THIS WITH COUNT = 0!               |              |
|         |       | 336        | ;        | histor | y:                   | tjq 9/   | 16  | /16/87 create                          |              |
|         |       | 337        | ;        |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        | TL/F/9635-18 |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |
|         |       |            |          |        |                      |          |     |                                        |              |



National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications

nterfacing the DP8344 to Twinax

**AN-516**