##  <br> System Central Interface <br> 

3 independent parallel ports, each bit programmable input or latched output. Handshake signals for each port.

Serial port with RS-232, 20ma, 60ma current loops, speed selectable between 45 and 9600 baud.

High-speed biphase cassette interface with selectable speeds from 800 to 100,000 baud. Can also be used as a signal generator to test audio equipment.

Two on-board relays control two recorders. Three status lines for external recorder control.

Reset-jump: on reset, the OPU jumps to the SCI monitor.
2708 programmer.
256 bytes of RAM for stack and buffer space.
$2 k$ monitor in $2708^{\prime} s$ provides system control and I/O.
SCI requires the following $S-100$ bus signals:
+8 volts, +16 volts, -16 volts, circuit ground
$\overline{\text { PWR, PDBIN, } \overline{\text { PHOLD }}, \overline{\text { PRESET, }} \text { PSYNC }}$
SINP, SOUT
AO-Al5, DIO-DI7, DOO-D07
2 mhz clock
Power Requirements: (nominal)

$$
\begin{aligned}
& +8-450 \mathrm{ma} \\
& +16-\quad 85 \mathrm{ma} \\
& -16-\quad 65 \mathrm{ma}
\end{aligned}
$$

Dimensions: 10.0 " wide x 5.1 " high (excluding edge connector)
SCI generates its own wait states, independent of the processor used, and can use 650ns 2708's.

Table of Contents
Assembly ..... 1
Address jumpers ..... 2
Reset-jump ..... 3
Serial-port connections ..... 4
EIA RS-232 connections ..... 5
Parallel port connections ..... 5
Cassette wiring ..... 6
Check-out ..... 7
Power-on test ..... 8
2708 programmer ..... 9
Cassette check-out ..... 9
Tape and recorders ..... 10
DIP switch functions ..... 11
Biphase cassette theory ..... 12
Parts List ..... B1
Parts Layout ..... B2
Baud-rate table ..... Ol
Schematic ..... D1
Large-scale IC's used in SCI ..... El
SCI monitor version 1.5 ..... F1
Useful utility programs ..... G1
Patches to Popular software ..... H1

A note of caution: This is an expensive interface. To protect your investment, and ensure a long operating life, exercise care in the construction of this board. Take your time, be certain of parts placement, don't force I.C.'s into their sockets, solder thoroughly, but sparingly, as a little solder goes a long way. Handle the I.c.'s carefully, making sure that the pins are straight before inserting them into their sockets. I.C. pins can break, and lead receptacles damaged, by careless insertion. Take the time to inspect and test the finished board before applying power. This avoids the smoke test.

Personal care: wear eye protection when cutting leads and soldering. This prevents foreign material from entering your eyes.

Use a metallic holder for the soldering iron. This prevents heat-damaged tables, possible fires, and carpet burns when soldering irons get loose. The soldering iron need only be 25 watts with a $1 / 8$ inch spade tip. A welder is not necessary. An iron with a three-wire cord is preferable for electrical safety. An Ungar \#l35 is an excellent iron for p.c. work, and costs about $\$ 8.00$. Rosin-core solder is supplied with the kit. If it's not enough, use 60/40 lead-tin rosin-core solder only. Acid-core solder will destroy the circuit and void the warranty.

All parts mount on the $F R O N T$ side, and solder on the BACK. Solder the parts after each step.
$\square$ Check the parts list and the parts layout. These should agree with the parts supplied. Contact us immediately if anything is missing, as shipping takes time.
$\square$ Locate the 7-pole DIP switch. Mount it in the upper left corner of the board. Mount it with the numbers toward the top of the board.
$\square$ Note the orientation of the I.c.'s: For vertical I.c.'s, pin 1 is to the upper left, and for horizontal I.c.'s, pin 1 is to the upper right.
$\square$ Install the three standard profile 24 -pin sockets in pads 17,18, and 19. These are the sockets for the 2708's.

Note that Is.pad 6 is the address jumper pad and does not have a socket.

Install the remaining sockets.
$\square$ Install the four regulators and the two heat sinks. Line up the heat sinks over the areas marked on tne p.c. board. Bend the leads of the regulators at right angles as shown on the parts list. The holes for the LM-320-T-12 were small on early production boards, and the leads of the regulator should be bent and cut approximately as shown, then crimp the leads slightly with pliers so they will fit the p.c. holes. Use $4-40$ nuts and bolts to secure the regulators.


Next, install the capacitors. Observe the polarity of the 16 tantalum capacitors: the + lead must line up with the + shown in the layout and marked on the p.c. board.

The - lead for the tantalum capacitor on the righthand side of the board must be bent inward, to avoid nitting the guide rails of the card rack.

Install the diodes, being careful to align the cathode bands with the markings on the p.c. board and shown in the layout drawing.

All resistors mount vertically:

$\square$ Install the $1 / 2$ watt resistors. These are about 50\% larger than the $1 / 4$ watt resistors. All are near IC-45. Note: There is an extra 51 ohm $1 / 2$ watt, used in the 60 ma serial. $\square$ Install the remaining resistors.

There are two types of small-signal transistors used: 2N3904 and 2N3906. Be sure to place them at the correct locations, and oriented as shown in the layout. Spread the leads slightly to fit the hole patterns.

The MJE-180 transistor in the upper right-hand corner of the board, has leads that must be crimped slightly to fit the mounting holes. Trim the leads, then crimp with pliers to fit.
$\square$ Insert the IED's, noting that the flat edge is the catnode. Check tine parts list for details.

## Jumper Options

Strap the address jumpers for the board address you specified when ordering. If you didn't specify, DOOO hex is the standard address in the firmware supplied by DAJEN.


Address pad, DOOO shown

| ADDRESS | Jumper(s) | ADDRESS | Jumper (s) |
| :--- | :--- | :--- | :--- |
| 8000 hex | A-12,13,14 | C000 hex | A-12,13 |
| 9000 | $A-13,14$ | DOOO | A-13 |
| A000 | A-12,14 | EOOO | A-12 |
| B000 | A-14 | FOOO | None |

Lower addresses $(6000,7000)$ could be used, but are not recommended, as system RAM usually occupies the first 32 K of memory space, if not more.

Note: I/O addresses use 16 consecutive ports, with the same byte as the board address. For a board address of DOOO, the I/O addresses are: DO,D1,D2,...DE,DF. For a board address of $A O O O$, the $I / O$ addresses are: $A O, A 1, A 2 .{ }^{\circ}$ ..AE, AF.
$\square$ The two fumpers in the upper right-hand corner next to pins 1 and 2 of IC pad 45, the serial port, should be installed if there are no immediate plans for connection to a Modem.


When used, $\overline{C T S}$ (Clear To Send) and $\overline{D C D}$ (Data Carrier Detect) must be converted to RS-232 levels (they are TTL compatible) using a 1489 or equivalent $\mathrm{RS}-232$ line receiver.



Typical 1489 circuit

Reset-Jump Jumper

IC-4 and 5 are located
in the lower left portion
of the SCI board. of the SCI board.

The reset-jump circuit takes control of the $\mathrm{S}-100$
bus when the reset line (pin 75 on the bus) is active (low). No other jump circuits should be active, as they will probably conflict and the system will hang-up.

This circuit is enabled by placing a jumper from the reset-jump pad to the enable pad. It is disabled by placing a jumper to the disable pad.

The address to which the processor jumps is determined by the first three bytes of the 2708 in IC position 17 (PØ). With the SCI monitor, the jump address is directed to the initialization routine of the monitor, and is typically:

| Høøб | C3 | Jump instruction for CPU |
| :--- | :--- | :--- |
| HØø1 | lE | Low-order jump address |
| HØØ2 | HØ | High-order jump address |

The manner in which the SCI jump circuit is set up requires that the CPU jump to a location within the first lk of the SCI board address to reset the jump circuit. This design eliminates false reset of the reset-jump circuit when the SCI is addressed at FØØø. Thus, if other than the SCI monitor is used, and a jump outside the first lk of the SCI memory block is desired, a second jump instruction must be used, and could be placed immediately following the first jump instruction.

Example: SCI addressed for Døøø-DFFF, desired jump address is to EøØØ:

D $\varnothing \varnothing \varnothing$ C3 83 D $\varnothing$ first jump instruction Døø3 03 Øø E $\varnothing$ second jump instruction

If a Modem is to be used, the $\overline{\text { ETS }}$ and $\overline{\mathrm{DCD}}$ (clear to Send, Data Carrier Detect) from the 1489 will connect to pins 1 and 2 on the interface plug. If a Modem with OTS and DCD is to be used interchangably with a device not sending those signals, wire one I/O plug for the Modem, and another for the other device, connecting pins 1 and 2 to pin 6 on the plug for the other device.

## RS-232 or Current Loop

Both an RS-232 device and a current-loop device can be connected to the SCI at the same time. Each keyboard can independently provide input, but each printer will print the same output. The devices must operate at the same baud rate. If only one device is used, the other input must be jumpered on the 14 pin connection plug.

$$
\begin{equation*}
\text { Gnd Gnd } \overline{\operatorname{RTS}} \overline{\times O} \overline{C T S} \tag{7}
\end{equation*}
$$

Pad 45


If a current loop device is used, connect the printer + lead to pin 13 for a 20 ma loop, or to pin 12 for a 60 ma loop, and the other lead to pin 6. The keyboard contacts connect to pins $8(+)$ and 7 . The RS-232 input must be jumpered from pin 10 to pin 9.

If an RS-232 device is used, connect the printer lead to pin ll, and the keyboard to pin 10, with common signal lead to pin 7. De-activate the current loop keyboard contact with a jumper from pin 8 to pin 7.

Remember, when only one keyboard device is used on the serial port, the other must be de-activated with an appropriate fumper.

It is recommended that coaxial cable such as $R G-174$ be used for connection to the serial devices, as the shielding prevents extraneous noise pick-up.

EIA RS-232 Connections
The following page lists the pin numbers used on the EIA RS-232 standard connections. RS-232 is normally used on Modems, and data terminals, for high-speed serial data transfers. The standard connector used is a 25 pin EIA designated type. The use of cables under 50 feet is recommended. If longer cables are used, the total capacitance of the cable and terminator must not exceed 2500 picofarads (micro-micro-farad). Normal cable capacitance is about 30 picofarads per foot.

The following are the standard connections used with a 25-pin EIA port connector (RS-232).

EIA pin Signal SCI pin Description on pad 45


If the RS-232 input is not used (SCI pin 10), tie to -l2 volts on pin 9.

If the serial input to the SCI is not used, tie pin 8 to pin 6 or 7 .

Resistor connections to +12 volts if Data Set Ready or Received Line Signal Detector are needed by terminal:

EIA pin SOI pin (connect to +12 with a jumper).


On SCI, jumper pin 4 (IC pad 45) to pin 8 of IC-38, the LM-358, or TL-082.

Keyboard and Parallel Port Wiring
All three parallel ports are wired identically, except that IC pad 44, the "Keyboard" port, has -l2 volts supplied on pin l, for keyboards that require a negative. bias. Otherwise the ports are identical, and the software determines which ports are input or output. The current available on the +5 volt supply is mainly a function of the regulator temperature. If forced air cooling is used, the regulator will remain cool, and a total of 500 ma is available. If convection cooling is used, it is recommended that total current be held to 100 ma.

If a keyboard is used that has only seven data lines, don't use D7, leave it open.

Gid 06 D7 so SI -12 (44)
$\begin{array}{lllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 \\ \text { Parallel Ports, 42, 43, } 44\end{array}$
$\begin{array}{lllllll}8 & 9 & 10 & 11 & 12 & 13 & 14\end{array}$ $D \varnothing-D 7=$ Data lines
$\begin{array}{lllllll}\text { D5 } & \text { D4 } & \text { D3 } & \text { D2 } & \text { DI } & D D & +5\end{array}$
SI= Strobe in $S O=$ Strobe out

Strobe polarity is determined by software, and is normally negative. The $2 k$ monitor supplied looks at DIP switch 7 to determine the strobe of the Keyboard port. If switch 7 is on, the monitor expects a negative strobe. If the switch is off or "Open", the monitor expects a positive strobe.



Positive

Typical Strobe Pulses

Cassette Cable Connections
$\square$ Cut the audio cable into two equal lengths. These ends then solder to appropriate pins of a 16 pin DIP plug for record and playback connections. If a standard cassette recorder is being used, connect the lead from the speaker jack to pins 7 and 8 on the plug (pin 8 , is the shield connection). If a high-impedance output from a deck is used, connect the center lead to pin 6 . For a microphone input, connect to pins 1 and 2 (shield to pin 1). If an AUX input is used, connect the center lead to pin 3.


Cassette Connections Spkr, AUX shown

## Cassette Control

If you plan to use two recorders, connect the Read recorder remote control line to pins 9 and 10 on the plug. Connect the Write recorder remote line to pins 11 and 12. When reading a cassette tape, the Read recorder will be activated, and when writing a tape, the Write recorder will be active.

If you will be using one recorder for both reading and writing, wire pin 9 to pin 11, and pin 10 to pin 12. Then connect the recorder remote line to pins 11 and 12, and it will be active when reading and writing.

When using more sophisticated cassette control, pins 14,15, and 16, provide additional control and status ines. Normally, with the monitor supplied, pin 14 is set for status input, for turns counters, or other status info, and pins 15 \& 16 output for additional control, connecting to a transistor relay driver or equivalent. These lines can be set up for other configurations, such as all outputs or two outputs and one input, by changing the initialization routine as desired. Complete control of an automatic deck, such as a Phi-Deck, can be easily implemented, to control forward, reverse, read, and write. One status output controls Fast-Forward, or Rewind, one status output controls Read-Write, one on-board relay turns power on and off to the drive motors, and the other
relay controls the Playback-Record solenoid. The status input counts the turns of the tape reel to locate files. Further information is forth-coming.

## Check-out

Before inserting the I.C.'s or applying power, inspect the finished board. Are all connections soldered, are there any solder bridges ? Are any leads touching other leads ? Solder bridges are not likely to occur with the solder-masked p.c. board. If they do, draw the solder away with the tip of the iron. Compare the orientation of capa-
 drawing. Correct any discrepancies. Excess solder flux can be removed with Miller-Stephenson. Heavy Duty Flux Remover. Alternatively, isopropyl alcohol and a clean rag will remove flux. Soak a corner of the rag in the alcohol and wipe the flux off, in a direction away from the edge connector, as flux remaining on the connector fingers could cause intermittent connection.

After inspecting and cleaning the board, use a VOM (Volt Ohm Meter) set to resistance scale X 100, to check the resistance of all fingers of the edge connector to ground, pins 50 and 100, and to +5 volts on board (pin 16 of IC 5 or IC 7). This eliminates the destruction of bus drivers in the computer if a problem exists. Most fingers will have infinite resistance.. Zero, or low resistance indicates a problem. Only pins $2(+16)$, 52 (-16), and Reset pin 75 will have any resistance indication. Even here, the resistance should be greater than 200 ohms. Of course, pins 1 and 51 the +8 supply will show resistance to ground and to the on-board +5 supply. If there is an abnormal indication, or short, follow the p.c. trace from that finger and look for a solder bridge or an etch problem. Repair the problem.

Caution: never insert or remove a board in the system bus with the power on. Always turn the power off, and wait half a minute for the power supply capacitors to discharge.

After a satisfactory resistance check, plug the SCI into the system bus and apply power. Measure the voltages out of the four regulators. The values should be within $10 \%$ of the nominal value shown:




I $C-3$

If any voltage measurement is not within range, there may be a problem with the regulator, associated bypass capacitor, a short in the p.c. power trace, or inadequate supply voltage. If the regulator is getting very hot, there is probably a short. Check that the associated tantalum bypass capacitors are correctly installed, the + lead is aligned with the + mark on the P.C. board. Or there is a short somewhere from the output trace to ground. If the
regulator is cool to the touch, check the supply voltage to the regulator. If the supply is ok $(+8,+16$, or -16$)$, the regulator is faulty. Contact DAJEN for a replacement.

With the regulators working correctly, turn off the power and remove the SCI. The next step is to insert the I.C.'s. Be careful when handing the I.C.'s. Avoid conditions that can generate static electricity: don't walk across carpets and then touch the I.C.'s, ground yourself to a metal object such as a desk or chair. Don't slide across plastic covered chairs. Leave the I.C.'s in the pink anti-static plastic bags until actually installing them. Place the p.c. board in front of you, the bag of I.C.'s to one side, and the layout picture to the other side. Remove one I.C. from the bag at a time and install it. Prior to inserting each.I.C., straighten any bent pins, and squeeze them in slightly so they line up with the lead receptacles of the socket. One way to do this is to hold the I.c. between thumb and fore-finger, and with the leads resting on a table top, press down lightly. Forming the leads prevents damage to the I.C. pins and to the socket.


To insert the I.C., place the pins directly over the socket receptacles and with an even pressure press the IC into the socket until it seats firmly. The 24 pin I.C.'s will require a great deal of force to seat into the socket.

Note: the 2708 marked $P O$ plugs into the left-most standard profile socket. Pl plugs into the middle socket, and P 2 , when supplied, plugs into the right-hand socket(IC-19).

After all the I.C.'s have been installed, make a visual check of their orientation and location. For all vertical I.C.'s, the orientation mark faces toward the top of the board, and for all horizontal I.C.'s the orientation mark faces to the right of the board. Make sure all I.C.'s are in their correct position.

## Power-on Test

Plug the completed board into the system bus. Connect the various peripherals (Tape recorder, keyboard, teletype, etc). If you are using a video monitor as the principal console output device, connect to the video interface board in the bus, and turn on the monitor. If you specified a teletype or serial device as the main console output, turn it to "Line". Apply power to the computer. If you have a front panel, hit the "Reset" switch. The front panel lights should indicate address 0000 , and the data bus should show 03 (bits 7,6,1,0 on). Hit "Run", the data lights should all glow, and the high-order address lights ( $\mathrm{A}-15,14,13,12$ ) should indicate the address of the SCI board (For example, for address D000, $A-15,14$, and 12 on, $A-13$ off). If you don thave a
front panel, hit "Reset". When running, the SCI monitor program clears the video monitor screen, outputs a prompt character (>) to the main console output device, and waits for a command from the main console input device. Characters typed on the input device are echoed to the output device. This action confirms that $90 \%$ of the SCI is functional, so proceed to the Cassette Checkout.

If SCI fails to perform up to here, there is a problem. A few tests can be performed with a voltmeter. To know where to begin, analyze what is happening: when "Reset" is pressed the reset-jump circuit is activated. SCI grabs the bus and outputs a jump instruction to the processor (the jump instruction is the first three bytes in Prom 0). The CPU reads the jump data and jumps to the beginning of the SCI monitor. At this time the reset-jump circuit is reset and the SCI monitor initiallzes the LSI circuits on board, clears the video screen, outputs the prompt character, and waits for input. Troubleshooting determines where the chain of events is interrupted. This then identifies the area of the faulty component. Start with the reset-fump circuit. With a VOM measure the voltage to circuit ground (pin 7, IC-4) of pin 6 on IC-4, while holding the reset button pressed. This voltage should be less than 0.3 volt. Still holding reset, check the voltage at pin 6 of IC-13, which should be low (0.3), check pin 6 of IC-27, also low, and finally, check the voltage on the DI pins of the edge connector. DI-7,6,l,0, should be high ( 3 volts or so), and DI-5,4,3,2 should be low. Use the schematic to identify the pin numbers of the DI lines. A problem at this point isolates the reset-jump circuit (IC-4,13,27) or the bus driver IC-10. Tests beyond this point require a front panel and an oscilloscope to trace signals. Contact us immediately.

## Programmer

The on-board programmer power supply is active when the switch marked "P" is off or open. Place this switch off. Measure the output voltage at $E$ of the $2 N 3906$ transistor next to IC-29. It should be about 27 volts or slightly higher. Place the switch back in the on position.

When programming $2708^{\prime} \mathrm{s}$, switch " $P$ " must be in the off position, otherwise leave it in the on position.

## Cassette Check-out

With SCI functioning and responding to commands, insert the supplied tape into the cassette recorder. Turn the recorder volume control to about $1 / 3$ of full range, and the tone control to mid-range. Hit the reset button and type in the command: SR 03E8(CR) (CR=Carriage Return). This sets the cassette read speed to 1500 baud. Place the recorder in the playback mode and type RC(CR) on the keyboard. The recorder should start playing and when the leader tone on the tape is reached, the "Level" light on SCI should glow. Adjust the level of the recorder to illuminate the "Level" light. When the sync code is received, the "Sync"
light will glow. If it doesn't, change switch " $R$ " to the opposite of its present position and repeat the entire procedure from the beginning.

For recorders that can't monitor the tape with a plug in the external speaker jack, add a 43 ohm resistor. across the amp and speaker leads as shown:

EXT
SPKR
jack


With the Read circuit working, fast forward the tape to a blank area. Record the digital counter reading. Hit the reset button and use the $Z$ command as follows: $Z 0800$ E6(OR). This writes sync bytes into the first $2 k$ of memory. Place the recorder in the record mode and type in this command: WC 0 800(CR). The recorder should start, and then stop after about 10 seconds. Rewind the tape to the beginning of this section, place the recorder in the playback mode, and read in the data. The sync light should glow. If it doesn't glow with sync bytes coming from the recorder, try reversing the "R" switch, hitting reset, and read in the sync bytes again. If they read in this time, return the " $R$ " switch to its original position and flip the "X" switch to the opposite of its present position. This reverses the phase of the data recorded on the tape so it will read in.

Try recording some random memory blocks to check for errors on playback. If there are errors, try adjusting the tone control on the recorder to eliminate them. On some recorders there is an optimum setting of tone for best results.

We recommend Scotch "Highlander" or AVC series tape, which is low noise, high density, and costs around one to two dollars per 60 minute cassette. With this tape, we estimate an error rate of about one in ten million. We have never had a non-recoverable error (re-reading fails to bring correct data).

## Recorders

We believe you get what you pay for. A medium-priced recorder will provide better reliability, capability, and much longer life. For a moderately priced recorder, we recommend the Panasonic RQ-430S, at about \$50-\$60. For best price-performance, we have found the Superscope C-104 at $\$ 80-\$ 100$ unbeatable. This recorder can routinely record reliably at 5000 baud ( 624 bytes per second). We have one that's seen continuous service for a year and a half and still provides reliable, fast data recording.

Characteristics to look for in a recorder: a digital tape counter to keep track of program locations, automatic level to eliminate guess-work about recording, freedom from line-noise pick-up. This last requirement can only be deter-
mined by actual use with your system. When you buy a recorder, buy it on condition that you can return it in exchange for one that works with your computer system. Most dealers are willing to comply with your desires. If yours won't, find one who deserves your business.

Maintenance is essential for reliable performance. Keep the tape heads and capstan pressure roller clean. A Q-tip soaked in isopropyl alcohol is a good tool to get to those hard-to-reach places in the recorder. The dirt you see on the cotton swab can cause drop-outs and lost data. Keeping the capstan roller clean will help keep wow and flutter down. Although the SCI cassette interface can tolerate a $33 \%$ change in speed, a dirty pressure roller can cause that amount of speed change and consequent loss of data. We routinely record 24 k data blocks, and following the above precautions, we almost never have errors.

## DIP Switch Functions



DIP Switch in IC pad 39

Switches 1 and 2 control the data inversion in the biphase cassette interface. Switch 1, "R", inverts the received data from the tape recorder. Switch 2, "X", inverts the data transmitted to the recorder. These switches compensate for different data inversions in different recorders.

Switches 3 and 5 are not used, and are available to the user if so desired.

Switch 4, "P", is the Programmer enable switch. When "OPEN" or "OFF", the on-board 2708 programmer is active. Normally, except when programming $2708^{1}$ s, this switch is "ON" to prevent inadvertent programming of the 2708 in IC pad 19 ( 3 rd standard profile socket on the right.).

Switches 6 and 7 control options selected by the SCI monitor program. In current versions of the SCI software, switch 6, on initial start-up or reset, selects the console devices used for input and output. When switch 6 is "ON", a keyboard connected to IC pad 44 is assumed to be the console input device, and a video interface is assumed for output. When switch 6 is "OPEN" or "OFF", a serial device connected to IC pad 45 is assumed for both input and output.


Theory of Biphase Cassette Operation
Biphase recording is a means of recording digital data In a high-speed, densely-packed format, on cassette tape. Because each cycle of the recording process represents one data bit, there is no wasted space. A standard cassette recorder operating well within its capabilities can record data at 2500 baud error-free. This is $2500 / 8$, or 312 bytes per second. In comparison, Kansas-City recording, operating with shifting frequencies, runs at 300 baud, or 37 bytes per second. Thus biphase is faster, and can as a consequence store more data on a given cassette. A 30 minute side of a standard Phillips cassette can hold 500 k -bytes of data.

To understand how biphase works, look at the figure on page 12 titled "Biphase Data Encoding and Decoding". Look at the top drawing. This is the basic cassette clock Which sets the data transmission speed, or baud rate (one baud is one bit per second). This clock is generated by dividing the crystal-controlled system clock through a series of dividers. Contained within the cassette interface is a shift register which is loaded with one byte of data to be output. Each positive transition of the cassette clock shifts one bit out ot the shift register. Data in a Tarbell-type system is shifted most significant bit first (bit 7 first, then bit 6, 5, ....l, 0). When all eight bits of the present byte are shifted out, the interface requests another byte.

The data shifted out of the register is then exclusiveOR'ed with the cassette clock. The logic states of a twoinput exclusive-OR gate are as follows:

| Inputs | $\stackrel{A}{\varnothing}$ | $\emptyset$ | $\varnothing$ | Output |
| :---: | :---: | :---: | :---: | :---: |
|  | $\varnothing$ | 1 | 1 |  |
|  | 1 | $\varnothing$ | 1 |  |
|  | 1 | 1 | $\varnothing$ |  |

Note: when both inputs are the same, the output is low.
The third line of the figure on page 12 illustrates the data after it has been exclusive-OR'ed with the clock. This is then fed to the recorder input. Notice that when the data is unchanging ( a string of zeroes or ones), the output to the recorder is the cassette clock frequency, and when the data changes from a one to a zero, or a zero to a one, an extra one-half clock cycle is added to the data output. These extra half-cycles are the basis of biphase. When they occur, the phase changes and the decoded data changes to the opposite state.

Now consider the decoding process. For the decoder presented, the input data must be inverted to provide the correct data output.

After being amplified and squared by a comparator, the data from the tape recorder is fed to a receiver shift register and a "double pulser". The "double pulser" puts out a pulse every time the incoming data changes state.

This output triggers a digital timer which is set equal to $75 \%$ of the time required for one complete cassette clock cycle. The output of this timex is the "reconstructed clock" shown in the figure. When triggered, this timer output goes low until it times out and returns to the high state. As it returns, the timer output pulse clocks the present data bit into the receiver shift register. When eight bits of data have entered the shift register, the cassette interface signals the computer that a data byte is available.

Notice that the first two data bits clocked into the receiver are l's, where O's were sent originally. The interface, started at random, has not locked to the data stream. However, after the first data transition from a 0 to a l, the clock is now locked to the data stream, and the correct bits are entered into the receiver register. That first byte of data (3C hex) is called the clock synchronizing byte, because it synchronizes the reconstructed clock with the data stream.

The byte following the clock sync byte, is the data synchronizing byte (E6 hex). Up to the time it is received, the receiver shift register has been reset, not signalling the reception of bytes to the computer. When the receiver recognizes the data "sync" byte, it knows the next 8 bits will be a data byte, and readies the data flag to signal the computer that a data byte is available.

Analyze what would happen if the original, non-inverted data had been input to the receiver: all the data would be inverted. This is why the receiver has a data inversion switch. If the tape recorder doesn't invert the data it receives, then the interface must.

The reason there is a transmitted data inversion switch is to allow easy software interchange among biphase-system owners. Each interface is shipped with a pre-recorded cassette tape. The system owner adjusts his interface and recorder to be compatible with that tape and he is then able to easily exchange tapes with other owners.

39 pf
.001 uf
．0047uf
．O1 uf
.05 uf
4．7uf 35 VDC


Resistors $1 / 4$ watt，unless noted 4.7 ohm（Yellow－Violet－Gold）
$3201 / 2$ watt（Red－Black－Black）
$1.51 \mathrm{l} / 2$ watt（Green－Brown－Black）
243 （Yellow－Orange－Black）
300 （Orange－Black－Brown）
300 1／2 watt（Orange－Black－Brown）
510 （Green－Brown－Brown）
$15101 / 2$ watt（Green－Brown－Brown）
102 k （Red－Black－Red）
28 4．7k（Yellow－Violet－Red）
5 20k（Red－Black－Orange）
39 k （Orange－White－Orange）
$\begin{array}{ll}\text { look } & \text {（Brown－Black－Yellow）} \\ \text { lMeg } & \text {（Brown－Black－Green）}\end{array}$


## Resistors


witch

Sockets
38 pin
$15 \quad 14 \mathrm{pin}$
$10 \quad 16 \mathrm{pin}$
320 pin
324 pin low profile
$3 \quad 24$ pin standard profile
240 pin
2 Heat Sinks
I．C．＇s
2 74LSOO
2 74LSO4
274 LSII
$1 \quad 74 \mathrm{LS} 32$

74 LS 155
74LS221
1 LM－320－T5
1 LM－320－T 12
74 LS 32
1 LM－340－T 12
1 TL－082


Typical
Regulator Installation

1 74LS386
22112
22708
26820
16850
$1 \quad 6852$
18131
$3 \quad 81 \operatorname{LS} 97$
18253


This table lists some of the baud rates which the cassette and serial ports can generate. Use the appropriate command (SR for Read, SS for serial, SW for write) to set the desired baud rate by inserting the hex number listed in the table, after the command letters. For example, to set the Read speed for 3600 baud, the command is: SR OlAO CR (Carriage Return). Remember that when reset, or started cold, the various speeds are set by the pre-determined values in the initialization routine. For speeds not listed in the table, the appropriate hex number can be calculated as follows:

For Write: $N=2,000,000 /$ Baud Rate, $N$ must be expressed in hex. Example: 2500 baud desired. $N=2,000,000 / 2500=800$ decimal A hex number is N3 N2 N1 NO, where N3 has a value of 4096 , N2 256, N1 16, NO ones. 800 has $0-4096$, so $N 3=0 ; 800$ has $3-256$, so $N 2=3$. This leaves $800-3 X 256=32$. $N 1=2(2 X 16=32)$, and $\mathrm{NO}=0$ because nothing remains. Thus the hex number is 0320. The command is: SW 03200R (Carriage Return).

Read speed: $N=1,500,000 /$ Baud Rate
Serial speed: $N=125,000 / B a u d$ Rate

|  | Cassette | System | Serial Port |  |
| :---: | :---: | :---: | :---: | :---: |
| Baud Rate | Write | Read | Serial |  |
| 45.45 | ABE4 | 80EB | OABE | 60 WPM, Baudot |
| 75 | 682A | 4E20 | 0682 |  |
| 75.75 | 6722 | 4D59 | 0672 | 110 WPM, Baudot |
| 110 | 4705 | 3544 | 0470 |  |
| 150 | 3415 | 2710 | 0341 |  |
| 300 | 1 AOA | 1388 | 01 AO |  |
| 600 | OD05 | 0904 | OODO |  |
| 900 | 08 AE | 0582 | 008A |  |
| 1200 | 0682 | 04E2 | 0068 |  |
| 1500 | 0535 | 03E8 | 0053 | Tarbell cassette |
| 1800 | 0457 | 0341 | 0045 |  |
| 2200 | 038D | 02A9 | 0038 |  |
| 2400 | 0341 | 0271 | 0034 |  |
| 2500 | 0320 | 0258 | 0032 | DAJEN Cassette |
| 3000 | 029A | $01 F 4$ | 0029 |  |
| 3600 | 022B | OlAO | 0022 |  |
| 4000 | $01 F 4$ | 0177 | 001 F |  |
| 4800 | 01 AO | 0138 | 001A |  |
| 5400 | 0172 | 0115 | 0017 |  |
| 6000 | 014 D | OOFA | 0014 |  |
| 7200 | 0115 | OODO | 0011 |  |
| 8000 | OOFA | OOBB | OOOF |  |
| 9600 | OODO | 009C | OOOD |  |
| 10400 | 0000 | 0090 | OOOC |  |
| 12000 | 00A6 | 007D | 000A |  |
| 14000 | 008E | 006B | 0008 |  |
| 18000 | 006F | 0053 | 0006 |  |
| 19200 | 0068 | 004E | 0006 |  |
| 31000 | 0040 | 0030 |  |  |
| 45000 | 002C | 0021 |  |  |
| 70000 | 001 C | 0015 |  |  |
| 100000 | 0014 | OOOF |  |  |




Pin Configuration


The 8253 consists of three independent l6-bit programmable timers, with a maximum count rate of 2 mhz . Each counter is programmed by writing a mode control word into the control word register. Depending on the mode, the count is loaded into the appropriate count register.

Control Word: D7 D6 D5 D4 D3 D2 D1 D0
Bit assigned: SCl SCO RLI RLO M2 MI MO BCD
Where: SC=Select Counter to which control word applies

| SCl | SCO | Counter | $B C D=$ | $0=$ Binary counter |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | $l=4-$ decade $B C D$ counter |  |
| 0 | 1 | 1 |  |  |
| 1 | 0 | 2 |  |  |
| 1 | 1 | Illegal |  |  |

RI=Read/Load command
RLI RLO
00 Latch counter for read operation
$0 \quad 1$ Read/Load least significant byte only
$1 \quad 0 \quad$ Read/Load most significant byte only
11 Read/Load least sig.byte first, then most.sig.byte.
Mode: M2 Ml MO Mode Bus Address: Al AO Device Selected

| 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 1 |
| $X$ | 1 | 0 | 2 |
| $X$ | 1 | 1 | 3 |
| 1 | 0 | 0 | 4 |
| 1 | 0 | 1 | 5 |


| 0 | 0 | Count Reg. O |
| :--- | :--- | :--- |
| 0 | 1 | Count Reg. 1 |
| 1 | 0 | Count Reg. 2 |
| 1 | 1 | Control Reg. |

where $X=$ don't care

Mode Definitions
Mode 0: Out will be low at start of count, goes high and remains high at the end of the count. The Gate input inhibits counting when low, and enables counting when high. Out goes low when count register is re-loaded. Re-loading during counting: lst load byte stops the count, 2nd load byte starts the new count.

Mode l: Programmable One-shot. Out goes low following the rising edge of the Gate input. Out goes high at the end of the count. If a new count value is loaded during the counting, the current count will not be affected. The Oneshot is retriggerable and Out will remain low for the full count after the last trigger.

Mode 2: Rate Generator. Divides by $N$ (the count). Out is low for one period of the input clock after each N counts. Gate when low inhibits counting and holds Out high. When Gate goes high, the counter starts counting for the full count. Gate will synchronize the counter. If the count register is reloaded, only subsequent counts will be affected. When Mode 2 is set, Out remains high until the count is loaded.

Mode 3: Square wave generator. Similar to mode 2, but the output is a square wave. If the count is odd, Out is high for $(N+1) / 2$ counts, and low for $(N-1) / 2$. If the count register is reloaded, the new count is effective immediately after the next output transition. Gate controls counting.

Mode 4: Software triggered strobe. Out is high after the mode is set. When the count is loaded, counting begins. Gate low inhibits counting. On reaching the count, Out goes low for one clock period. Reloading the count register while counting does not affect the present count. Reloading the count register restarts counting. Gate low inhibits counting.

Mode 5: Hardware triggered strobe. The counter starts counting after the rising edge of the Gate input, and Out goes low for one clock period when the count is reached. The counter is retriggerable.

The loading of the count register does not have to immediately follow the loading of the Mode register. The sequence of bytes specified in the mode word must be followed. All counters are down counters (count down from the count loaded).

To read the counter while counting, issue the RL $\varnothing \varnothing$ mode addressed to the correct counter in a mode word. Then reading the counter will produce a latched count. The mode of reading must then be issued, and either one or two reads made to input the least significant byte, then the most significant byte of the count. The entire reading procedure must be completed. If two bytes are to be read, then two bytes must be read, otherwise the WR command can't be sent to the counter.
$2 \varnothing 1918 \quad 17 \quad 16-\infty-11 \quad 10 \quad 9 \quad 8 \quad-\infty-\infty-\infty \quad 21$

Vcc CB2 CB1 PB7 PB6----PB1 PBØ PA7 PA6-----m--PA1 PA $\varnothing$ Vss

6820 PIA

R/W CSø $\overline{C S 2} \operatorname{CS1} \mathrm{E} D 7--\mathrm{D} \varnothing \overline{\text { Reset }} \mathrm{RSI} \operatorname{RS} \varnothing \overline{\text { IRQB }} \overline{\text { IRQA }}$ CA2 CAI
$\begin{array}{lllllllllllll}21 & 22 & 23 & 24 & 25 & 26 & 33 & 34 & 35 & 36 & 37 & 38 & 39\end{array} 40$

| CAl, CA2 | Control lines for parallel port A |
| :---: | :---: |
| CBI, CB2 | Control lines for parallel port B |
| CS $\varnothing$, CSI, | CS2 Chip select inputs |
| D¢-D7 | Data bus lines |
| E | Enable pulse, clocks valid data, conditions control lines. |
| IRQA, IRQB | Interrupt flag lines for use in interruptdriven systems. |
| PA $\varnothing$-PA7 | Parallel Port A |
| PBØ-PB7 | Parallel Port B |
| R/W | Read/Write control |
| Reset | Resets control registers and flags |
| RSø, RS1 | Address lines to select internal registers |

The $682 \varnothing$ Peripheral Interface Adapter consists of two independent parallel ports, each with its own handshake signals and interrupt request line, each bit programmable as input or latched output, and the necessary control registers to implement operation.

## Register Addressing

RSl RSØ Control Register bit Location selected

| $\varnothing$ | $\varnothing$ | CRA-2 $=1$ |
| :--- | :--- | :--- |
| $\varnothing$ | $\varnothing$ | CRA-2 $=\varnothing$ |
| $\varnothing$ | 1 |  |
| 1 | $\varnothing$ | $C R B-2=1$ |
| 1 | $\varnothing$ | $C R B-2=\varnothing$ |
| 1 | 1 |  |

Data Register A
Direction Register A Control Register A Data Register B
Direction Register B Control Register B

The Data Direction registers determine the function of each bit in the associated parallel port. A $\varnothing$ bit sets the corresponding peripheral line to an input mode. A 1 results in a latched output mode.

The Control Registers set the operation of the control lines, $C A-1,2, C B-1,2$, and enable the interrupts. Bits $\varnothing-5$ of the control register may be written and read, while bits 6 and 7 are read-only.

Control Word Format for Control Registers


Bit 2 of each control word allows access to either the data or direction register. See the register addressing on page $\mathrm{E}-3$.

Bits 6 and 7 are read-only flags, and are set by signals on the Control lines. They are reset after read operations, by an E pulse, when the PIA is not selected.

Control lines $C A-1,2$, and $C B-1,2$, can be programmed for a variety of input-output functions. The following tables summarize the options available:

Interrupt inputs $\mathrm{CA}-1$ and $\mathrm{CB}-1$
Bit 1 Bit $\varnothing$ Interrupt Interrupt Flag Interrupt Request Input Bit $7 \quad \overline{\text { IRQA }}$ or $\overline{\text { IRQB }}$

| $\varnothing$ | $\varnothing$ | $\downarrow$ Active | set high | Disabled- $\overline{\text { IRQ }}$ stays high |
| :--- | :--- | :--- | :--- | :--- |
| $\varnothing$ | 1 | $\downarrow$ Active | set high | Low when flag goes high |
| 1 | $\varnothing$ | $\uparrow$ Active | set high | Disabled-IRQ stays high |
| $I$ | 1 | $\uparrow$ Active | set high | Low when flag goes high |

CA-2 and CB-2 as interrupt inputs
Bit5 Bit4 Bit3 Interrupt Flag Interrupt request

Input
$\begin{array}{lllll}\varnothing & \varnothing & \varnothing & \downarrow \text { Active } & \text { set high } \\ \varnothing & \varnothing & 1 & \downarrow \text { Active } & \text { set high } \\ \varnothing & 1 & \varnothing & \uparrow \text { Active } & \text { set high } \\ \varnothing & 1 & 1 & \uparrow \text { Active } & \text { set high }\end{array}$
CB-2 configured as an output
$\overline{I R Q A}$ or $\overline{I R Q B}$
Disabled- $\overline{I R Q}$ stays high Low when flag goes high Disabled-IRQ stays high Low when flag goes high

CB-2 Set
High when flag bit ition of first $E$ pulse 7 is set by active
$1 \varnothing 1$ Low on positive transition of first E pulse after a write B operation.
$1 \quad \varnothing$ Low when $C R$ bit 3 goes low after write into Control Register B.

111 same
CA-2 configured as an output
$1 \varnothing \varnothing$ Low on negative transition of E after a read operation of reg A.

High on pos. edge of first E pulse after E pulse which occurred when not selected.

Low as long as CRbit 3 is low. High when CR bit 3 is written high.
same

High when flag goes high from active transition on CA-1

High after first E pulse when part not selected

Bit5 Bit4 Bit3 CA-2 Cleared
CA-2 Set


Parallel Port A has internal pull-up resistors that represent about one TTI load. When configured as outputs, the voltages at the port pins must be above 2.0 volts, or erroneous data will be seen when trying to read what was written.

Parallel Port B when configured as output, can drive up to 1 ma of current, and the output voltage does not have to be above 2.0 volts for the output to be read correctly after a write operation. Thus, Port B can drive the base of a transistor switch directly.

The E pulse conditions the interrupt control lines. At least one E pulse must occur from the inactive edge to the active edge of the input signal to condition the edge sense network. In other words, at least one E pulse (about 2 us apart) must occur between strobe inputs from an external device. Then the interrupt flag will be set on the next active transition of the strobe.

The interrupt flags are cleared after a read of the particular data register. They can not be set again until an E pulse occurs while the part is deselected.

## Interrupts

When using interrupts, $\overline{\overline{I R Q A}}$ or $\overline{\operatorname{IRQB}}$ is tied to the appropriate Vectored Interrupt pin on the $\mathrm{S}-100$ bus, or they may be tied together to Int (pin 73), as they are open-drain outputs. Then when an interrupt occurs, the appropriate flags can be checked in the Control Registers to determine the requesting device.

Pin-outs

| 1 | Vss | CTS |
| :---: | :---: | :---: |
| 2 | RxData | DCD |
| 3 | RxCK | Dø |
| 4 | TxCk | D1 |
| 5 | RTS | D2 |
| 6 | TxData | D3 |
| 7 | IRQ 6850 | D4 |
| 8 | CSØ | D5 |
| 9 | CS2 | D6 |
| 10 | CS 1 | D7 |
| 11 | RS | E |
| 12 | Vdd | $\mathrm{R} / \overline{\mathrm{W}}$ |


|  | Definition of pins |
| :---: | :---: |
| CSø, CS1, $\overline{C S 2}$ Chip-select inputs. |  |
| When CSX and CSI are high, |  |
| and CS2 is low, the 6850 is |  |
|  |  |
| $\overline{\mathrm{CTS}}$ | Clear to Send input from a |
|  | modem, when low indicates tha |
|  | the data channel is ready for |
|  |  |
|  | is not used, must be tied to ground. |
|  |  |

Data Carrier Detect input from a modem, when low the data carrier is present. If high, the data carrier is lost, and the 6850 will generate an interrupt to reflect the DOD status in the status register. The receive interrupt must be enabled for this to happen. Must be tied to ground when not used. Dø-D7 Eight bidirectional data lines to the central bus. E Enable input. Clocks data to and from the ACIA and enables the input/output bus drivers.
$\overline{I R Q}$ TTL compatible, open drain, active low output that requests an interrupt when the ACIA interrupts are enabled. It may be tied together with other opendrain interrupt outputs in a polled-interrupt system where the interrupt routine checks the status of each device to determine which one requested service.
RS Register Select. Tied to address line AO. When low, the status/control registers are selected. When high, the receive/transmit data registers are selected.
$\overline{R T S}$ Ready to Send output. Signals the modem that the ACIA is ready to send data. Active low.
$\mathrm{R} / \overline{\mathrm{W}}$ Read/Write signal from the bus.
RxCK Receiver clock, normally 16 times the actual data rate. RxData Received data, serial input, least significant bit first.
TxCK Transmitter clock, normally 16 times the data rate.
TxData Transmitter data, serial output, least significant bit sent first.
Vss System ground.
Vdd +5 volt supply, nominally $5 \%$.
The ACIA transmits and receives serial data in an asynchronous format, with one start bit, seven or eight data bits, and one or two stop bits, with or without parity. As used in the SCI, the ACIA is set up for one start bit, eight data bits, no parity, two stop bits, and divides the clock by a factor of 16.

Status Register Bit Assignments:
The status register is selected when $R S$ is low, and $R / W$ is high, and the ACIA is selected.
$\begin{array}{llllllll}\text { Bit } & 7 & 6 & 5 & 4 & 3 & 2 & 1\end{array}$
IRQ PE OVRN FE CTS DCD TDRE RDA
CTS Indicates the state of the CTS pin. When high, TDRE is disabled.
$D C D$ Indicates the state of the $D C D$ pin. Remains high after DCD goes low, until reset by reading the status register then the data register, or reset by Master Reset.

FE Framing error which indicates a lack of the proper stup bit, which can be the result of a poor transmission, or the break condition (open loop).
IRQ Interrupt request status, reflects the state of the IRQ pin. High indicates interrupt. Cleared by a read or write data operation.
OVRN Indicates a receiver over-run. The last received data was not read by the time the new data was ready.
PE Parity Error, when parity is selected, indicates that the parity of the received data did not match the parity of the data transmitted, which results from a lost data bit.
RDA Received data available in the receiver buffer.
TDRE Transmit Data Register Empty, ready for new data to be entered for transmission.

Control Register Bit Assignment:
The control register is selected when $R S$ is low, $R / W$ is low, and the ACIA is selected.

Bit 1 Bit $\varnothing$ Select Clock divide ratio, or reset


Bit 65 State of RTS Transmit control

| 0 | 0 | low | transmit interrupt disabled |
| :--- | :--- | :--- | :--- |
| 0 | 1 | low | interrupt enabled |
| 1 | 0 | high | interrupt disabled |
| 1 | 1 | low | interrupt disabled, break level |
|  |  |  |  |

Bit 7 Receive interrupt control
0 disabled
1 enabled

## Reference information

For further information on the 8253 Programmable Counter, see the Intel Data Catalog

Intel Corporation
3065 Bowers Ave.
Santa Clara, Ca 95051
For information on the 6820, 6850, and 6852, see the M6800 Microcomputer System Design Data from:

Motorola Semiconductor Products, Inc Box 20912
Phoenix, Arizona 85036

A good source of data for TTL IC's is:
The TTL Data Book for Design Engineers
Texas Instruments, Inc.
P.O. Box 5012

Dallas, Texas 75222

This monitor provides the routines that initialize and interface the LSI circuits on board the System Central Interface. Other monitor functions are a video driver for a video display interface, commands to display and alter memory, inigh-speed cassette routines to store and load blocks of memory or data in a check-summed format (Automatically starting and stopping the tape recorders), assign I/O devices, and program 2708's.

## Monitor Operation

When reset is activated, or on initial start-up, the monitor configures the I/0 ports, sets the speeds for cassette and serial port operation, and turns off the relays. The monitor then erases the screen of the video display, clears the command buffer area, outputs a prompt character ( $>$ ) to the main console output device, and waits for a command.

Commands consist of one or two letters followed by hexadecimal addresses where appropriate. Command letters must be followed by a space, then addresses as necessary. If a mistake is made when typing in a command, hit rubout or control H (backspace) to delete the last character typed. Addresses can be from one to four hex characters ( $\varnothing-9, A-F)$. If more than four hex characters are typed without any intervening space, only the last four characters will be used. For example, if ACløø is typed, only Cløø is seen by the monitor. To read 16 bytes of a tape, and place them at $\emptyset \emptyset \varnothing \varnothing$ hex, the following is sufficient: RS $\varnothing$ l $\varnothing$ (CR). All command strings are terminated by a carriage return. At this time, a line feed and carriage return are output, and the command is executed. If the command is erroneous, or there is an error in the command string, ERROR is output and the monitor waits for a new command. After the command has been executed, an appropriate remark is output and the monitor awaits another command.

## Escape

All command routines contain an escape. To return to the command mode, just hit the Escape (Esc) key on the main console input device. The routine being executed will abort, and the monitor will wait for a command input. When escape is used to exit cassette routines, the cassette relays are left activated. This allows the operator to rewind, or fast forward the cassette. Before using the cassette routines again, the reset switch must be activated, or a command to go to the start of the monitor. This re-initializes the cassette ports and turns the relays off.

## Video Driver Software

This driver assumes that the video interface is a 1 k block of memory located at CCDD to CFFF hex, and that $C C \varnothing \varnothing$ is the upper left-hand corner of the monitor screen. A cursor is displayed on-screen to indicate where the next character will be written control commands available are: carriage return, which moves the cursor to the left-
hand margin; line feed, which moves the cursor down one line; control $H$, a backspace, which moves the cursor back one position (when the cursor is at the left-hand margin, backspace moves it to the rigit-hand margin, one line up); rubout, does the same thing as backspace; control K , a vertical tab, moves the cursor to the upper left-hand corner of the screen (useful for live-action games, the program can use the upper left corner as a reference point to the rest of the screen when changing parts of the display); control I, form feed, which erases the entire screen and places the cursor at the upper left corner of the screen.

When the last line of the display is filled, the screen is scrolled up one line. The speed at which this occurs can be varied by typing $\varnothing-9$ during the scrolling process. $\varnothing$ is the slowest speed, about 2 seconds per line, and 9 is the fastest, about $1 \varnothing$ lines per second. Typing a space will stop the scroll. Typing any other character will start it again.

There are differences among the video interfaces offered on the market. The P-Tech VDM requires that bit 7 be low for characters output to the screen. The Poly VTI requires bit 7 be high. The areas where bit 7 is critical are illustrated in the video driver section of the assembly listing.

Jump Locations
At the beginning of the monitor are 12 jump instructions. The first jump simply jumps to the start of the monitor. The following fumps are the solution to easy interfacing with any program. Just call the appropriate routine and the SCI monitor takes over to do all the interface work. No need to worry about port locations, status data, or cassette routines. Each call ( 3 bytes) replaces at least 10 bytes in a typical status check, data handing routine, and the 12 bytes of cassette functions replace at least 38 bytes of code, in addition to providing much more advanced functioning. So program modification is simple, fast, and saves memory space.

Data in the routines is always handled in the accumulator (A). H is the high-order nibble of the SCI memory location (example, $D \varnothing \varnothing \varnothing$, $E \varnothing \varnothing \varnothing$, $E \varnothing \varnothing \varnothing$, etc.).

Høø3 Jumps to the input routine and returns to the calling program with the character from the console input device. Bit 7 is not masked.

Høø6 Jumps to the console output routine, outputs the character, then returns.
$H \varnothing \varnothing 9 \quad$ Cassette input. Calling this location starts the recorder, waits for a level indication, initializes the cassette circuits, and returns with a data byte. Each subsequent call returns with a byte of data.
$H \varnothing \varnothing C \quad$ End cassette read operation. Call this location when all the data has been read. This routine then waits for an inter-record gap (a blank spot), then turns off the recorder.
$H \varnothing \varnothing \mathrm{~F}$ Cassette write. This routine turns on the recorder, writes a leader on tape, sets the baud rate, outputs
the sync bytes then the data. Subsequent calls will write data to tape.

Hめl2 Cassette write end, writes a brief trailer, followed by an inter-record gap, turns off the recorder, and returns to the calling program.

Hø15 Parallel input from the second parallel input port. (Port $\mathrm{H} \varnothing$ ). Gets the data byte and returns. Useful for paper tape readers or analog-to-digital converters.

Høl8 Parallel output, port H6. Outputs a byte, then a strobe pulse to the peripheral, and returns.
$\mathrm{H} \varnothing 1 \mathrm{~B}$ Input status check. The status of the currentlyselected input device is polled. If data is not available, the zero flag is set. If data is available, the zero flag is not set, and the accumulator will return with the data byte. This is useful for escape routines, data input, and is directly compatible with Processor Technology software. Bit 7 is masked low on all data (E6 7F).
$\mathrm{H} \varnothing 1 \mathrm{E}$ Input masked. This routine is identical to $H \varnothing \varnothing 3$, but masks bit 7 low for all data. Saves two bytes in the user's program.

Hø21 Write B. This routine outputs the data byte passed in the B register. Directly compatible with Processor Technology software.
Hめ24 Call Escape, check input character, veturn
For details on the use of these jump locations, and interfacing the SCI to popular software, see appendix $H$, "Patches to Popular Software".

## Cassette Format

The cassette tapes written and read by this monitor have the following format: a leader of tone, a clock synchronizing byte (3C hex), a data synchronizing byte (E6 hex), a low-order starting address byte (where the data will be stored), a high-order starting address byte, a high-order block-length byte, a low-order block-length byte (the number of data bytes), the data, and a checksum which is the 8-bit result of adding all the bytes (excluding the clock and data sync bytes), and finally a trailer tone and an interrecord gap (a blank spot).

When an external program is calling cassette functions via the jump locations, the sync bytes and the leader and trailer tones with an inter-record gap are generated by the SCI. The header and data information are the responsibility of the calling program.

## Monitor Commands

The SCI monitor will accept both upper and lower case characters. In the command mode, bit 7 is ignored.

In the following explanations, CR means Carriage Return, or simply Return. ADDR means a one to four character hex address. Commands, their operands, and hex addresses must be separated by one space.

AI K, $P$, or $S(C R)$ Assign Input device, either Serial, Parallel, or the Keyboard port at IC44. When reset is activated, input returns to the device specified by the DIP switch (see page 11).

AO P, S, or V(CR) Assign Output device, either Parallel, Serial, or Video interface using the SCI video software driver.

Dump hex data from memory. Dumps one line of 16 hex bytes, starting at ADDR. To dump additional data, hit the space bar. To return to the command mode, hit any other character.

DA ADDR ADDR(CR) Dump ASCII; displays memory data in hex bytes, and the ASCII equivalent. Useful for locating tables and comments in programs.

E ADDR(CR)

EM ADDR(CR)

G ADDR(CR)
H ADDR ADDR(CR)

I NN(CR)
Enter memory. The memory address and its content are displayed. If a new byte is desired, type it in and it will be entered into memory. The byte actually stored will be displayed, and the next memory location will be displayed. If the content is to remain unchanged, typing a space will bring the next byte. Typing a non-hex character will terminate the routine. If you want to move backward in memory, hit Control H , a backspace.

Enter Memory. Similar to the E command, but no data is read from memory. Sixteen bytes may be entered per line of type. This routine saves paper when using a printer for console output. Use the DA or $D$ command to verify correct entry of the data into memory.

Go. Transfers execution to that address.
Hex arithmetic. Calculates the sum and difference of the two hex numbers. The first number printed is the sum, the second is the result of subtracting the first number from the second.

Input from port NN. The byte at the specified port is displayed. To repeat the input, hit the space bar. To return to the monitor, hit any other key.

M ADDR ADDR ADDR(CR) Move memory from the block specified by
the first two addresses, to a block starting at the third. The data is moved and then verified. Any errors that occurred in the move are listed. Can be used as a simple memory check, see appendix $G$.

0 NN MM (CR)

P ADDR ADDR(CR)
$R C(C R)$

RS ADDR ADDR(CR) Read Specify. If no address is given, reads all information in the file and places it in memory, including the header, beginning at $\varnothing \varnothing \varnothing \varnothing$. If one address is given, the information is placed in memory starting at that address. If two addresses are given, that block of memory is filled with the first part of the file. The recorder is stopped when it reaches an inter-record gap. The checksum is calculated to check for errors, except where two addresses are given. In that case, TAPE ERROR always appears.
$R V(C R)$
Read Verify. Reads a file and compares i.t with memory. Useful for checking files as they are written to make sure there are no errors.

S ADDR ADDR N1 N2..N9 Search the memory block specified by the two addresses, for the hex character string N1 N2...N9. The address of the start of each string found is printed. Up to 9 bytes may be specified, and a minimum of one, or the routine will loop forever. If all memory is searched, allow 50 seconds for execution.

SR NNNN(CR)

SS NNNN (CR)

SW NNNN (CR)
$V A D D R A D D R$ ADDR(CR) Verify a block of memory specified by the first two addresses, with a block of memory starting at the third address. Useful for checking the programming of $2708^{\prime} \mathrm{s}$, or changing bits in different memory blocks.

WC $A D D R$ WDDR(CR) Write Cassette, the memory block specified by the two addresses, in the format defined earlier. The routine says WRITTEN when done. Automatically starts and stops the recorder as do all tape commands.

Z $A D D R A D D R$ NN(CR) Zero memory from $A D D R$ to $A D D R$. If NN is not given, zeroes are written. If NN is given, the memory block is filled with that hex byte. Makes a simple means to fill memory with sync bytes to write a sync tape for recorder set-up. Or fill memory with FF to check the erasure of $2708^{\prime} s$.

Hitting Escape will cause an exit from all routines, and return to the command mode. If used during a cassette routine, reset must be hit before trying to use the cassette routine again, or Go to the start of the monitor (HOOO), or output 00 to port $H 2$ the cassette port control.

Cassette commands turn the relays on and off to control two recorders, one for read and one for write. If only one recorder is used, wire the two sets of relay contacts together in parallel, as outlined on page 6, Cassette Control.

Keyboard problems
Keyboards with unlatched outputs may have problems with Escape functions. Increasing the keyboard strobe pulse to 20 ms will allow the strobe and escape character to be recognized, while the monitor is executing a program. Also, some encoders are noisy on the data lines when not active. A false escape character may be occasionally generated which the SCI monitor will interpret as a legitimate escape. Connecting a transistor such as a $2 N 3904$ to bit 4 of the keyboard data lines, and driving it with an active-low strobe will elmainate the problem.

Using the 8253 for a sweep generator.
Using the cassette output pin ( 2 of IC pad 41 for low level, and pin 3 for high level) as the signal source, and the following program, the 8253 can be programmed to sweep any range of frequencies. This range can start as low as 30 hz , and go as high as 1 mhz (to use the 1 mhz band, the output capacitors of the cassette system must be bypassed, so get the signal direct from pin ll of $\because$ IC-31, the 74LS386).

The program as written produces an electronic siren, which provides interesting results when piped through a stereo. For a slowly changing tone that can be used to check the response of an audio amplifier, change the following lines:

0000210030 this changes the start frequency
OOOA 1E 80 this changes the total range
00130100 EO this changes the magnitude of the step

Program to sweep the 8253
00002100 OC set the starting frequency to 651 hz
0003 Ol AO FF set $B$ to subtract 60 hex each freq change
0006 3E 76 set up 8253
0008 D3 DB SCI address set for DOOO. change to suit
OOOA 1E IO set number of steps
OOOC 7D output L to 8253 counter
OOOD D3 D9 change D9 for other address of SCI
OOOF 7C output $H$ to 8253 counter
0010 D3 D9 change D9 for other address of SCI
0012 C5 Push B to save
00130100 FA set up a delay
001603 increment BC
001778 MOV A,B
0018 Bl ORA C
0019 c2 1600
001 Cl POP B restore BC
001D 09 DAD B add B to HL
OO1E 1D DCR C decrement step counter
001F C2 OC 00 JNZ loop until done
0022030000 JMP start all over
Try other variations of locations 0000, 000A, and 0013 for different sound effects.

Using the $E$ command and the $M$ command, a simple check of a block of memory can be made to look for hard errors (Always bad bits). This is a simple, fast memory check. Since it only executes once, it is not always able to find elusive errors, but will pinpoint hard memory failure.

Using the E command, to check and verify entry, enter the following sixteen bytes of data in the first sixteen locations of the block of memory to be tested: øø 112233445566778899 AA BB CC DD EE FF

Hit return and using the Move command, enter:
M ADDRI ADDR2 $\operatorname{ADDR} 3$ (CR)
ADDRI is the beginning address of the sixteen bytes of data, ADDR2 is the ending address of the block of memory, minus 16, and ADDR3 is ADDRI plus 16.

## Example:

A block of unknown memory at $2 \varnothing \emptyset \emptyset$ hex to $2 F F F$ is to be tested. First, enter the sixteen test bytes:

E $2 \emptyset \emptyset \varnothing(C R)$
$2 \emptyset \varnothing \emptyset$ NN $\varnothing \varnothing$ øø
$2 \not 01$ NN 1111
2øø2 NN
and so on untll all 16 bytes are correctly entered. NN above is the present content of the memory location.

Then use the Move command :
M $2 \emptyset \emptyset \emptyset 2 F E F 2 \emptyset 1 \varnothing(\mathrm{CR})$
This command then fills the block of memory with the sixteen bytes of test data and checks for any errors. If any errors do show up, the memory is unusable and should be tested thoroughly to locate the problems.

Interfacing the SCI Monitor to ESP-1
ESP-1 is an Assembler, Editor, and Monitor for an 8080, written for the 8080 by Michael Shrayer. The following patches are for the SCI Monitor version 1.5.

| Location | Code before | for SCI |  |
| :---: | :---: | :---: | :---: |
| 6052 |  | CD ø6 Hø | Output |
| 6 CAD |  | CD øб Hø | Output |
| 7øC6 | DB $\emptyset \varnothing$ | C3 1E | Input |
| $7 \varnothing \subset 8$ | E6 ø2 | Hø |  |
| $7 \varnothing \mathrm{CA}$ | CA C6 70 |  |  |
| $700 D$ | DB $\emptyset 1$ | C3 24 HO | Escape Routine |
| 7ØCF | E6 7F |  |  |
| 70D1 | C9 |  |  |
| 7ØDF | DB øø | Øø Фø | Output |
| 70E1 | E6 Ø1 | $\emptyset \emptyset \square$ | " |
| 70E3 | CA DF $7 \emptyset$ | $\emptyset \emptyset \emptyset \emptyset \emptyset \emptyset$ | " |
| 70E6 | 78 | 78 | " |
| 70 E 7 | D3 01 | C3 ø6 Hø | " |
| 70E9 | 09 |  |  |
| 77 E 8 | 26 | 29 | Cassette Read |
| 77 EC | 26 | 29 |  |
| $77 \mathrm{~F} \varnothing$ | 26 | 29 | " " |
| 77FA | 26 | 29 | " " |
| 7815 | 26 | 29 | " " |
| 781D | CD ED 70 | CD ØC Hø | " " |
| $782 \emptyset$ | 21 øø 6ø | CD ED 70 | " " |
| 7823 | C3 DE 73 | $21 \varnothing \varnothing 6 \emptyset$ | " " |
| 7826 | OD BD $7 \emptyset$ | C3 DE 73 | " " |
| 7829 | DB 6E | CD BD | " " |
| 782 B | E6 10 | 76 C3 | " " |
| 782D | c2 2678 | Ø9 Hø 78 | " " |
| 776 C | CD A7 77 | C3 7477 | Cassette Write |
| 7776 | A7 | AA |  |
| 777A | A7 | AA | " " |
| 777 E | A7 | AA | " " |
| 7782 | A7 | AA | " " |
| 7780 | A7 | AA | " " |
| 779A | A7 | AA | " " |
| 77 Al | 215 F 78 | CD $12 \mathrm{H} \varnothing$ | " " |
| 77 A 4 | C3 E5 76 | 215 F 78 | " " |
| 77 A 7 | F5 | 63 | " " |
| 77 A8 | CD BD 7ø | E5 76 F5 | " " |
| 77 AB | DB 6E | CD BD | " " |
| 77 AD | E6 20 | 70 Fl | " " |
| 77AF | C2 A8 77 | 03 ØF HØ | " " |

In the Escape routine, if ESC is typed the SCI monitor will take over. This is not a standard character for ESP-1.

In the cassette read routine, if ESP-l detects an error, the SCI monitor must be reset to turn off the recorder, and reset the cassette port.

The write cassette routine takes full advantage of the SCI monitor to write a tape and control the recorder.

In the above, $H$ stands for the 4 k memory block of the SCI (D $\varnothing, E \varnothing$, etc.).

Patches for Cromemco $3 k$ Control Basic
Cromemco 3k Control Basic is a simple Basic modelled after Palo Alto Tiny Basic. It has integer arithmetic, and can call its programs located anywhere in memory. Its greatest utility is in control applications, such as Data Aquisition, and process control.

| Location | Code Before | Code for |  |
| :---: | :---: | :---: | :---: |
| EE9D | DB $\emptyset \emptyset$ | F1 E5 | Output routine |
| EE9F | E6 80 | F5 E6 |  |
| EEAL | CA 9D EE | 7F CD 06 | " |
| EEA4 | Fl | Hø | " |
| EEA5 | E5 | $\varnothing \varnothing$ | " |
| EEA6 | F5 | $\varnothing \varnothing$ | " |
| EEA7 | E6 7F | $\varnothing \varnothing$ ¢ $\varnothing$ | " |
| EEA9 | D3 01 | $\varnothing \varnothing$ Øø | " |
| EEEE | DB $\emptyset \varnothing$ | CD 1B | Input routine |
| EEFO | E6 4ø | Hø Øø |  |
| EEF2 | C8 | C8 | " |
| EEF3 | DB ø1 | Øø øø | " |

The SCI input routine checks status of the selected input device, and returns with the zero flag set if no data is available. If data was available, the zero flag is not set, and the accumulator contains the data input.

In the above, $H \varnothing$ represents the memory block of the SCI monitor, such as $D \varnothing$, Eø, etc.

An aggressive game of chess, a challenge for any player.

Location Original Code SCI

| ØDF DB $\varnothing \varnothing$ | CD $\varnothing 3$ | Input Routine |
| :---: | :---: | :---: |
| ØDP3 E6 40 | HO Øø |  |
| ØDF5 CA FI $\emptyset \mathrm{D}$ | $\phi \varnothing$ øø $\varnothing \varnothing$ |  |
| $\emptyset \mathrm{DF8}$ DB $\varnothing 1$ | $\varnothing \varnothing$ øø |  |


| $\emptyset D E 6$ | DB | $\varnothing$ |
| :--- | :--- | :--- |
| $\varnothing D E 8$ | E6 $8 \varnothing$ | $C 3$ |
| $H \emptyset$ | Output Routine, Character |  |

Ø1D7 03 Øø E $\varnothing$
$03 \varnothing \varnothing$ Hø Return linkage to monitor

The game of CHASE
ø1A9 DB øø
Ø1AB E6 $4 \varnothing$
$\varnothing 1 \mathrm{AD}$ CA A9 $\varnothing 1$ $\emptyset 1 B \emptyset$ DB $\varnothing 1$

CD $\varnothing 3$ Input Routine
H $\varnothing \varnothing$
øø $\varnothing \emptyset \varnothing \varnothing$
$\varnothing \varnothing \emptyset \varnothing$

Output is always to the video display memory located at CCD $\quad$ to CFFF hex. (Normally a VDM-I)

## TREK-80

The best game of STAR TREK to hit the market. A liveaction game, it's a challenge to win. Output is always to a video display memory which must be equivalent to a VDM-1. TREK-80 is from Processor Technology.

| $\varnothing 1 B \emptyset$ DB øø | CD 1B | Input Routine |
| :---: | :---: | :---: |
| ø1B2 øø | Hø |  |
| O1B3 E6 $4 \varnothing$ | $\varnothing \emptyset \quad \varnothing \varnothing$ |  |
| ¢1B5 08 | C8 |  |
| $\emptyset 1 \mathrm{B6}$ DB $\emptyset 1$ | Фø øø |  |
| Ø1B8 E6 7F | E6 7F |  |

This is a typical Processor Technology input routine and is applicable to most of their software.

| -0,00 |  |  | 0005 | * ${ }^{\text {a }}$ * *** | SCI | MONITOF VERSIOA | 106******* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DO'00 |  |  | 0010 | PORT | EQU: | ODOH | PORT LCCATION: |
| D0,00 |  |  | 001.5 | StACK | EQU | CDFCOH | STACK IOCATION |
| DOOO |  |  | 0020 | STKO | EQU | STACK+4 | INF DEV COCE |
| 0000 |  |  | 0025 | STK1 | EQU | STACK+5 | OUT DEV CODE |
| DO'0 0 |  |  | 0030 | STK2 | EQU | STACK+6 | SCROLL SPEED |
| 0000 |  |  | 0035 | STK3 | EQU | STACK+7 | CASS READ ¢PD |
| 0000 |  |  | 0040 | STK5 | EQU | STACk+9 | CASS WFITE SPD |
| DO'O 0 |  |  | 0045 | STK7 | EOU | STACK + 11 | SERIAL SFEED |
| DO'0 0 |  |  | 0050 | STK9 | EQU | STACK +13 | TEMP STORE |
| DO'0 0 |  |  | 0055 | STK10 | EQU | STACK +14 | VDM CHARACTER |
| 0000 |  |  | 0060 | STK11 | EQU: | STACK+15 | VDM FOINTEF. |
| 0000 |  |  | 0065 | STK13 | EQU | STACK+17 | TEMP STORE |
| 0000 |  |  | 0070 | STK15 | EQu | STACK +19 | TEMP STORE |
| 0000 |  |  | 0075 | STK16 | EQU | STACk +20 | TEMP STORE |
| D0'00 |  |  | 0080 | STK17 | EOU | STACK+21 | - INPUT BUFFER |
| DO'O 0 |  |  | 0085 | PORTO | EQU | PORT+0 | PAR INF |
| DO'00 |  |  | 0090 | PORT1 | EQU | PORT+1 | CONTROL REG |
| 0000 |  |  | 0095 | PORT2 | EQU: | FORT+2 | CASSETTE CONTROL |
| 00000 |  |  | 0100 | PORT 3 | EQU | FORT+3 | CONTROI. |
| 0000 |  |  | 0105 | PORT 4 | EQU | PORT+4 | KEYBD IN |
| DO'0 0 |  |  | 0110 | PORT5 | EQU | PORT+5 | CONTROL |
| 00'00 |  |  | 0115 | PORT6 | EQU | PORT+6 | PAR OUT |
| DOOC |  |  | 0120 | PORT 7 | EQU | FORT+7 | CONTROL |
| DOAO |  |  | 0125 | PORT 8 | EQU | FORT +8 | CASS READ CLOCK |
| 0000 |  |  | 0130 | PORT9 | EQU | PORT+9 | CASS WPITE CLOCK |
| 0000 |  |  | $01: 5$ | PORTA | EQU | PORT+10 | SERIAL CLOCK |
| DO'00 |  |  | 0140 | PORTB | EQU | PORT+11 | CONTROL REG |
| D0'00 |  |  | 0145 | PORTC | EQU | FORT+12 | UART CONTROL |
| DO'00 |  |  | 0150 | PORTD | EOU | PORT+1? | UART DATA |
| 0000 |  |  | 0155 | PCRTE | EQU | PORT 14 | CASS SSDA CONT |
| DO'O |  |  | 0160 | PORTF | EQU | PORT+15 | CASS SEDA CATA |
| 0000 |  |  | 0165 | * *CODE | STAR | TS HERE** |  |
| DCOC | (3 27 | [0 | 0170 | SCI | JMP | INIT | INIT PORTS |
| DOO? | C3 64 | [2 | 0175 |  | JMP | INPUT. | INPUT |
| DOOE | C3 95 | [2 | 0180 |  | JMP | WRITE | WRITE |
| DOO ${ }^{\circ}$ | C3 D1 | [3 | 0185 |  | JMP | CASRO | CASS IAPUT |
| DOOC' | C3 D6 | [4 | 0190 |  | JMP | ENO | TURN OFF RELAY |
| DCOF | C3 :90 | [5 | 0195 |  | JMP | CASWCO | CASS HRITE |
| D012' | C3 EE | [5 | 0200 |  | JMP | caswz | ENS OF WRITE |
| D01E | C3 70 | [2 | 0205 |  | JMF | FIN | PAR INPUT |
| 00.1E | C3 B0 | [2 | 0210 |  | JMP | FOUT | PAR OUTPUT |
| D0:1E' | C3 52 | [2 | 0215 |  | JMP | ISTAT | INP STATUS |
| DC1E: | C3 5E | [2 | 0220 |  | JMP | INFM | INP MAEKED |
| 021 | C3:98 | [2 | 0225 |  | JMP | WR ITE | Q OUT |
| D024 | C3 :58 | [2 | 0230 |  | JMP | ICHAF | ESCAPE |
| 0027 | 3100 | [F | 0235 | INIT | LXI | SP, STACK | SET STACK |
| D02 1 | 3 E 0 C |  | 0240 |  | MVI | $\mathrm{A}, \mathrm{OCL}$ | erase video |
| DC20 | CD BC | [2 | 0245 |  | CALL | V DM +1 |  |
| D0 2 F | 3 E 30 |  | 0250 |  | MVI | A, 30t | INIT PARALLEL FORTS |
| D031 | [3 101 |  | 0255 |  | OUT | PORT1 | INIT parallel forte |
| DOZて | [3 D3 |  | 0260 |  | OUT | PORT 3 |  |
| DO3E | [3:05 |  | 0265 |  | OUT | PORT5 |  |
| D037 | $[307$ |  | 0270 |  | OUT | PORT7 |  |
| 0035 | [. 3 DE |  | 0275 |  | OUT | PORTE | CLOCK FiEG |
| 00.3E | 57 |  | 0280 |  | sue | A | SET INPUT PORTS |
| -03C. | 13 D4 |  | 0285 |  | OUT | FORT4 |  |




D11[ 23
B11E OC
D1:1F CA CD [4
D1.22 C3 17 [1
D125 23
П126 5E
0127 23 :
D12E 56
D12 E E
D12 1 E9
D12E F. 5
D12C 11 '00 00
D1:2F 2 A D1 [F
D132 7E
D132 FE DE
0135' CA 70 [1
D13E 7E
D13c FE 20
D13E CA 47 [1
D13E FE DE
D1'4C CA 47 [1
D142 23
ก146 C3 38 [1
D147 23
D148 22 D1 [F
D14E $2 B$
D14C' CD 6E [1
$\begin{array}{llll}014 F & 5 F & & \\ 0150 & C 0 & 68 & {[1}\end{array}$
015 Z 07 .
015407
D155 07 : $\quad$ :
D156 07
0157 ع3
D15 5 5F
D15c' CD 68 [1
D15C 57
015 C CD 68 [1
D1'60' 07
0161' 07
D16\% 07
016? 07
0164 \&2
D165 57
D166E1
П167 C9
D16E 2 B
$01657 E$
D16f FE 20
$0166^{\circ}$ C2 72 [1
016F E1
D170 E1
D171 (9
0172 CD $7 E$ C1
D175. [A CD [4
D178 FE 10
D17f C2 CD [4
0175 C9
D1.7E [6.30

| 0880 |  | INX | + |
| :---: | :---: | :---: | :---: |
| 0885 |  | INP. | $C$ |
| 0890 |  | $j Z$ | ERPOF |
| 0805 |  | JMF | CMC 2 |
| 0900 | CMD3 | INX | ト |
| 0905 |  | MOV | E.M |
| 0910 |  | INX | + |
| 0915 |  | MOV | [, M |
| 0920 |  | XICHG | FLACE |
| 0925 |  | PCHL | FLACE |
| 0930 | CONVO | PUSH. | + |
| 0935 |  | LXI | [,OOCOF |
| 0940 |  | L.HL D | ¢TK13 |
| 0945 |  | MOV | A, M |
| 0950 |  | CPI | COH |
| 0955 |  | $J Z$ | CONV $2+\varepsilon$ |
| 0960 |  | MOV | $A, M$ |
| 0965 |  | CPI | 2 OH |
| 0970 |  | $\downarrow \mathrm{Z}$ | CONV1 |
| 0975 | . | CPI | COH |
| 0980 |  | $J Z$ | CONV1 |
| 0985 |  | INX | - |
| 0950 |  | JMP | CONVO+13 |
| 0995 | CONV 1 | INX | - |
| 1000 |  | CHLD | ¢TK12 |
| 10.5 |  | [CX | F |
| 1010 |  | CAL. L | CONV |
| 1015 |  | MOY | E, A |
| 1020 |  | CALL | CONVZ |
| 1025 |  | RLC |  |
| 10:0 |  | RLC |  |
| 1035 |  | RLC |  |
| 1040 |  | RLC |  |
| 1045 |  | ADD | E |
| 1050 |  | MOV | E, A |
| 1055 |  | C:ALL | CONVE |
| 1060 |  | MOV | C, A |
| 1065 |  | C:ALL | CONVE. |
| 1070 |  | P:LC |  |
| 1075 |  | RLC |  |
| 1080 |  | F. LC |  |
| 1085 |  | RLC |  |
| 1050 |  | A DC: | [ |
| 1095 |  | MOV | [, A |
| 1100 |  | POP | + |
| 1105 |  | RET |  |
| 1110 | CONV2 | CCX | - |
| 1115 |  | MOV | A, M |
| 1120 |  | CPI | COH |
| 1125 |  | JNZ | CONV 3 |
| 1120 |  | POP | + |
| 1135 |  | POP | + |
| 1140 |  | RET |  |
| 1145 | CONV 3 | CALL | CONV4 |
| 1150 |  | JC | ERFOF |
| 1155 |  | CPI | 10 H |
| $11 \in 0$ |  | JNC | ERROF |
| 1165 |  | RET |  |
| 1170 | CONV 4 | SUI | 2 OH |

INCREMENT COMMAND COUNTE COULON'T FIND IT LOOP
GET ADCRESS OF COMNAND SAVE IA D AND E

CE IN FL
HL IN FC AND GO
SAVE HL
ZERO DE
GET FOINTEF TO BUFFER
WAS IT A CARRIAGE RET?
YES

A SPACE?
YES
A CARRIAGE RET?
YES
INCREMENT FOINTER
l. 00 P

INCREMENT FOINTER
©AVE PCINTER
GET CHARACTEF
GET LOHER AIBBLE
save in E
EET NIEBLE
ROTATE

GET 1 ST HAI.F
NOW HAVE 1ST BYTE
GET $2 N E$ EYTE

GET CATA

DONE?
NO
EET RIC OF LAST CALL

CONVERT
CARRY SET
A AUMBER ?
NO
ASC EIAS


| D1FA | $\varepsilon 0$ |  | 1470 |  | $A D C$ | E |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D1FE | 77 |  | 1475 |  | MOV | $N, A$ |
| D1FC | C3 96 | ［3 | 1480 |  | JMP | SPACE |
| D1FF＇ | CD 2 B | ［1 | 1485 | PFOGO | C．ALL | CONVC |
| D202 | EB |  | 1490 |  | XiCトG |  |
| D20 ${ }^{\text {2 }}$ | CD 2E | ［1 | 1455 |  | CALL | CONVC |
| DÉOE | 3 EAO |  | 1500 |  | MV I | $A, O A O F$ |
| D20ध | $32: C D$ | ［．F | 1505 | PFOG 1 | ¢＇T | ©TK9 |
| D20E | ［5 |  | 1510 | ． | PUSH | ［ |
| D20 0 | E 5 |  | 1515 |  | PUSH | ＋ |
| D2．0［＇ | 0100 | 04 | 1520 |  | LXI | E， 04 CO |
| OE1C | CDC5 | ［3 | 1525 |  | C．AL．L | ESCAF |
| D2：13 | $7 E$ |  | 1520 | PFOG 2 | MOV | $A, M$ |
| D21： | 12 |  | 1535 |  | STAX | ［． |
| D215 | 13 |  | 1540 |  | INX | ［ |
| D216 | CD 2 B | ［2 | 1545 |  | C：AL．L | ［ONE |
| 021： | （2） 13 | ［2 | 1550 |  | $\cdots \mathrm{NZ}$ | FROG2 |
| 021C | E1 |  | 1555 |  | POP | ＋ |
| D215 | ［1 |  | 1560 |  | POP | ［ |
| D2＇1E＇ | 3 A｀CD | CF | 1565 | － | LDA | STK9 |
| 0221 | 3 D |  | 1570 |  | C．CR | A |
| 口2．22 | C2 08 | ［2 | 1575 |  | JNZ | FROG1 |
| D2 25. | 0100 | 04 | 1580 | VERO | LXI | E，C 4 COF |
| D＜2 2 | C3 26 | ［5 | 1585 |  | JMP | VERFY +6 |
| D22E | 23. | ， | 1590 | DONE | INX | F |
| D2 $2 C^{\circ}$ | OB |  | 1595 |  | CCX | E |
| －D2 2 ［ | 97 |  | －1600 |  | SUB | A |
| D22E | F 0 |  | 1605 |  | ORA | B |
| D22F | E1 |  | 1610 |  | OR A | C |
| D23 3 | C9 |  | 1615 |  | RET |  |
| D2 31 | $7 E$ |  | 1620 | COMN T | MOV | $A, M$ |
| D2 32 | CD：99 | ［2 | 1625 |  | C．ALL | WRITE |
| 0235 | 23 |  | 1630 |  | INX | $t$ |
| D23E | F 7 |  | 1635 |  | ORA | A |
| 吹37 | F2 31 | ［2 | 1640 |  | $J P$ | COMNT |
| D23 | C9 |  | 1645 |  | RET |  |
| D＜3E＇ | $C D 3 E$ | ［． 2 | 1650 | DELA 2 | CALL | ［ELAY |
| D2 3E | C5 |  | 1655 | DELAY | PUSH | E |
| D23F | 0100 | 70 | 1660 |  | LXI | E， 70 OCOH |
| D2 42＇ | 03 |  | 1.665 |  | INX | E |
| D243 | 57 |  | 1670 |  | SUE | A |
| 0244 | E 0 |  | 1675 |  | ORA | B |
| D2 45 | E1 |  | 1680 |  | ORA＇ | C |
| D24 ${ }^{\prime}$ | C2 ： 42 | ［2 | 1685 |  | JNZ | ［ELAY＋ 4 |
| D＜ $4{ }^{\text {c }}$ | C1 |  | 1690 |  | POP |  |
| D24\％ | C9 |  | 1695 |  | RET |  |
| D＜ 4 E | （5 |  | 17000 | ［ELAS | PUSH | B |
| D24C | 0100 | E 8 | 1705 |  | LXI | E，OBCOCH |
| D24F＇ | C3 42 | ［2 | 1710 |  | JMP | ［ELAY＋ 4 |
| D2．52 | CD 86 | ［2 | 1715 | ISTAT | CALL | CHKST |
| D25 5 | E6＇80 |  | 1720 |  | ANI | 80 H |
| D257 | C 8 |  | 1725 |  | R Z |  |
| 0258 | CD 6A | ［2 | 1730 | ICHAR | CALL | INPUT＋$\epsilon$ |
| 0＜5E | E6 7F |  | 1735 |  | ANI | 7 FH |
| D2 5［ | C9 |  | 1740 |  | RET |  |
| D25E | CD 64 | ［2 | 1745 | INPM | C．ALL | INPUT |
| D261 | E6 7F |  | 1750 |  | ANI | 7 FH |
| $0263^{\prime}$ | C9 |  | 1755 |  | RET |  |
| D2 64． | CD 52 | ［2 | 1760 | IAPUT | $C A L L$ | ISTAT |

GET NIEBLE STORE

FROGRAN 27C8
§AVE IA HL
DO 16CX
SAVE A

W．ANT TO CUIT？
EET BYTE
PLACE IN 2708

L．OOP
EET HL
GET DF
GET COUNT EYTE
DECREMENT IT
LOOP
VERIFY DATA

GET BYTE
WRITE IT

EIT 7 FIGH ？
NO，LOCP

THO TINES
SAVE＇B

DONE？

RESTORE BC

HALF AS NUCH DELAY
GET STATUS
EIT 7
$Z=N C$ CATA
EET CHAR
MASK BIT 7

MASK BITS C－6
CHECK STATLS

| D267 | ${ }^{\text {c A }}$ | 64 | ［2 | 1765 |  | $J Z$ | INPUT | LOOP TIL READY |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0261 | 3 A | © C | ［F | 1770 |  | LDA | STKO | INPUT［EVICE |  |
| － 0.66 | E 7 |  |  | 1775 |  | ORA | A |  |  |
| D2 6E | CA | 78 | ［2 | 1780 |  | $\checkmark$ \％ | FINO | FRIMARY fafallel | INPUT |
| 0271 | 3 D |  |  | 1785 |  | ［CR | A | primary farallel | －INPUT |
| －0272： | CA | ＇82 | ［2 | 1790 |  | $J \mathrm{~L}$ | FIN1 | OTHER FARALLEL | INPLT |
| C＜ 75 | ［ ${ }^{\text {c }}$ | ＇D |  | 1795 |  | IN | FORTC | INPUT FROM SERIA |  |
| D277＊ | C9 |  |  | 1800 |  | RET |  | INPUT FROM SERIAL |  |
| D＜ 78. | ［．B | D4 |  | 1805 | PINO | IN | FORT4 |  |  |
| 0271 | 00 |  |  | 1810 |  | NOP |  | CMA IF IAV DATA |  |
| 吹7E | C9 |  |  | 1815 |  | RET |  | cha if inv data |  |
| D2．7C | 「．${ }^{\text {c }}$ | ＇01 |  | 1820 | PIN | IN | FORT1 | CHECK §TATUS |  |
| D27E | E 7 |  |  | 1825 |  | OR A | A | CHECK EIT 7 |  |
| DC7F | F2 | 7 C | ［2 | 1870 |  | JP 1 | FIN | LOOP |  |
| D2．82 | ［B | ＇00 |  | 1835 | PIN1 | IN | PORTO |  |  |
| D284 | 00 |  |  | 1840 |  | NOP |  | CMA IF INV DAT |  |
| D285 | ${ }^{1} 9$ |  |  | 1845 |  | RET |  | CMA IF INV DAT |  |
| 0286 | 3 A | ＇C4 | ［．F | 1850 | criks $T$ | LDA | STK 0 | CHECK ¢TATUS |  |
| D2 8\％ | E 7 |  |  | 1855 |  | ORA | A |  |  |
| D2 81 |  | 95 | ［2 | 1860 | ： | $J Z$ | PINS 0 | PAR STAT |  |
| 0285 | 3 D |  |  | $18 \in 5$ |  | CCR | Prso |  |  |
| D28E |  | ＇D1 |  | 1870 |  | IN | FORT1 | STATUS PORT |  |
| D2＇90 | C 8 |  |  | 1875 |  | R Z |  | gtatus port |  |
| D2 91 |  | DC |  | 1880 |  | IN | FORTC | SERIAL STATUS |  |
| D2 93 | 0 F | ， | － | 1885 |  | FRC |  | GET BIT 0 ． |  |
| 0294＂ | C 9 |  |  | 1890 |  | RET |  |  |  |
| － 295 |  | 05 |  | 1895 | PINSO | IN | PORTE | STATUS PORT |  |
| 2297 | C9 |  |  | 1900 |  | RET |  | Status port |  |
| D298 | 78 |  |  | 1905 | WFITB | MOV | AsB | GET DATA |  |
| D2 9 5 | F5 |  |  | 1910 | WFITE | PUSH | PSW | SAVE A |  |
| 0291 | 3 A | C5 | ［ F | 1915 |  | L＇DA | ¢TK1 | OUT LEVICE |  |
| D29 ${ }^{\text {c }}$ | E7 |  |  | 1920 |  | ORA | A |  |  |
| 02＇9E | CA | B日 | ［2 | 1925 |  | $J \mathrm{~J}$ | VDM： | VICEO FOUTINE |  |
| D2 A1 | 3 D |  |  | 1930 |  | －CR | A | vileo foutine |  |
| D2．A2 | CA | ＇81 | ［2 | 1935 |  | J Z | POUT＋1 |  |  |
| DEAEV |  | DC |  | 1940 | SOUT | IN | FORTC |  |  |
| D2 A7 |  | ：02 |  | 1945 |  | A＇NI | C 2 H | READY |  |
| D＜AE 9 | CA | A 5 |  | 1950 |  | JZ | Sout | LOOP |  |
| D2AC | F1 |  |  | 1955 |  | FOP | PSW | GET A |  |
| D2：AC |  | DO |  | 1960 |  | OUT | PORRTD |  |  |
| DCAF | C9 |  |  | 1965 |  | RET |  |  |  |
| D2＇6C | F5 |  |  | 1970 | POUT | PUSH | FSk | SAVE A |  |
| D2 B1 |  | D7 |  | 1975 |  | IN | FORT7 | CHECK STATUS | － |
| D2 B2 | E． 7 |  |  | 1980 |  | ORA | A | BIT 7 HIGH？ |  |
| 02 EL | F2 | ＇B1 | ［2 | 1985 |  | JP ${ }^{\text {P }}$ | FOUT＋1 |  |  |
| $02 \mathrm{B7}$ | F1 |  |  | 1950 |  | POF | FSW | CET A |  |
| D2 BE |  | D6 |  | 1.995 |  | OUT | FORTE |  |  |
| DERE | C9 |  |  | 2000 |  | RET |  |  |  |
| DEBE | F1 |  |  | 2005 | V［M | POP | FSW | GET A． |  |
| D2BEC | C5 |  |  | 2010 |  | PUSH | B | SAVE REGIs |  |
| D 28 BC | ［5 |  |  | 2015 |  | PUSH | ［ | SAVE HEC |  |
| D2 BE | E5 |  |  | 2020 |  | PUSH | ＋ |  |  |
| D2 BF | F5 |  |  | 2025 |  | PUSH | FSW |  |  |
| 02 CC | 2 A | CF | ［F］ | 2030 |  | L．HLD | ¢TK11 | GEt VDM FOINTEF |  |
| 02 Cz | FE | O C |  | 2035 |  | CPI | $\mathrm{CCH}^{\text {ch }}$ | ERASE SCREEN ？ |  |
| D2CE | CA | 44 | ［3 | 2040 |  | $J 7$ | FF | YES |  |
| D2CE | FE |  |  | 2045 |  | CPI | COH | CARRIAGE RETURA | 3 |
| D2CA | CA | 54 | ［3 | 2050 |  | $J$ J | CR | Carriace me turk |  |
| DECL | FE | OA |  | 2055 |  | $C P I$ | OAH | LINE FEEO |  |




| D3 Bz |  | 3 A |  | 2650 |  | CPI | ${ }^{2} \mathrm{AH}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D3 B $^{\text {¢ }}$ | C 8 |  |  | 2655 |  | R C | YES |
| DJ $\mathrm{BE}^{\circ}$ | C6 | 07 |  | 2660 |  | ADI | O7H |
| D 2 B | C9 |  |  | 2665 |  | RET |  |
| DてBC | 7 C |  |  | 2670 | R7HL | MOV | $\mathrm{A}, \mathrm{H}$ |
| C3B4 | $C D$ | 9 C | ［3 | 2675 |  | CALL | RTHEX |
| D ${ }^{\text {¢ }}$［ | 7 D |  |  | 2680 |  | MOV | A l ． |
| DJ BE | CD | 9 C | $[3$ | 2685 |  | CALLL | RTHEX |
| D3C1 | CD | 96 | ［3 | 2690 |  | C：ALL | SPACE |
| D3：C4 | C 9 |  |  | 2695 |  | RET |  |
| D3C5 | CD | 58 | ［2 | 2700 | E¢CAP | $C A D L$ | ICHAR |
| ロゴく | FE | 16 |  | 2705 |  | CPI | 1 BH |
| D3C | CO |  |  | 2710 |  | RNZ |  |
| D2CE | 21 | ：BD | ［7 | 2715 |  | L＇XI | －，CMNTE |
| DECE | C 3 | 05 | ［5 | 2720 |  | －MP | CMPLT＋3 |
| D301 | ［．$B$ | D2 |  | 2725 | CASR 0 | IN | FORT2． |
| ロこロて | E6 | 01 |  | 2730 |  | ANI | C1H |
| ロ305 | C2 | 1 A | ［ 4 | 2735 |  | JNZ | CASR1 |
| Dごロ | ［B | ：02 |  | 2740 |  | IN | FORTÉ |
| Dこ 01 | F6 | 01 |  | 2745 |  | O＇R I | 01 H |
| D300 | ［3 | D2 |  | 2750 |  | OUT | POPTE |
| DこDE | 2E | 32 |  | 2755 |  | MVI | $A, 321$ |
| D3．EC | ［3 | DE |  | 2760 |  | OUT | PORTS |
| DzE2 | 3 A | C7 | ［F | 2765 |  | L．DA | ©TK3 |
| DコE5 | ［3 | 08 | ， | 2770 |  | OUT | PORTE |
| D3E7 | 3 A | C8 | ［F | 2775 |  | LDA | STK3＋1 |
| DJEA | ［3 | D 8 |  | 2780 |  | OUT | FORT8 |
| DIEC： | CD | C 5 | ［3 | 2785 |  | C．AL．．L | ESCAF |
| DこEF | ［B | D2 |  | 279 |  | IN | FORTE |
| DてF1 | E 7 |  |  | 2795 |  | ORA | A |
| DZ！Fz | F2 | EC | ［3 | 2800 |  | $J P$ ： | CASRC＋2 7 |
| D？F5 | CD | 3 E | ［2 | 2805 |  | CALL | CELAY |
| DJFE | ［B | D2 |  | 2810 |  | IN | PORTE |
| DJFA | E 7 |  |  | 2815 |  | OR A | A |
| D2FE | F2 | EC | ［3 | 2820 |  | JP！ | CASRO＋27 |
| DJFE |  | ＇80 |  | 2825 |  | MVI | A， 80 O |
| DLOC | 03 | DE |  | 2830 |  | OUT | FORTE |
| D402 | $3 E$ | ＇B8 |  | 2835 |  | $\mathrm{M}: \mathrm{VI}$ | A）OBEH |
| D404： | ［3 | DF |  | 2840 |  | OUT | PORTF |
| D40t | 3E | 82 |  | 2845 |  | MV I | A，82F |
| 040 \％ | ［3 | ＇DE |  | 2850 |  | OUT | PORTE |
| D40 ${ }^{\circ}$ |  | ＇70 |  | 2855 |  | MVI | A， 70 H |
| D4OC． | ［． 3 | DF |  | 2860 |  | OUT | FORTF |
| D40E |  | 181 |  | 2865 |  | MVI | Ag81F |
| D410 | 03 | ＇DE |  | 2870 |  | OUT | FORTE |
| D4 12 | 3 E | E6 |  | 2875 |  | M：VI | $A, D E \in H$ |
| 0414 | ¢． 3 | DF |  | 2880 |  | OUT | FORTF |
| D416 | 3 E | $\bigcirc 3$ |  | 2885 |  | MVI | $A, 031$ |
| D＜1\％ | 03 | ＇DE |  | 2890 |  | OUT | PORTE |
| D41\％ | CD | C 5 | ［3 | 2895 | CASR 1 | C：AILL | ESCAF |
| 04.15 | $\square{ }^{1}$ | DE |  | 2900 |  | IN | PORTE |
| D＜1F | E 7 |  |  | 2905 |  | ORA | A |
| 0420 | F2 | 1 A | $[4$ | 2910 |  | JP | CASR1 |
| D42？ | ［B | DF |  | 2915 |  | IN | FORTF |
| 0425 | C 9 |  |  | 2920 |  | RET |  |
| D． 426 | CD | ＇01 | ［3 | 2925 | CASR 2 | CAI．L | CASRC |
| D42 ${ }^{\circ}$ | C 6 | 00 |  | 2930 |  | NVI | E，OOH |
| D42E | 6 F |  |  | 2935 |  | MOV | L．$A$ |
| D42C | 47 |  |  | 2940 |  | MOV | $E, A$ |

OK？

NOW ITS CONE WRITE 1 L

GET CHAR ESCAPE？

IS RELAY ON．？

GET LATA AT POKT2 TURN OA FEAD RELAY

SET LP，REAC CLOCK
GET READ SFEED

WANT：TO GUIT？
LEVEL CETECTION BIT 7 HIGH ？ LOOP TJL TONE

CHECK IEVEL AGAIA
BIT 7 IIEH ？
LOOP TIL TCNE
SET UP SEDA
RESET FECEIVER 8－SIT WOFD，SM，1 BYTE．

WRITE 10 CCN REG 3
INT，ONE SYAC CLR STAT
WRITE 70 SYNC FEG
SYNC CODE
ENABLE X－MIT
WANT TO CUIT ？
CHECK $\subseteq T A T U S$
BIT 7 HIGH ？
NOT READY
GET［ATA
GET SA AAD LEN
ZERO CFECKEJM FEG
PUT ACDRESS IA HL．


PUT BlCCK LEN IN DE

ZERO A
IS D ZERO ?
IS E ZERO :
NO, LOCP
GET CHECKSLM COMPARE WITH B SAVE RESULT IN D

CHECKSLM OK 3.
TAPE EFRCR
TAPE OK

COMPLEIE
READ AND SFECIFY SAVE IA H

A CARRIAGE RET $?$
GET ANCTHEF ADERESS
ZERO CFECKSUN FEG
PLACE EYTE IN MEMORY KEEP CFECKSUM


D48F CD 1A［4
D4．92 77
0493 5 F
049480
D49547
D4SE 23
D497c3 40［4
D4 9F CD EA［4
D49［50
D4 9E 59
D4 9F CD D1［3
$\begin{array}{llll}D 4 A C & 06 & 00 & \\ D 4 A L & C 3 & 43 & {[4}\end{array}$
D4A7 CD 26 ［4
D4AF C3 40 ［4
D4＇AC CD 26 ［4
D4＇BO CD 1A［4
D4B？EE
0484 C2 C4 C4
D4B7 ع 0
D4BE 47
D4Be 23
D4B11B
D4RE 57
D\＆BC E2
D4．BE E3
ПムBE C2 BO 「．4
D $4 C 1 \quad C 3$ LE［4
D4C4 CD D6［4
D4C7 21 D4［7
D4CA CD 31 ［2
D4CE．CD 8E［3
D4＇DC 21 EO［7
D4DZ C3 05［5

D4DE CD C5［3
D4Dc［B＇D2
D4DE E7
D4DC FA DS［4
D4DF［B D2
D4E1 F6 FE
D4Eこ［3 D2
DGEECS
DGEG CD 2E 〔1
DAESEB
DLEACD2E［1
D4E［13
D4EE 7E
DUEF G5
DU＇FC 4F
D4F1 7 A
D4．FA 9C
D4Fき 47
D4F4．C9
D4FE：CDEG［4
D4FE CD 2E［1
D4FE 73
D4FC CD 2E［2
D4FF＊C2 FE［4

3240
3245
3250
3255
$32 \in 0$
$32 \in 5$
3270
3275
3280
3285
3290
3205
3.300

3305
3310
3315
3320
3325
3320
3335
3340
3345
3350
3355
3360
$33 \in 5$
3370
3375
3380
3385
3350
$33 \leq 5$
3400
3405
3410
3415 END
3420
3425
3430
3435
3440
3445
3450
3455
3460
34 65
3 470
3475
3480
3485
3490
J495
3500
$35 C 5$
3510 2ER0
3515
3520
3525
3520

|  | INX | ＋ |  |
| :---: | :---: | :---: | :---: |
|  | CALL | CASR1 |  |
|  | MOV | M，$A$ | ． |
|  | MOV | $E \& A$ |  |
|  | $A D C$ | $E$ |  |
|  | MOV | $B, A$ |  |
|  | INX | ＋ |  |
|  | JMP | CASR ${ }^{\text {c }}$ |  |
| CASR 6 | C．ALL | EKLEN＋ 4 | GET 2NC．ADOR |
|  | MOV | ［， E |  |
|  | MOV | E，C |  |
|  | CALL | CASRC |  |
|  | M．VI | E，OOP | ZERO CFECKSUN，FEG |
|  | JMP | CASR ${ }^{2}+3$ |  |
| CASR 7 | C．AL．L | CASRź | RC PROERAM |
|  | JMP | CASR3 |  |
| CASR 8 | C．ALL | CASR2 | RV PFOERAM |
|  | C．ALL | CASR1 |  |
|  | CMP | $N$ | NEMOFY SAME AS TAPE？ |
|  | JNZ | VTERF | ERROR |
|  | ADD | E |  |
|  | MOV | E，A | KEEP CFECKSUN |
|  | INX | 「 |  |
|  | DCX | ［ |  |
|  | SUE | A |  |
|  | OR A | ［ |  |
|  | ORA | E |  |
|  | JNZ | －CASR8＋2 |  |
|  | $\cdots$ MP | $C A S R 2+14$ |  |
| V1ERR | CALL | END | SHUT OFF RELAY |
|  | LXI | H，CMATZ |  |
|  | C．AL．L | COMNT |  |
| EFROR | CALL | CRLF |  |
|  | L＇XI | H，CCMNT1 | ERROR |
|  | JMPP | CMPLT +3 |  |
| EAD | CALL | ESCAF | QUIT ？ |
|  | IN | FORTE | CHECK LEVEL |
|  | OR A | A | EIT 7 HIEH ？ |
|  | －M | END | LOOP TIL NO LEVEL |
|  | IN | PORTE | A GAP |
|  | ANI | CFEH | MASK RELAY |
|  | OUT | PORTL | RESTORE |
|  | RET |  |  |
| BKLEN | CALL | CONVC |  |
|  | X：CFG | SAVE | IN HL |
|  | CALLL | CONVC |  |
|  | INX | ［ |  |
| $\cdots$ | MOV | $A, E$ |  |
|  | SUE | L | CAlCULATE LENGTH |
|  | MOV | $C, A$ |  |
|  | MOV | $A, D$ |  |
|  | SRG | ト |  |
|  | MOV | $E, A$ |  |
|  | RET |  |  |
| 2 ER 0 | CALL | BKLEN | ZERO A NENORY |
|  | C．ALL | CONVC | NO ZERO？ |
|  | MOV | $\mathrm{M}, \mathrm{E}$ |  |
| － | CALL | CONE |  |
|  | JNZ | ZERO +6 | LOOP TIL DONE |


| DEO2 | 21 | $C A$ | $[7$ |
| :--- | :--- | :--- | :--- |
| OSOE | $C D$ | 31 | $C 2$ |
| $D 508$ | $C 3$ | 98 | $C 0$ |
| $D S O E$ | $C D$ | $E 6$ | $C 4$ |
| $D 5 O E$ | $C D$ | $2 B$ | $C 1$ | DE11 7E

D512 12：
DE12＇ 13
DE14＇CD 2E［2
DE17 C2 11 ［5
DE1／ 21 D7［F．
DE：1［ 22 D1［F
DE2C CD EE［4 DE2J CD 2E［1 D52t CD C5［＇3 D5 25 1A
$\begin{array}{llll}D E 2 A & E E \\ \text { DE } 2 \mathrm{E} & \mathrm{C} 2 & 38 & {[5}\end{array}$
D52E 13
DE2F CD 2E［． 2
D53年 C2 $26^{\circ}$［5
0535 C3 02 ［5
D53ध E5
DE3： 21 D4［7
D53C＇CD 31－［2
D53F 21 E0［7
DE42 CD 31 C2
D545 E1
D54E CD B9［3．
D54c 7E
DE4A CD 9C［3
DE4［ CD 96 ［3
DE5C CD 50［5
D55：1A
DE54 CD 9C［3
D557 CD 8E．［3
D551 C3 2E［5
DE5［ 7 A
D55E CD 9C［3
DE61 78
DE6F C3 BE［C3
DE65 CD E6［4
DE68 70
0569 16 00
DE6E CD 9DD D5
DE6E 57
DE6F7C
DE70 CD：90［5
DE7？ 82
057457
DE75 78
D57E CD：9D［5
ロ도 \＆2
057157
057E 79
DETC CD：90［5．
D57F \＆ 2
D580 57
D5 817 E

| 35：5 | crplt | LXI | FSCMNT4 |
| :---: | :---: | :---: | :---: |
| 3540 |  | C．ALL | COMNT |
| 3545 |  | JMP | ¢TRT |
| 3550 | move | C：ALL | EKLEA |
| 3555 |  | CALL L | convc |
| 3560 |  | MOV | A，M |
| 3565 |  | STAX | ［ |
| 3570 |  | INX | ［． |
| 3575 |  | CALLL | CONE |
| 3580 |  | JNZ | NOVE＋6 |
| 3585 |  | L＇XI | ＋，STK17＋2 |
| 3590 |  | S．HI．D． | ¢TK1？ |
| 3595 | VERFY | CALL | EKLEN |
| 3600 |  | C．AL．L | CONVC |
| 3605 |  | CALL | ESCAF |
| 3610 |  | I．DAX | ［ |
| 3615 |  | CMP | N |
| 3620 |  | JNZ | vMERF |
| 3625 |  | IN | ［ |
| 3630 |  | CALL | CONE |
| こ635 |  | －NZ | YERFY $+\epsilon$ |
| 3640 |  | JMP | CMPLT |
| 3645 | VIERR | PUSH | ＋ |
| 3550 |  | LXI | H，CMITE |
| 3655 |  | CALL | COMNT |
| 3660 |  | LXI | tgemsti |
| 3665 |  | C．Al．L | COMNT |
| 3670 |  | POP | ＋ |
| 3675 |  | C：ALL | RTH：L |
| 3680 |  | MOV | A，M |
| 3685 |  | C：ALL | FTHEX |
| 3690 |  | C：ALL | EPACE |
| 3695 |  | CALL | FTDE |
| 3700 |  | LDAX | ［ |
| 3705 |  | CALL | RTHEX |
| 3710 |  | CALL | CRLF |
| 3715 | ＊ | JMP | VER FY＋ 14 |
| 3720 | RTDE | Nov | $A \cdot \mathrm{D}$ |
| 3725 |  | C：AL L | RTPEX |
| 3730 |  | MOV | A，E |
| 3735 |  | JMP | RTHL +5 |
| 3740 | WCO | C．ALL | EKIEN |
| 3745 |  | Mov | $A, L$ |
| 3750 |  | MVI | ［， 0 Or |
| 3755 |  | CALL | CASk 0 |
| 3760 |  | Mov | ［，A |
| 3765 |  | MOV | $\mathrm{A}, \mathrm{H}$ |
| 3770 |  | CALL | CASWC |
| 3775 |  | ADC | ［ |
| 3780 |  | MOV | ［，A |
| 3785 |  | MOV | $A, B$ |
| 3790 |  | C：ALL | CASWC |
| 3795 |  | ADC | ［． |
| 3800 |  | MOV | ［，A |
| 3805 |  | Mov | $\mathrm{A}, \mathrm{C}$ |
| 3810 |  | C：ALL | CASWO |
| 3815 |  | ADC | － |
| 3820 |  | MOV | ［，A |
| 3825 | WC1 | MOV | $A, M$ |

COMPLETE
rove a block of mer EET START ADCR
GET BYTE
MOVE A BYTE

LOOP TIL DONE

VERIFY MEMORY
GET ADCRESS
HANT TO QUIT ？
COMPARE
ERROF

LOOP
SAVE H

KRITE ADDRESS
WRITE EYTE．

WRITE CTHER EYtE

URITE CE

WC WRITE CASS
WRITE ADCRESS
ZERO CFECKGUM FEG
CHECKSLM IA D．

WRITE ELOCK LEN


DEOT FE O
DEOSCA 18 ［6
$D \in O C^{\prime} 04$
DEDC FE 10
LUEOF CA 18 ［6
DE1： 04
DE12 FE 13
DE1E C2 ：CD［4
D61\＆ 78
$0 \in 1 \mathrm{C} 32: \mathrm{C4}$［F
DE1C C3 98 ［0
DG1F $2 \mathrm{~A} D 1 \mathrm{~F}$
D $E 2$ CD E6［0
DE2E 0600
D 627 FE 16
DE2SCA 38 ［6
DE2C 04
DERE FE 10
DE2F CA 3 E［6
$D \in 32$ C 4
$0 \in 3$ ？FE 13
DE3E C2 CD［4
D6 3 \＆ 78
D63！ 32 C5［F
DE3C C3 98 ［0
DE3F CD 2E［1 －DE 42 EB
$D E 4222$ C7［F
DE4 C C3 9\＆［0
DE4c＇CD 2E［1
DE4C EB
DG4［ 22 CS CF
DE＇50 c3 98 ［0
DE5こ CD $2 E$ C． 1
D6 56 7 B
D657［3 DA
D65！7A
DE5月［3 DA
DE5C EB
DE5［ $=2$ CE［F
DEGC C3 98 ［0
DEGZ CD EE［4
$D \in 6 \epsilon^{\circ} C D 8 E[3$
DE6S 160 ：
DEGE CD B9［3
DEGE CD 96 ［3
DE71 CD 96 ［3
D674 7E
DG7E CD 9C［3
D678 23
DG7¢ 15
DE7f C2 71 ［6
DG7［ 11 F8 FF
D $\epsilon^{\prime} 80 \quad 19$
$D E 81^{\prime} 16 \quad 08$
D6 8̌ CD 96 ［3
DE8t CD 96 ［3
D685：7E
D68：E67F

| 4125 |  | CPI | CBH |
| :---: | :---: | :---: | :---: |
| 4130 |  | $\checkmark 7$ | A I 1 |
| 4125 |  | INR | E |
| 4140 |  | CPI | 10 H |
| 4145 |  | $\cdots$ | AI 1 |
| 4150 |  | INR | E |
| 4155 |  | CPI | 13 H |
| 4160 |  | JNZ | ERROF |
| 4165 | AII | MOV | $A, B$ |
| 4170 |  | STA | STKO |
| 4175 |  | JMP | ©TR T |
| 4180 | A00 | L．HLD | ¢TK12 |
| 4185 |  | CALL | CHCK |
| 4190 |  | MVI | $\mathrm{E}, \mathrm{OOH}$ |
| 4195 |  | CPI | 16 H |
| 4200 |  | $\checkmark$ I | A 01 |
| 4205 |  | INR | E |
| 4210 |  | CPI | 10 H |
| 4215 |  | $J$ J | A 01 |
| 4220 |  | INP | E |
| 4225 |  | CPI | 13H |
| 4230 |  | JNZ | ERROF |
| 42 25 | AO1 | MOV | $A, E$ |
| 4240 |  | STA | ¢TK1 |
| 4245 |  | JMP | ¢TRT |
| 4250 | SF | CALL | CONVC |
| 4255 |  | XCHG | PUT |
| 4260 |  | S．HI．D | STK3 |
| 4265 |  | JMP | STRT |
| 4270 | Sh | CALLL | CONVC |
| 4275 |  | XCHG | FUT |
| 4280 |  | SHLD | CTK5 |
| 4285 |  | JMP | STRT |
| 4290 | SS | CALL | CONVC |
| 4255 |  | MOV | AsE |
| 4300 |  | OUT | PORTA |
| 4305 |  | MOV | $A, D$ |
| 4310 |  | OUT | FORTA |
| 4315 |  | XCHG |  |
| 4320 |  | SHLD | ©TK7 |
| 4325 |  | JMP | ¢TRT |
| 4330 | DAO | CALL | EKL．ER． |
| 4335 |  | C．ALL | CRI．F |
| 4340 |  | MVI | ［．， 08 － |
| 4345 |  | C．ALL | FTHL |
| 4350 |  | CAALL | SPACE |
| 4355 | DA 1 | CALLL | SPACE |
| 4360 |  | MOV | $A, M$ |
| 4365 |  | CALL | FTHEX |
| 4370 |  | INX | 1 |
| 4375 |  | ［CR | ［ |
| 4380 |  | JNZ | ［ A1 |
| 4365 |  | LXI | ［，OFFFEH |
| 4390 |  | LAL | ［ |
| 4395 |  | MV I | ［．08 |
| 4400 |  | CALL | SPACE |
| 4405 | DA2 | CALL | SPACE |
| 4410 |  | MOV | $A, \mathrm{M}$ |
| 4415 |  | ANI | 7 FH |

K FOR kEYBD

P FOR FAR FORT
© FOK SERIAL NO GOOC

INFUT 「EVICE CCDE

```
ASSIEN OLTFUT CEVICE
ZERO B
V FOF VDN
P FOR FAR FORT
S FOR GERIAL NO GOOE
output device code
CASS READ ©PEED IN HL
```

CASS WFITE SPEED
IN HL

SERIAL SPEED

GET LENGTH
SET BYtE COUNTER
HRITE ADCRESS

GET REMORY
WRITE IT．

LOOP
2 IS COMP 9
SUB H EY 9
SET EYTE CCUNTER

GET BYte
MASK BIT 7


DT0こ EB
0704 C3 CF［6
0707 CD 2B［1
0701 21 EG［F
D70「 36 ＂CB
D70F 23
D71C 73
071123
071236 Cg.
DJ14 CD ES［F
D717 CD 9C［3
DT1f CD 3E［7
071C C3 14 ［7
D7＇2C CD E6［4
D723 10
D724 4D
D725 21 EG CF
D72E $367 E$
0721 2 3 ．
D72E 36 ＇D3
D72［ 23
D72E 71
072F 23
D730 こ6 C9
D732 CD ES［FF
DZ3E CD 3E C7
D73EC3 $32 \quad 57$
DTJE CD 5E［2
Di3E FE 20
Di40 C2 02 ［5
D74ご CD 8日［3
D74E C9
0747 CD 2 Cl ［1

D74E OE 10
D75C 7E
D751 CD 9C［3
D754 23
D755 CD 96 C3
D75 6 CD
D759 C2 $50 \quad[7$
Di5C CD 3E C7
07．5F C3 4E［7
0762
D762 11
0762 FF D5
D765 17
D76E1F D6
D76E 20
D765 47 D7
076E 21
D76C 63 D6
076E 28
07.6 F SC 01

D771 25
D772 CC D1
077430
D775 03

| 4715 |  | XCHG |  | REETORE H |
| :---: | :---: | :---: | :---: | :---: |
| 4720 |  | JMF＇ | CMPRO |  |
| 4725 | IAPO | C：ALL | CONVC |  |
| 4720 |  | L＇X I | ト．sTk 17＋20 | BUFFER ATEA |
| 4735 |  | MVI | M，OCBF |  |
| 4740 |  | INX | － |  |
| 4745 |  | MOV | $\mathrm{r}, \mathrm{E}$ |  |
| 4750 |  | INX | ＋ |  |
| 4755 |  | MVI | NsOCSH |  |
| 4760 | INP 1 | C：AL．L | ¢TK17＋20 | execute it |
| 4765 |  | CAALL | R THEX |  |
| 4770 |  | CALL | COAGA |  |
| 4775 |  | JMP | INP 1 | ［O AGAIN |
| 4780 | OUTo | C：ALL | EKLEA |  |
| 4785 |  | CCR | E |  |
| 4790 |  | Mov | C ¢ L ． |  |
| 4795 |  | L＇XI | FsSTK17＋z0 | QUFFER AREA |
| 4800 |  | MVI | M，OTEH | MOV A，E |
| 4805 |  | ．INX． | ＋ |  |
| 4810 |  | MVI | N，ODこH |  |
| 4815 |  | INX | F． |  |
| 4820 |  | MOV | $\mathrm{N}, \mathrm{C}$ |  |
| 4825 |  | INX | ＋ |  |
| 4830 |  | MVI I | NoOCSH |  |
| 4835 | OLT1 | CALL | STK17＋20 | EXECUTE it |
| 4840 |  | CALL | ［OAGA | DO AGAIN？ |
| 4845 |  | JMP | OUT1 |  |
| 4850 | DOAGN | C：ALL | INPM |  |
| 4855 |  | CPI | 2 OH | A SPACE |
| 4860 |  | JNZ | CMPLT | DONE |
| 4865 |  | CALL | CRLF |  |
| 4870 |  | RET |  |  |
| 4875 | ONO | CALL | CONVG |  |
| 4880 |  | XCHEG |  |  |
| 4885 |  | CALL | FTHL |  |
| 4890 |  | MVI | C， 1 Or |  |
| 4895 |  | MOV | A， M |  |
| 4900 |  | CALL | L RTHEX |  |
| 4905 |  | INX | ＋ |  |
| 4910 |  | CALL | SPACE |  |
| 4015 |  | CCR | ${ }^{\text {c }}$ |  |
| 4920 |  | JNZ | ［MO＋s |  |
| 4925 |  | C．ALL | ［ OAGA | REPEAT？ |
| 4930 |  | JMP | ［ MO +4 |  |
| 4935 | ＊＊＊CON | MA：N［ | LOOK－UF TAEL |  |
| 4940 | TABL 1 | CB | 11H | A I |
| 4.945 |  | CW | A IO |  |
| 4950 |  | DB | 17 H | A 0 |
| 4955 |  | OW | A 00 |  |
| $49 \in 0$ |  | ［． $\mathrm{B}^{\text {B }}$ | 2 OH | D |
| 4965 |  | CW | EMO |  |
| 4970 |  | EB | ＜1H | DA |
| 4975 |  | ［．W | ［ A 0 |  |
| 4980 |  | DB | 28 H | E |
| 4985 |  | ［ W | EMO |  |
| 4990 |  | CB | 35 H | EM |
| 4995 |  | ［W | EM3 |  |
| 5000 |  | CB | 2 OH | F |
| 5005 |  | D8 | 03 | FLOPFY BOOT |





SyMEOL taELE

| A I 0 | DEFF | A I1 | ［．618 | A．OO | DS 1F | A 01 | 0628 | BINAS | D3AF | EKLEN | ［ 4 E 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BS | D370 | CASRO | ［351 | CASR 1 | D41A | CASR2 | D426 | CA＇SF3 | D440 | $C A \subseteq R 4$ | ［．464 |
| CASF5 | D468 | CASR6 | ［49 A | CASR 7 | D4 A7 | CASR8 | D4AD | CASKO | D590 | CASW1 | ［5E0 |
| C＋SV2 | DSEE | CHCK | COE6 | CHKS T | D28t | CMD 1 | ［OFA | CNDE | D117 | CMC 3 | ［125 |
| CMN10 | D7E7 | CMN T1 | C7EO | CNNT2 | D7 DE | CMNTZ | O7C4 | CMN14 | D7CA | CMA T5 | ［7C3 |
| CrN 16 | D7BE | CMPLT | ［502 | CNPRO | D6CF | CMPR1 | D6CB | CMPF2 | D6F9 | CONMC | ［OAC |
| CCMNT | D231 | CONVO | ［12B | CONV1 | D147 | CONV 2 | $[168$ | CONV 3 | D172 | COAV4 | D17E |
| CF | 0354 | CRLF | ［38日 | OAO | 0663 | DA1 | 0671 | DA2 | D686 | CELA2 | ［23B |
| DEL／S | D24E | CELAY | ［23E | DELET | D004 | E．MO | 0747 | DOAEN | D73B | CONE | ［22B |
| ENO | ： 19 C | EM1 | C1ED | EN2 | 01c8 | EM3 | C1CC | EM 4 | D1E9 | ENC | ［406 |
| EFRER | D4C0 | ESCAP | ［3C5 | －FF | D344 | G 0 | D157 | HEX | D6B5 | HONE | ［383 |
| ICH／R | D25 | INIT | ［027 | IN：IT 1 | D05A | INIT2 | 0075 | INPE | D707 | INF 1 | D714 |
| IAPN | 025E | INPUT | 1264 | ISTAT | D2 52 | LCL | 0192 | LF | Dさ6E | NOVE | ［50日 |
| OLTC | D720 | OUT1 | ¢732 | PIN | D27c | PINO | 0278 | PIN1 | D2 82 | FIASO | ［295 |
| PCRT | 0000 | POFTO | 0000 | PORT1 | 00D1 | FORT2 | OOC． 2 | POR13 | O0D3 | FOFT4 | $\operatorname{coD} 4$ |
| PCR15 | O005 | POFTG | 00［6 | PORT 7 | 0007 | PORT8 | OOC． 8 | PORT9 | O009 | FOR TA | COOA |
| PORTB | OODE | PORTC | OODC | PORTD | OODE | PORTE | OOLE | PORTF | OODF | FOLT | ［2B0 |
| PFINT | D6A2 | PROGO | ［1FF | PROG1 | D208 | PROGz | ［213 | RTUE | D550 | FTHEX | ［39C |
| RTHL | D3B5 | SC1 | ［2EB | SC2 | D2 F | SC3 | D319 | SC．I | 0000 | SEFCH | ［6C6 |
| SK IF | $D \in A 0$ | sout | 「．2A5 | SFACE | D396 | SR | 063F | SS | D653 | ¢TACK | CFCO |
| STKC | DFCC4 | STK 1 | ［FC5 | STK10 | DFCE | STK11 | ［FCF | STK13 | DFD1 | ¢TK15 | CFD3 |
| S7K16 | DFO4 | STK17 | CFC5 | S 7 K 2 | DFCE | ¢TK3 | OFC7 | STKE | DFC9 | ¢TK 7 | ［．FCB |
| S 7 K ¢ | DFCE | STPT | ［098 | S． | DE 4： | TABL1 | D762 | TABL2 | D7BE | VD1 | C2E5 |
| V［2 | D332 | V 03 | ［33C | VCM | D2 BE | VERO | ［2＜5 | VERFY | D520 | VMERR | ［538 |
| VTEFR | D4C4 | WCO | 「．565 | WC1 | D5 81 | WRITE | D298 | WR ITE | D299 | ZEFO | D 4 F 5 |

