GCromemco ## TU-ART Digital Interface Instruction Manual Scanned by Howard M. Harte, March 26, 2003. <a href="www.hartetec.com">www.hartetec.com</a> ### Cromemco TUART Digital Interface Copyright © 1978 by Cromemco Inc. All rights reserved. ### **Table of Contents** | Section 1 — INTRODUCTION 1 1.1 Definitions 1 1.2 Switch Selectable Options 1 1.3 Interrupt Priority Chain 3 1.4 Status Bit Selection 3 1.5 Interface Options 4 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Section 2 — TU-ART REGISTER DESCRIPTIONS | | Section 3 — INTERRUPT OPERATION | | Section 4 — CONNECTING THE TU-ART TO I/O DEVICES | | Section 5 — PROGRAMMING EXAMPLES 23 5.1 1-Second Metronome 23 5.2 Initialization Subroutine 24 5.3 Character Output Subroutine 25 5.4 Character Input Subroutine 25 5.5 "Echo" Program 26 | | Section 6 – THEORY OF OPERATION. 27 6.1 Introduction. 27 6.2 Power Supply. 27 6.3 Crystal Controlled Clock. 27 6.4 Address Select. 29 6.5 Function Decode. 29 6.6 State Sequencer. 29 6.7 Status Strobe. 29 6.8 Bus Multiplexers 31 6.9 Serial Interface 31 6.10 Parallel Interface 31 6.11 Priority Chain 31 | | Section 7 — APPLICATION NOTES .33 7.1 OAE OP-8ØA Paper Tape Reader .33 7.2 4FDC Compatibility .33 | ### **Table of Contents** | ASCII CHARACTER CODES | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LIST OF ILLUSTRATIONS Figure 1 – TU-ART Switch Settings | | LIST OF TABLES Table 1 — Z80 (Mode 2) Response 10 Table 2 — Z80 (Mode 0) Response 11 Table 3 — J2 Parallel A 16 Table 4 — J3 Parallel B 17 Table 5 — J4 Serial A 18 Table 6 — J5 Serial B 19 | ## section. ### Introduction The Cromemco TU-ART (Twin Universal Asynchronous Receiver and Transmitter) provides two channels of duplex serial data exchange; two channels of parallel data exchange; and ten interval timers. Status information is available through polling or by interrupt. In addition, each interval timer activates an interrupt and two interrupt request lines are brought out for the user. The TU-ART has its own crystal-controlled clock and interfaces to the S-100 bus asynchronously so that CPU clock frequency is not critical. The TU-ART incorporates two TMS 5501 NMOS I/O Controller chips. ### 1.1 Definitions Throughout this manual the two TMS 5501 chips will be referred to as "Device A" and "Device B." Device A (IC 4) is the leftmost chip. Device B (IC 5) is the rightmost chip. Device A is nearer the heat sink and drives serial connector J4 and parallel connector J2. Device B is located to the right of Device A and drives serial connector J5 and parallel connector J3. ### 1.2 Switch Selectable Options Addressing The TU-ART The system CPU views the TU-ART as a dual assembly of input/output ports with interrupt capability. The CPU normally reads data or status from the TU-ART via the S-100 bus by executing an IN A, (port) instruction, and writes data or commands to the TU-ART by executing an OUT (port), A instruction. There are fourteen I/O ports used for data transfers, commands and status by Device A, and another fourteen by Device B (see Figure 2). The user may independently switch select Device A and Device B I/O Base Addresses (the four most significant I/O address bits); the four least significant bits of the I/O address on the S-100 bus then determine the offset from the selected base address. The base address of Device A is selected by DIP switch positions 6 thru 3; the base address of Device B is selected by DIP switch positions 10 thru 7 (see Figure 1). Notice that positioning a switch ON conditions the TU-ART to respond to a logic 0 on its associated address line; an OFF switch corresponds to logic 1. For example, if DIP switch positions 6 thru 3 are ON, and positions 10 thru 7 are OFF, then the TU-ART Device A Command Register is mapped into output port 02H, and the Device B Command Register is mapped into output port 0F2H. Note that Device A bits A7, A6 and A5 also control D7, D6 and D5 of the TU-ART's Z-80 mode 2 Interrupt Acknowledge response vector. ### **Interrupt Mode** When this switch (position 1) is ON, the TU-ART operates in the 8080 interrupt mode: one of eight "Restart" instructions is gated to the data bus during an Interrupt Acknowledge cycle. Since the TU-ART can interrupt from one of 16 different sources, it is necessary to poll the devices if the TU-ART is in 8080 mode (see "Operation Using 8080 Mode Interrupts"). When switch position 1 is OFF, the TU-ART responds in Z-80 mode 2. In this mode, the TU-ART supplies a byte to the data bus during Interrupt Acknowledge that is used as the lower eight bits of a memory address. The Z-80 supplies the upper eight bits from the I register and automatically reads the corresponding memory location, as well as the next location, to find the starting location of an interrupt routine. (Refer to Section 3.1 and/or the Z-80 CPU Reference Manual, Zilog, 1977, for details.) ### **Normal/Reverse Address** When this switch (position 2) is ON, it allows Device A and Device B to swap base addresses by means of an output to one of the parallel ports (Software ### TU-ART Digital Interface Address Reverse). This allows either Device A or Device B to be driven by a software driver whose port issignments are frozen in memory. Setting the switch ON connects the MSB of Device A's parallel output port to the Reverse Address control so that addresses may be flipped under software control. To flip addresses, output a byte with D7 high to Device A's parallel output port. To return to normal addressing, output a byte with D7 low to Device B's parallel output port. When switch position 2 is OFF, the Address Reverse switch is disconnected from the parallel port. The Address Reverse signal is brought out to pin 1 of J2 and J3. When the Address Reverse switch is $\ensuremath{\mathsf{ON}}$ pin 1 will show the state of the TU-ART: Pin 1 = Ø means Reverse Mode, Pin 1 = 1 means Normal Mode. tion of Device A's parallel port. When the Address Reverse switch is OFF, pin 1 of J2 or J3 may be grounded externally to place the TU ART in reverse Mode (Hardware Address-Reverse). Do not ground pin 1 of J2 or J3 while the Reverse Address switch is ON as this will conflict with opera ### Figure 1 TU-ART Switch Settings Caution: Base addresses 00H and 30H are used by Cromemco's 4FDC Floppy Disc Controller; 40H is used by Cromemco memory boards with BANK SE- LECT; and 5ØH is used by Cromemco's PRI Printer Interface. ### 1.3 Interrupt Priority Chain When more than one TU-ART is used in a system, it is necessary to coordinate the Interrupt Responses in order to prevent bus conflict during Interrupt Acknowledge cycles. This is done by first connecting J1 PRIORITY OUT from the highest priority TU-ART to J1 PRIORITY IN of the next highest priority TU-ART, then connecting J1 PRIORITY OUT of the second TU-ART to J1 PRIORITY IN of the next TU-ART, and so on until all TU-ARTs are connected. The J1 PRIORITY IN pin of the highest priority board is left unconnected. Device A is internally prioritized over Device B on each TU-ART. ### 1.4 Status Bit Selection The connection of status flag bits to data bits is done on the PC board at the location of the status socket below J4. Cromemco software conventions assign D6=Receiver Data Available (RDA), and D7=Transmitter Buffer Empty (TBE). For specialized assignments (like more than one bit per flag) see the following "Status Socket" section. ### **Status Socket** The status flag bits available on input port 0 are connected to the data bits by foil traces in the "status" socket located between IC's 8 and 9. The flag assignment used by all Cromemco software is discussed in the section entitled "Register Description." If necessary, the flags may be assigned to different data bits. This may be most easily done as follows: - Notice that the flags are arranged along the left row of pads and that the data bits are arranged along the right side row of pads. Note also that only those 8 traces connecting the right and left pads are not covered by the solder mask. There are 5 traces which pass through this area which are covered. - Use a razor blade or a sharp knife to cut all 8 of the traces connecting the left and right rows of pads. Be very careful not to cut the traces which are covered by the solder mask. - Install and solder a 16 pin IC socket in the 2 rows of pads. - 4. Install a 16 pin "component header" in the socket. - Using small (24 or 28 Awg) insulated wire connect the flags (on the left) to the desired data bits (on the right) on the component header. - The component header is now a "plug" for your particular flag assignment. Several different flag assignment "plugs" can be prepared in the same manner and used at different times to suit the requirements of the software being executed. Any given flag may be assigned to more than one data bit. However, each data bit can have only one flag assigned to it. ### 1.5 Interface Options ### **TTY 20 mA** To drive a Teletype, the following connections should be made (at J4 or J5 for Device A or B respectively): | TU-ART | ASR-33 TTY | |--------------------------|-----------------------------------------------------------------| | J4/J5 PIN 23 connects to | Terminal strip "BL", terminal #7 (current into printer) | | J4/J5 PIN 25 connects to | Terminal strip "BL", terminal #6 (return current from printer) | | J4/J5 PIN 17 connects to | Terminal strip "BL", terminal #4 (current into keyboard) | | J4/J5 PIN 24 connects to | Terminal strip "BL", terminal #3 (return current from keyboard) | | Caution: 120 VAC is also | present on terminal strip "BL" | at terminals #1 and #2. ### **RS/232C** An RS232 terminal (such as a CRT) may be plugged into an interface cable directly out of J4 or J5. The TU-ART assumes the role of data-set (computer) in this case. See Figure 8: Terminal to TU-ART Cable for this connection. ### Parallel I/0 The parallel port output drivers may be tri-stated by grounding pin 8 of the parallel port (J2, J3). A bidirectional bus may be implemented by simply wiring the input and output lines together and using pin 8 to control the direction of data flow. Pin 8 low implies data input to the TU-ART and pin 8 high implies data output from the TU-ART. ### Figure 2 Summary Of TU-ART I/O Port Addresses | OFFSET | A7 A6 A5 A4 | l A3 | 3 A2 | 2 A | 1 AØ | FUNCTION | |--------------------------------------------------------------------|------------------------------------------|-----------------------|-------------------------|---------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ø<br>0<br>1<br>1<br>2<br>3<br>3<br>4<br>4<br>5<br>6<br>7<br>8<br>9 | Device A<br>Base Address<br>(see Fig. 1) | | Ø Ø Ø Ø Ø Ø 1 1 1 1 0 Ø | Ø Ø Ø Ø 1 1 Ø Ø Ø 1 1 Ø Ø | | IN Device A status register OUT Device A baud rate register IN Device A receiver data register OUT Device A transmitter data register OUT Device A command register IN Device A interrupt address register OUT Device A interrupt mask register IN Device A parallel port OUT Device A parallel port OUT Device A timer 1 OUT Device A timer 2 OUT Device A timer 3 OUT Device A timer 4 OUT Device A timer 5 | | Ø<br>Ø<br>1<br>1<br>2<br>3<br>3<br>4<br>4<br>5<br>6<br>7<br>8<br>9 | /see Fig. 1)<br>/ | Ø<br>Ø<br>Ø<br>Ø<br>Ø | 1<br>1<br>Ø | 00001110001100 | Ø Ø 1 1 0 1 0 1 0 1 0 1 | IN Device B status register OUT Device B baud rate register IN Device B receiver data register OUT Device B transmitter data register OUT Device B command register IN Device B interrupt address register OUT Device B interrupt mask register IN Device B parallel port OUT Device B parallel port OUT Device B timer 1 OUT Device B timer 2 OUT Device B timer 3 OUT Device B timer 4 OUT Device B timer 5 | ### NOTES: All of the following unassigned ports are free for system use: IN 2, IN 5 through IN 9, IN 10 through IN 15 and OUT 10 through OUT 15. If Device A and Device B are set to the same base address, Device A will override. Device A is IC 4. Device B is IC 5. # TUARURE CRIPTIONS ### **TU-ART Register Descriptions** ### 2.1 Offset IN/OUT Description Each of the twenty-eight TU-ART registers is viewed as an I/O port by the system CPU. The function of each register is discussed in the following subsections. The sub-section headings consist of an I/O port address offset, followed by either "IN" or "OUT," followed by the TU-ART register name. The descriptions given below apply equally to Device A registers and Device B registers. Refer to Figure 3 for a summary of TU-ART register formats. ### **00 IN Status Register** The CPU reads the contents of this register to determine the status of the Device A/Device B serial port. The status bit assignments may be altered by cutting PC foil traces and installing a jumper wire header (see Section 1.4). | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DØ | |-----------------------------|------------------------|----------------------|------------------------|-----------------------|--------------------|-----------------------|----------------| | Transmit<br>Buffer<br>Empty | Read<br>Data<br>Avail. | Int.<br>Pend-<br>ing | Start<br>Bit<br>Detect | Full<br>Bit<br>Detect | Ser-<br>ial<br>Rov | Over-<br>run<br>Error | Frame<br>Error | ### D7 Transmitter Buffer Empty (TBE) A high in bit 7 indicates that the transmitter data buffer is ready to accept a new byte. TBE goes high as soon as the serial transmitter begins to send the byte currently in the buffer. Since the transmitter is "double-buffered," the user may respond to the TBE signal and load the buffer even before the previous byte has been totally transmitted. TBE also activates interrupt request 5. TBE is cleared when the buffer is loaded and is set by the RESET command. ### D6 Receiver Data Available (RDA) A high in bit 6 indicates that a byte of data is available from the receiver buffer. This flag remains high until the buffer is read. A RESET command clears the flag. If the buffer is not read by the time the next byte from the receiver is ready, the new byte will write over the old byte and the overrun error flag will be set. RDA also activates interrupt request 4. ### D5 Interrupt Pending (IPG) A high in bit 5 indicates that one or more of the eight interrupt request sources has become active. This flag goes high at the same time as the interrupt request pin of the TMS 5501. ### D4 Start Bit Detect (SBD) A high in bit 4 indicates that the serial receiver has detected a start bit. This bit remains high until the full character has been received. SBD is cleared by RESET command. This bit is provided for test purposes. ### D3 Full Bit Detect (FBD) The FBD flag in bit 3 goes high one full bit time after the start bit has been detected. This bit remains high until the full character has been received. FBD is cleared by a RESET command. This bit is provided for test purposes. ### D2 Serial Receive (SRV) A high in bit 2 indicates high level on the serial data input line. A low in bit 2 indicates a low level on the serial data input line. SRV is high when no data is being received. This bit is provided for break detection and for test purposes. ### D1 Overrun Error (ORE) A high in bit 1 indicates that the receiver has loaded the receiver data buffer before the previous contents were read. ORE is cleared after the status port is read or by the RESET command. ### DØ Frame Error (FME) A high in bit Ø indicates an error in one or both of the stop bits which "framed" the last received data byte. FME remains high until a valid character is received. ### **TUART Digital Interface** ### **60** OUT Baud Rate Register The CPU loads this register to set the baud rate and stop bits for serial receive and transmit data. Bit assignments are as follows: | D7 | טט | บธ | D4 | D3 | D2 | D1 | DØ | |--------------|------|------|------|------|-----|-----|-----| | STOP<br>BITS | 96ØØ | 48ØØ | 2400 | 1200 | 300 | 15Ø | 110 | ### D7 Stop A high in bit 7 selects one stop bit for serial receive and transmit data. A low in bit 7 selects two stop bits. ### D6-DØ Baud Rate A high in one of the lower seven bits selects the corresponding baud rate. If more than one bit is high, the highest rate selected will result. If none of the bits are high, the serial transmitter and receiver will be disabled. (For special purposes these baud rates can be octupled—see the description of HBD in the command register.) ### **01 IN Receiver Data** The CPU reads this register to obtain the assembled byte of data from the serial receiver. ### **61 OUT Transmitter Data** The CPU loads this register with a data byte for serial transmission. ### **02 IN Not Connected** Reading this port causes no response from the TU-ART. This input port is available to other parts of the computer system. ### **Ø2 OUT Command Register** The format for the command register is as follows: | | | | latched | | | | | | | | | |-------------|----|------|--------------|----------------|--------------|----|-------|--|--|--|--| | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DØ | | | | | | Not<br>Used | | Test | HIGH<br>BAUD | INTA<br>Enable | RST7<br>Sel. | | Reset | | | | | ### D5 Test Bit (TB5) A high in bit 5 disables the internal interrupt priority logic and then enables the internal clock. Thus, the signal on the INT pin of the 55Ø1 becomes a TTL level clock of 1562.5 Hz (12.5 kHz if HBD is high—see "D4 High Baud" below). TB5 should be low for normal operation. ### D4 High Baud (HBD) A high in bit 4 octuples the rate of the internal clock. This causes the interval timers to count eight times faster and the serial data rates to increase eightfold. When bit 4 is high, baud rates up to 76.8K baud are available for high speed data transfers. ### D3 INTA Enable (INE) A high in bit 3 allows the 5501 to respond to an Interrupt Acknowledge by gating a Restart instruction into the data bus at the correct time and resetting its internal interrupt request latch. A low in bit 3 prevents the 5501 from detecting an INTA cycle. Bit 3 should be high for normal operation. ### D2 RST7 Select (RS7) A high in bit 2 connects the MSB of the parallel input port to the interrupt request latch for the lowest priority interrupt (interrupt 7). A low-to-high transition on the MSB of the parallel input port (P17) will activate the interrupt request latch. A low in bit 2 connects the output of Timer 5 to the interrupt request latch for the lowest priority interrupt (interrupt 7). When the timer count reaches zero, the interrupt request latch will be activated. ### D1 Break (BRK) A high in bit 1 holds the serial transmitter output in the low state (spacing). RES will override (see "DØ Reset" below). A low in bit 1 allows normal operation. BRK should be low for normal operation. ### DØ Reset (RES) A high in bit Ø causes the following actions: a) The Serial Receiver goes into search mode; ### **TU-ART Digital Interface** - RDA, SBD, FBD, and ORE are set to zero. The contents of the receiver buffer are not affected. - b) The Serial transmitter output is set high (marking). If DØ and D1 are both high, the RES function will override. RES sets TBE high. - c) The interrupt register is cleared except for the TBE interrupt request which is set high. - d) The interval timers are cleared. RES is not latched. ### **Ø3 IN Interrupt Address** The CPU reads this register to obtain the encoded address of the highest priority interrupt currently requesting service. This address is identical to the "Restart" instruction op-code for the interrupt acknowledge. Thus, the register contents may be (in order of service priority): | CONTENTS | SOURCE | |----------|---------------------------| | C7 | Timer 1 | | CF | Timer 2 | | D7 | Sens | | DF | Timer 3 | | E7 | Receiver Data Available | | EF | Transmitter Buffer Supply | | F7 | Timer 4 | | FF | Timer 5 or PI7 | This register is provided for servicing interrupts via polling. After the register is read, the corresponding bit in the interrupt request register is reset. If the register is read when no interrupt is pending, it will read ØFFH. ### **03 OUT Interrupt Mask** | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DØ | |----------------|--------|-----|-----|--------|------|--------|--------| | Timer5<br>/Pi7 | Timer4 | TBE | RDA | Timer3 | Sens | Timer2 | Timer1 | The contents of this register are logically "And"-ed with output from the interrupt request register on the 5501. A high bit in the interrupt mask allows the corresponding request to pass on into the priority encoder. A low bit in the interrupt mask inhibits the corresponding interrupt from passing any further. Since the interrupt requests are latched independently of the state of the mask, an interrupt may be requested while the mask bit is low. The request will be retained until the mask is changed and the request allowed to pass on (assuming no RES command in the interim). ### **64 IN Parallel Input** This register contains the data presented at J2 (Device A) or at J3 (Device B). The input data must be stable 75 ns after Input Strobe goes low. The peripheral supplying data to the TU-ART can indicate data available by activating the SENS line (or by raising the MSB of the parallel input if the RS7 bit in the command register is high). When using Z-80 block input commands, it is not necessary to supply data at full speed. The input peripheral should simply pull down the WAIT line (pin 21 of J1 or J3) whenever Input Strobe goes low and should not let WAIT go high until the next byte is presented to the TU-ART. (The TU-ART will not read this byte until Input Strobe goes low again.) ### **64** OUT Parailel Output This register contains the data which drives the parallel output buffers. The output data is guaranteed stable 1.45 µsec after the falling edge of Output Strobe. The TTL output buffers which drive J2 (Device A) and J3 (Device B) may be put in a high-impedance state by pulling down on Disable (pin 8). When using the Z-80 block output commands, it is not necessary to receive data at full speed. The output peripheral should simply pull down the WAIT line (pin 21 of J2 or J3) whenever Output Strobe goes low and not let WAIT go high until the output peripheral has had time to "digest" the data. ### **65 IN Not Connected** Same as Input Ø2. ### **Ø5** OUT Timer 1 The CPU outputs a "count" to this register to start Timer 1. This count is decremented by 1 every 64 $\mu seconds$ after initial loading. When the count reaches zero, bit 0 of the interrupt request register is set and the timer disabled. Since the maximum count is 255, the longest interval is $255\times64~\mu sec.=16.32~msec.$ Accuracy is plus 0 and minus $64~\mu sec.$ Loading a count of zero causes an immediate interrupt request to the interrupt request register. Loading a new count while the timer is counting re-initializes the timer without an interrupt request. If HBD is high in the command register, the timers will count 8 times as fast. ### **06 IN Not Connected** Same as Input Ø2. ### **06 OUT Timer 2** Operates in the same fashion as Timer 1. ### **67 IN Not Connected** Same as Input Ø2. ### Ø7 OUT Timer 3 Operates in the same fashion as Timer 1. ### **68 IN Not Connected** Same as Input Ø2. ### 98 OUT Timer 4 Operates in the same fashion as Timer 1. ### **69 IN Not Connected** Same as Input Ø2. ### **89 OUT Timer 5** Operates in the same fashion as Timer 1. ### **ØAH-ØFFH IN And OUT Not Connected** Addressing these I/O ports causes no response from the TU-ART. These I/O ports are available to other parts of the computer system. ### Figure 3 Summary Of Register Formats For TU-ART, Each Device | OFFSET | FUNCTION | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DØ | REF.<br>PAGE | |--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------------------|----|------------------------------------------------------|----------------------------------------|---------------------------------------------------|--------------------------------|------------------------------|----------------------------------------------------------|----------------------------------------| | Ø<br>0<br>1<br>1<br>2<br>3<br>3<br>4<br>4<br>5-9 | IN STATUS OUT STATUS IN SERIAL OUT SERIAL OUT COMMAND IN INT ADDR OUT INT MASK IN PARALLEL OUT PARALLEL OUT Timer 1-5 | 1<br>T5/PI7<br>MSB<br>MSB (De | | IPG<br>4800<br>ion of sion of s<br>TB5<br>14*<br>TBE | hift —<br>HBD<br>12*<br>RDA<br>μsec, H | FBD<br>12ØØ<br>INE<br>IØ*<br>T3<br>BD=Ø)<br>BD=1) | SRV<br>300<br>RS7<br>1<br>SENS | ORE<br>150<br>BRK<br>1<br>T2 | FME<br>110<br>LSB<br>LSB<br>RES<br>1<br>T1<br>LSB<br>LSB | 6<br>7<br>7<br>7-8<br>8<br>8<br>8<br>8 | | | * | | | | | | | | | | | |----|----|----|---------------------|--|--|--|--|--|--|--|--| | t4 | 12 | 10 | Source of Interrupt | | | | | | | | | | 0 | ø | Ø | Timer 1 | | | | | | | | | | ě | ø | 1 | Timer 2 | | | | | | | | | | Ð | 1 | ø | SENS | | | | | | | | | | a | 1 | 1 | Timer 3 | | | | | | | | | | 1 | ø | ø | ADA | | | | | | | | | | 1 | 9 | 1 | TBE | | | | | | | | | | 1 | 1 | Ø | Timer 4 | | | | | | | | | | 1 | 1 | 1 | Timer 5/P17 | | | | | | | | | ## section. ### **Interrupt Operation** The TU-ART offers sophisticated interrupt capabilities, including on-board priority encoding, interrupt generation, interrupt acknowledgment, and daisy chain expandability. These features, in conjunction with the Cromemco 4 MHz Z-80 processor, make very high throughput possible. ### **IMPORTANT** Both channels of the TU-ART must be properly initialized. An uninitialized TU-ART may generate spurious interrupts! Further, the rest of the system must be interrupt compatible (all Cromemco boards are, although the 8K Bytesaver requires the interrupt modification shown on the 8K Bytesaver schematic). A description of interrupt operation follows for both the Z-80 and 8080 type interrupt modes. ### 3.1 Operation Using Z8Ø Interrupts When the TU-ART is used with the Cromemco ZPU, all 16 of the possible interrupt sources on the TU-ART can generate a unique response without the need for chaining the interrupt requests and polling the responses. This means fast response from interrupt request to service routine and, when coupled with the 4MHz Z-8Ø, an extremely powerful realtime system can be implemented. A "high priority" interrupt request is one which takes precedence over lower priority requests. This is shown in the following table where the interrupts serviced first are at the top. It is, of course, possible to use the interrupt mask of each Device to selectively enable and disable the sources of interrupts (reference the description of OUT Ø3, Interrupt Mask, in the previous section). Remember that the INE bit in the status register must be high for correct operation of Interrupt Acknowledge cycles. Also, be sure that the Z-8Ø has executed the interrupt mode setting command ØED5EH Table 1 Z80 (Mode 2) Response | Priority | | Z | A-UT<br>11 Ø8- | | Source of Interrupt | | | | | |-----------------------------------------------|-------------------------|-------------------------|-------------------------|---------------------------------|---------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DØ | | | 15 (Highest) 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | Set By Device A Adr. A7 | Set By Device A Adr. A6 | Set By Device A Adr. A5 | Ø Ø Ø Ø Ø Ø 1 1 1 1 1 1 1 1 1 1 | Ø Ø Ø Ø 1 1 1 0 Ø Ø Ø 1 1 1 1 1 | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0<br>0<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø Ø | Device A, Timer 1 Device A, Timer 2 Device A, SENSA Device A, Timer 3 Device A, RDA Device A, TBE Device A, Timer 4 Device A, Timer 5 (PI7) Device B, Timer 1 Device B, Timer 2 Device B, Timer 3 Device B, Timer 3 Device B, TBE Device B, TBE Device B, Timer 4 Device B, Timer 5 (PI7) | ### TU-ART Digital Interface ### Cromemce ("IM2") and the interrupt enable command ØFBH ("EI"). Both of these instructions must be executed each time the Z-80 is RESET. Assuming that both the Z-80 and the TU-ART have been initialized, the reception of a byte of serial data at Device B would initiate the following sequence of events: - a) The assembled byte is loaded into the receiver data buffer. - b) The RDA status bit is set and the interrupt request register (bit 3) is set. - c) If bit 3 of the interrupt mask of the Device in question is a one, the request passes on to the priority encoder. If bit 3 is a zero, no further action occurs until the mask is changed. - d) The priority encoder compares all incoming interrupt requests and sets its output to the value of the highest priority incoming interrupt. Thus, since Device B receives the serial data byte in our example; the priority encoder will set its output to "priority 3" if Timers 1, 2, 3, and SENSB from Device B are inactive or masked out. - e) Device B's INT pin goes high, which in turn pulls PINT low on the S-100 bus. - f) The Z-80 checks the interrupt line at the end of the current instruction, and finding the line active, goes into an Interrupt Acknowledge (INTA) cycle. - g) The occurrence of the INTA cycle is detected by the TU-ART which then transmits PRIORI- disables Interrupt Acknowledge from lower priority boards. If no board with higher priority is holding PRIORITY IN low, and if Device A has no interrupt pending, then Device B gates the proper Z-80 INTA response vector onto the data bus. In this example, Device B would place 18H logically ORed with (A7) (A6) (A5) 00000 from Device A's base address on the data bus. The corresponding bit in the interrupt request latch is reset. h) The Z-80 reads the INTA response byte and appends it to the byte in the I register. This then forms a sixteen bit address which points to the first of two sequential bytes in memory which in turn designate the actual starting address of the service routine. The CPU automatically executes a CALL to this starting address. ### 3.2 Operation Using 8080 Mode Interrupts When the TU-ART is used in Z-80 interrupt mode 0 it is necessary to "chain" Device B through the SENS input on Device A. This requires one of the eight INTA responses, RST2 0D7H), to be serviced by a routine which polls the status and interrupt address registers of Device B. The remaining seven INTA responses are serviced immediately. The resulting priority assignments are shown in Table 2. Table 2 Z8Ø (Mode Ø) Response | Priority | TU-ART's (Hex)<br>8Ø8Ø INTA Response | Souce of Interrupt | |--------------|--------------------------------------|-------------------------| | 15 (Highest) | C7 (RSTØ) | Device A, Timer 1 | | 14 | CF (RST1) | Device A, Timer 2 | | 13 | D7 (RST2) | Device B, Timer 1 | | 12 | D7 (RST2) | Device B, Timer 2 | | 111 | D7 (RST2) | Device B, SENSB | | 10 | D7 (RST2) | Device B, Timer 3 | | 9 | D7 (RST2) | Device B, RDA | | 8 | D7 (RST2) | Device B, TBE | | 7 | D7 (RST2) | Device B, Timer 4 | | 6 | D7 (RST2) | Device B, Timer 5 (P17) | | 5 | D7 (RST2) | Device B, SENSA | | 4 | DF (RST3) | Device A, Timer 3 | | 3 | E7 (RST4) | Device A, RDA | | 2 | EF (RST5) | Device A, TBE | | 1 1 | F7 (RST6) | Device A, Timer 4 | | Ø (Lowest) | FF (RST7) | Device A, Timer 5 (PI7) | ### TU-ART Digital Interface ### Cromemca It is of course, possible to use, the interrupt mask of each Device to selectively enable and disable the sources of interrupts (reference the discussion of OUT Ø3, Interrupt Mask, in the previous section). It is not necessary to reset the INE status bit of Device B to zero even though Device B can never respond directly to an Interrupt Acknowledge (INTA) cycle. The INTA status information is not fed to Device B if 8080 mode INTA has been selected on the Option DIP Switch. Therefore, the 5501 never attempts to drive the bus during INTA. No wiring changes are necessary to disconnect the INT pin of Device B from the PINT driver and to connect it to the Device A SENS pin. All this is done automatically when 8080 mode INTA has been selected on the Option DIP Switch. Note that SENSA at J1 is still connected. Pulling this line low will generate an interrupt request. The Z-80 must execute the EI instruction (0FBH) after resets or interrupts before an interrupt may take place. The sequence of events corresponding to Device B receiving a byte of serial data are as follows: - a) The assembled byte is loaded into the receiver data buffer. - b) The RDA status bit is set, the interrupt request register bit 3 is set, and the IPG status bit is set in the device which received the character (Device B in this example). - c) If bit 3 of the interrupt mask of the device in question is a one, the interrupt request passes on to the priority encoder. If bit 3 is a zero, no further action occurs until the mask is changed. - d) The priority encoder compares all incoming interrupt requests and sets its output to the value of the highest priority incoming interrupt. Thus, if Device B received the serial data byte in our example, the priority encoder will set its output to priority three if and only if Device B's Timers 1, 2, and 3 and SENSB are inactive or masked out. - e) Device B's INT pin goes high which in turn activates the SENS pin of Device A. - f) If bit 2 of Device A's interrupt mask is a one, the interrupt request will pass on to the priority - encoder. If bit 2 is a zero, no further action occurs until the mask is changed. - g) The priority encoder in Device A compares all incoming interrupt requests and sets its output to the value of the highest priority incoming interrupt. In our example, the interrupt from Device B activates the SENS input at Device A. This interrupt will have top priority if and only if Device A's Timers 1 and 2 are inactive or masked out. - h) Device A's INT pin goes high which in turn pulls PINT low on the S-100 bus. - The CPU checks the interrupt line at the end of the current instruction and, finding it active, goes into an Interrupt Acknowledge (INTA) cycle. - the TU-ART which then transmits PRIORITY OUT = Ø to J1. This temporarily disables Interrupt Acknowledge from lower priority boards. If no board with high priority is holding PRI-ORITY IN low, Device A will gate an 8080 INTA response onto the bus. In this example, Device A would place ØD7H on the data bus (RST2). The corresponding bit in Device A's interrupt request register is reset. - k) The Z-8Ø reads the INTA response byte and performs a CALL to location 1ØH, the starting address of the RST2 service routine. - 1) The service routine located at starting location 10H, reads the status register of Device B. If IPG is zero, no interrupts are pending in Device B so that the interrupt request must have originated from the SENSA line. The service routine branches to the appropriate subroutine. If IPG is one, Device B has an interrupt pending which must be serviced. The source of the interrupt is determined by reading Device B's Interrupt Address register. In our example, the Interrupt Address register would contain E7H. When this byte is read, the corresponding bit of the interrupt request register will be reset. The service routine has now determined the true cause of the interrupt and branches to the appropriate subroutine. connecting ces ### Connecting The TU-ART To I/O Devices ### **4.1 Parallel Ports** Each device has an 8-bit output port and an 8-bit input port with TTL buffering. The I/O connectors J2 and J3 provide these signals, along with several control lines. A full listing of these lines and their pin assignments is given in Tables 3 and 4. Figure 4 shows the timing of the TU-ART's parallel ports. Notice that the CPU driven Input Strobe (ISB) line is low while the TU-ART is reading the parallel port. Data should become stable no later than 75 nano- seconds after ISB goes low and should be held stable for at least 40 nanoseconds after ISB goes high. The CPU driven Output Strobe (OSB) line goes low while the TU-ART is loading a byte from the S-100 bus. There is an additional delay of up to 450 nanoseconds inside the TMS 5501 IC, so data becomes available at J2 or J3 a maximum of 450 nanoseconds after OSB goes high. Figures 5 and 6 show suggested circuits for block-mode transfers. In these schemes, the peripheral requests service from the processor and holds down the "ready" (Wait) lines between bytes. Figure 4 Parallel Port Timing Figure 5 Suggested Block Input Circuit ### Figure 6 Suggested Block Output Circuit ### Table 3 J2 Parallel A | | | g: . | Male | | |-----|-----------------|---------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin | Name | Signal<br>Direction | Voltage<br>Level | Function | | 1 | Invert | Input | TTL | Used for normal/reverse<br>address switching. See<br>discussion under "Switch<br>Selectable Options." | | 2 | Input Strobe A | Output | TTL | When active indicates that data present on input bits Ø -7 is being sampled. | | 3 | Vcc | Output | +5V | | | 4 | Bit 6 | Input | TTL | | | 5 | Bit 4 | Input | TTL | | | 6 | Bit 2 | Input | TTL | | | 7 | Bit Ø | Input | TTL | | | 8 | Disable | Input | TTL | Turns the output drivers for the parallel output bits OFF. | | 9 | Output Strobe A | Output | TTL | Indicates that data is present on parallel output bits Ø-7. | | 10 | Bit 6 | Output | TTL | | | 11 | Bit 4 | Output | TTL | | | 12 | Bit 2 | Output | TTL | | | 13 | Bit Ø | Output | TTL | | | 14 | Signal Ground | Output | Ø٧ | | | 15 | SENS A | Input | TTL | Interrupt request, input to IC 4 5501 (A) | | 16 | Bit 7 | Input | TTL | | | 17 | Bit 5 | Input | TTL | | | 18 | Bit 3 | Input | TTL | | | 19 | Bit 1 | Input | TTL | | | 20 | NMI | Input | TTL | Non maskable interrupt. This pin is tied directly to pin 12 of the S-100 bus. Consult the Z-80 manual for use. Only usable with the Cromemco ZPU card. | | 21 | Wait | Input | TTL | This pin is tied directly to pin 72 (PRDY) of the S-100 bus. Forces the CPU to wait when held low. | | 22 | Bit 7 | Output | TTL | | | 23 | Bit 5 | Output | TTL | | | 24 | Bit 3 | Output | TTL | | | 25 | Bit 1 | Output | TTL | | | | | | | | ### Table 4 J3 Parallel B | Pin | Name | Signal<br>Direction | Voltage<br>Level | Function | |----------------------------------|----------------------------------------------------|-----------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------| | 1 | Invert | Input | TTL | Used for normal/reverse address switching. See discussion under "Switch Selectable Options." | | 2 | Input Strobe B | Output | TTL | When active indicates that data present on input bits Ø-7 is being sampled. | | 3<br>4<br>5<br>6<br>7<br>8 | Vcc<br>Bit 6<br>Bit 4<br>Bit 2<br>Bit Ø<br>Disable | Output<br>Input<br>Input<br>Input<br>Input<br>Input | +5V<br>TTL<br>TTL<br>TTL<br>TTL | Turns the output drivers for the parallel output bits OFF. | | 9 | Output Strobe B | Output | TTL | Indicates that data is present on parallel output bits Ø-7. | | 10<br>11<br>12<br>13<br>14<br>15 | Bit 6 Bit 4 Bit 2 Bit Ø Signal Ground SENS B | Output Output Output Output Output Input | TTL<br>TTL<br>TTL<br>TTL<br>ØV<br>TTL | Interrupt request, input to IC 5 5501 (B). | | 16<br>17<br>18<br>19<br>20 | Bit 7 Bit 5 Bit 3 Bit 1 PRESET | Input<br>Input<br>Input<br>Input<br>Input | TTL<br>TTL<br>TTL<br>TTL | Preset. This pin is tied directly to pin 75 of the S-100 bus. Consult the Z-80 manual for use. Only usable with the Cromemco ZPU card. | | 21 | Wait | Input | TTL | This pin is tied directly to pin 72 (PRDY) of the S-100 bus. Forces the CPU to wait when held low. | | 22<br>23<br>24<br>25 | Bit 5<br>Bit 3 | Outpu<br>Outpu<br>Outpu<br>Outpu | t TTL | | ### **4.2 Serial Ports** Device A and Device B each have a bidirectional serial port with RS-232 and current loop buffering. The I/O connectors J4 and J5 provide access to these signal lines, along with several control lines. A full listing of the J4 and J5 pin assignments is shown in Tables 5 and 6. Figure 7 shows how flat wire cables should be connected to the TU-ART. Figure 8 shows a suggested wiring diagram. ### Table 5 J4 Serial A | Pin | Name | Signal<br>Direction | Voltage<br>Level | Function | |------|----------------------|---------------------|------------------|-------------------------------------------------------------------------------------------------------------------------| | 1 | FRAME GROUND | | | Not connected on PC board. This pin should be tied to the chassis at the back panel if an RS232 terminal is being used. | | 2 | INPUT A | Input | ±12V | RS232 data input. | | 3 | OUT A | Output | ±12V | RS232 data output. | | 4 | NC | | | | | 5 | NC | | | | | 6 | DSR | Output | +12V | RS232 data set ready. Tied to +12V through 1.5k (R5) on the PC board. | | 7 | SIGNAL GND | | ØV | RS232 signal ground | | 8 | стѕ | Output | +12V | RS232 clear to send. Tied to +12V through 1.5k (R4) on PC board. | | 9-16 | NC | | | | | 25 | TTY<br>PRINTER A (-) | Output | | Data output current loop –<br>(current sink) | | 23 | TTY<br>PRINTER A (+) | Output | +12V | Data output current loop + (current source) | | 17 | TTY<br>KEYBD A (+) | Input | +12V | Data input current loop + (current source) | | 24 | TTY<br>KEYBD A (-) | Input | -5V | Data input current loop –<br>(current sink) | | 26 | NC | | | | ### Table 6 J5 Serial B | Pin | Name | Signal<br>Direction | Voltage<br>Level | Function | |-------------|--------------------------|---------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------| | 1 | FRAME GROUND | | | Not connected on PC board.<br>This pin should be tied to the<br>chassis at the back panel if an<br>RS232 terminal is being used. | | 2 | INPUT B | Input | ±12V | RS232 data input. | | 3 | OUT B | Output | ±12V | RS232 data output. | | 4 | NC | | | | | 5 | NC | | | | | 6 | DSR | Output | +12V | RS232 data set ready. Tied to +12V through 1.5k (R5) on PC board. | | 7 | SIGNAL GND | | Ø٧ | RS232 signal ground. | | 8 | CTS | Output | +12V | RS232 clear to send. Tied to +12V through 1.5k (R4) on PC board. | | 9-16 | NC | | | | | 25 | TTY<br>PRINTER B (-) | Output | | Data output current loop – (current sink) | | 23 | TTY<br>PRINTER B (+) | Output | +12V | Data output current loop + (current source) | | 17 | TTY<br>KEYBD B (+) | Input | +12V | Data input current loop + (current source) | | 24<br>18-22 | TTY<br>KEYBD B (-)<br>NC | Input | -5V | Data input current loop –<br>(current sink) | | 26 | NC | | | | ### Figure 7 Cable Connection \*NOTE: Some ribbon cables may feed the female connector from the side opposite that illustrated in this figure. In all cases, the cable stripe must be aligned with the arrow head on the TU-ART legend. Figure 8 Terminal To TU-ART Cable Pin# Pin# **TXD** RXD TU-ART Terminal DB 25-S connects connects DB 25-S to Female to Female GND Connector J Connector **DB 25P** Male Connector **DB 25P** 15 ft. Male Connector (length optional) This is a diagram of the cable required to connect a serial RS-232 I/O device (such as a CRT terminal) from the DB 25-S socket of the TU-ART cable (model TRT-CBL) to the DB 25-S connector of the RS-232 device. The jumper connection between pins 4, 5, 6, 8 and 20 may not be required since some terminals have internal pullups on these lines. ### **4.3 Originate Mode Modification** The TU-ART board is factory wired in the answer mode for both serial I/O channels A and B. That is, serial data is input to the TU-ART at J4 or J5 pin 2 (RS232 IN) and serial data is output from the TU-ART over J4 or J5 pin 3 (RS232 OUT). In this context, the TU-ART is playing the role of the computer end of a serial line which is attached to a remote terminal. The TU-ART may be re-configured in the originate mode (that is, the TU-ART assumes the role of the remote terminal) by cutting foil traces and installing jumper wires as described below. There are two vertical rows of pads located between connectors J4 and J5 (see illustration ahead). Device A and Device B may be independently configured in either the answer or originate modes. To configure either device in the originate mode: - 1) Cut the trace connecting the top and bottom pads on the appropriate device side (the trace connecting "2" and "IN"). - Cut the trace connecting the middle two pads on the appropriate device side (the trace connecting "3" and "OUT"). - Install an insulated jumper wire between pads "2" and "OUT." 4) Install an insulated jumper wire between pads "3" and "IN." ### 4.4 Spare RS232 Drivers And Receivers There are two uncommitted sections in IC 9, a 75189 Receiver. Pads for jumper wires have been provided at pins 1, 2, 3 and at pins 11, 12, 13. There are two uncommitted sections on IC 11, a 75188 driver. Pads have been provided at pins 4, 5, 6 and at pins 8, 9, 10. These uncommitted sections are shown on the schematic diagram. ### Sections Programmes ### **Programming Examples** ### **5.1 1-SEC Metronome** This program rings the console bell at 1-second intervals using Z80 mode interrupts. It is provided as an example of TU-ART operation. It is assumed that the CRT or terminal being used will be connected to serial ports Ø and 1 of the 4FDC and that this program will be loaded and executed from the disk. Set TU-ART switches 1, 6, 7, and 9 OFF; all other switches on the TU-ART DIP switch should remain ON. This addresses Device B at base port 50H and Device A at base port 80H. Note that Timer 1, Device A is used to generate the interrupt below. | 0000 | | 0014<br>0015<br>0016 | ; | ORG | 100H | | |--------------|--------------|----------------------|-------------|-----------|----------------|--------------------------------------------------------| | 0100<br>0101 | F3<br>310003 | 0017<br>0018<br>0019 | ;<br>TUART: | DI<br>LD | SP,300H | | | 0104 | 3E00 | 0019 | | LD | A,0 | ;Select Device A (see | | 0104 | D354 | ØØ21 | | OUT | 54H,A | ;software ADDR-REVERSE). | | 0108 | 3EØ9 | 0022 | | LD | A, 9 | Reset Device A & enable | | 010A | D382 | 0023 | | OUT | 82H,A | ;interrupt ack response. | | 010C | 3EØ1 | 0024 | | LD. | A,1 | ;Mask out all interrupts but | | 010E | D383 | ØØ25 | | OUT | 83H,A | those from Timerl, Device A | | 0110 | 3E00 | 0026 | | LD | A,0 | ;Mask out all interrupts | | Ø112 | D353 | 0027 | | OUT | 53H,A | from Device B. | | Ø114 | 3EØ2 | 0028 | | ĹD | A, 2 | ;Select page 2 | | Ø116 | ED47 | 0029 | | LD | I,A | for interrupt vectors. | | | ED5E | 0030 | | IM2 | • | ;Interrupt mode 2 (Z80 mode). | | Ø11A | CD2801 | 0031 | | CALL | INIT | ;Initialize the Timer. | | | | 0032 | ; | | | | | | | ØØ33 | ; What | follows | is an in | finite loop. It could | | | | | | | | l program entirely | | | | | | ated to | the Time | r program. | | | | ØØ36 | | | | | | Ø11D | C31D01 | | HERE: | JP | HERE | | | | | | ; | | | | | | | | | rupt Sei | vice Rou | tine. | | | | | ; | | _ | | | 0120 | Ø5 | | TIMER: | DEC | B | | | 0121 | C22AØ1 | 0042 | | J₽ | NZ,TM2 | o trutting 7 (°C) to the | | 0124 | 3EØ7 | 0043 | | LD | A,7 | ;Outputting 7 (^G) to the ;console will ring the bell. | | Ø126 | D3Ø1 | 0044 | | OUT | 1,A | | | Ø128 | Ø67D | | INIT: | LD | B,125 | ;Multiplier factor.<br>;Count for Timer1. | | Ø12A | 3E7D | 0046 | TM2: | LD | A,125<br>85H,A | ;(125 * 64 usec = 8 msec) | | Ø12C | D385 | 0047 | | OUT | оэн, н | ;Enable interrupts before | | Ø12E<br>Ø12F | FB<br>C9 | ØØ48<br>ØØ49 | | EI<br>RET | | ;going to label HEPE. | | DIZI | Cy | | | RET | | going to tabel more. | | | | 0051 | į | | | • | | 0130 | | ØØ51<br>ØØ52 | * | ORG | 28ØH | | | 0280 | 2001 | ØØ53 | | DW | TIMER | ;Interrupt vector, Timerl | | 0282 | (0000) | ØØ54 | | END | 7 11,011 | , | | ULUL | (5555) | 2234 | | | | | | Error | 5 | Ø | | | | | ### **5.2 Initialization Subroutine** ``` 0001 ; 0002 ; TUART PROGRAMMING EXAMPLES 0003; 0004; 0005 ; 0006 ; ;BASE ADDRESS DEVICE A ØØØ7 ABASE: EOU (ØØØØ) ;BASE ADDRESS DEVICE B 5 ØH ØØØ8 BBASE: EQU (ØØ5Ø) 0009 ; ,9600 BAUD, ONE STOP BIT ØCØH ØØ1Ø BAUDA: EQU (ØØCØ) ;110 BAUD, TWO STOP BITS ØØ11 BAUDB: EOU (0001) ;BAUD RATE PORT A ØØ12 ABDR: EOU ABASE (0000) BAUD RATE PORT B ØØ13 BBDR: EQU BBASE (ØØ5Ø) ØØ14 ; ; RESET+INTA COMMAND ØØ15 RESET: EQU (ØØØ9) ABASE+2 ; COMMAND PORT A ØØ16 ACMD: EQU (0002) BBASE+2 ; COMMAND PORT B EQU 0017 BCMD: (ØØ52) ØØ18 ; ; NO INTERRUPTS FROM A EOU 0019 MASKA: (ØØØØ) ;NO INTERRUPTS FROM B EQU 0020 MASKB: (0000) ABASE+3 ; INTERRUPT MASK PORT A 0021 AMSK: EQU (0003) BBASE+3 ; INTERRUPT MASK PORT B EQU ØØ22 BMSK: (ØØ53) 0024 ; EXAMPLE 1 -- INITIALIZATION ROUTINE ØØ25 ; ØØ26 ; SUBROUTINE INIT: ØØ27 : CALLING PARAMETERS: NONE ØØ28 ; RETURN CONDITION: TUART INIT'ED 0029 : 0030 ; ØØ31 ; 1000H ORG 0032 0000 ;SAVE STATE ΑF PUSH 0033 INIT: 1000 F 5 A, RESET ; GET COMMAND LD ØØ34 3EØ9 1001 ACMD, A ; DEVICE A RESET OUT 0035 D3Ø2 1003 BCMD, A ; DEVICE B RESET TUO D352 ØØ36 1005 ØØ37 ; A, MASKA ; GET INTERRUPT MASK ĽD 1007 3E00 ØØ38 AMSK, A ; MASK A SET OUT D3Ø3 0039 1009 A, MASKB ;GET INTERRUPT MASK LD 0040 100B 3E00 BMSK, A ; MASK B SET OUT 0041 100D D353 ØØ42 ; A, BAUDA ;GET BAUD RATE LD ØØ43 3ECØ 100F ABDR, A ; RATE A SET OUT 0044 1011 D3ØØ A, BAUDB ; GET BAUD RATE LD ØØ45 1013 3EØl BBDR,A ; RATE B SET OUT D35Ø 0046 1015 :RETRIEVE STATE ΑF POP ØØ47 F1 1017 RET 0048 1018 ``` ### **5.3 Character Output Subroutine** ``` 0050 : EXAMPLE 2 -- SUBROUTINE TO TRANSMIT A CHARACTER 0051 : TO DEVICE A ØØ52 ; 0053; SUBROUTINE CHAROUT: ØØ54 ; CALLING PARAMETERS: ASCII CHR. IN REG. A ØØ55 ; RETURN CONDITION: CHARACTER SENT ØØ56 ; 0057 ; 0058; ABASE+Ø ; STATUS REGISTER A ØØ59 ASTAT: EQU (ØØØØ) ABASE+1 ; DATA REGISTER A EOU ØØ6Ø ADATA: (ØØØ1) ;BUFFER EMPTY BIT ØØ61 TBE: EOU (0080) 0062 ; 0063 CHROUT: PUSH ;SAVE THE CHARACTER F5 1019 A, ASTAT READ STATUS DBØØ 0064 SCHK: IN 101A ;TRANSMIT BFR. EMPTY? TBE AND ØØ65 E680 1 Ø1C Z,SCHK ;LOOP UNTIL READY 0066 JR 28FA 101E ; RETRIEVE CHARACTER AF POP 1020 F1 ØØ67 ADATA, A ; TRANSMIT IT OUT 1021 D301 ØØ68 ; DONE RET C9 0069 1023 ``` ### **5.4 Character Input Subroutine** ``` 0071 ; EXAMPLE 3 -- SUBROUTINE TO READ A CHARACTER ØØ72 ; FROM DEVICE A ØØ73 ; ØØ74 ; SUBROUTINE CHRIN: ØØ75 : CALLING PARAMETERS: NONE ØØ76 ; RETURN CONDITION: ASCII CHR IN A ØØ77 ; Z FLAG RESET ØØ78 ; ØØ79 ; ØØ8Ø ; ;DATA AVAILABLE BIT EOU 4 ØH (0040) ØØ81 RDA: A, ASTAT ; GET STATUS IN DBØØ ØØ82 CHRIN: 1024 ;RCVR DATA AVAIL? AND E640 ØØ83 1026 Z, CHRIN ; LOOP TILL READY JR 28FA 0084 1028 A, ADATA ; READ CHARACTER IN DBØ1 ØØ85 1Ø2A : DONE RET C9 ØØ86 1 Ø 2C ``` ### 5.6 "Echo" Program | | | 0088 ;<br>0089 ;<br>0090 ; | EXAMPLE 4 "! | ECHO" PROGRAM FOR DEVICE A | |----------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------------------|------------------------------------------------------------------------------------------| | 0103<br>0106<br>0109 | (0200)<br>310002<br>CD0010<br>CD2410<br>CD1910<br>18F8 | 0091;<br>0092<br>0093 STACK:<br>0094<br>0095<br>0096 READ:<br>0097<br>0098<br>0099; | CALL INIT CALL CHRIN CALL CHROUT JR READ | ;STACK AREA CK;SET STACK POINTER ;RESET TUART ;WAIT FOR AN INPUT ;NOW SEND IT BACK ;LOOP | | Ø1 ØE | (0000) | 0100 | END | | | Errors | i | Ø | | | # Theory of the Control ## Theory Of Operation ## **6.1 Introduction** The TU-ART has ten functional blocks supporting the TMS 5501s: **Power Supply** Three IC regulators and a zener diode are used to generate $\pm 5$ and $\pm 12$ volts. Crystal Controlled Clock An 8 MHz crystal oscillator is used as an on-board reference to control the internal state machine and to drive the Ø1 and Ø2 clocks of the TMS 5501s. Address Select Two four-bit address comparators generate base address select signals when the four most significant device address bits of an input or output instruction agree with one of the two base address switch settings on the TU-ART. The base address select signals enable the appropriate TMS 55Ø1 (depending on the current state of the Address Reverse multiplexer). Function Decode The four function address pins on the TMS 5501s are driven by a read only memory addressed by the lower four bits of the S-100 address bus and status signal WO. The ROM also generates signals for internal bus control. State Sequencer The internal state sequencer starts up whenever the TU-ART is addressed and cycles the internal bus through an 8080 M3-like sequence. The sequence starts with a SYNC pulse to the 5501s while the internal data bus is strobed with status information appropriate to the type of cycle requested by the processor (IO read, IO write, or Interrupt Acknowledge); continues while data is written or read; and terminates after signalling READY to the processor. Status Strobe Data bus pins DØ and D1 are controlled by the status strobe circuit during internal SYNC time to select the proper TMS 55Ø1 operation. Bus Multiplexers The internal data bus is time multiplexed (for status information), direction multiplexed (depending on the type of cycle: read or write), and path multiplexed (depending on the particular read-type function being performed) under control of the state generator and three-state bus drivers. Serial Interface The TTL level serial output signal from the TMS 55Ø1s is converted to EIA RS/232 levels and to a teletype compatible current switch. Serial input may be from either EIA or teletype. Parallel Interface TTL Bus buffers drive the parallel ports. Handshaking signals are controlled by the function decoder ROM. Priority Chain A ripple priority resolver controls Data bit DØ (INTA) on each TMS 55Ø1 during SYNC time. This prevents both devices from responding to an Interrupt Acknowledge cycle from the processor when both devices have active interrupt requests. The priority chain is expandable to multiple boards. These ten blocks, which are listed in the approximate order of attack for troubleshooting, will be discussed in detail below. ## **6.2 Power Supply** The TMS 55Ø1s require three power supplies: $V_{CC}$ = +5, $V_{DD}$ = +12, and $V_{BB}$ = -5. A -12V source is created by zener diode D1 for the EIA line driver and receiver IC's. The +12 supply is used by the EIA line drivers, the TTY interface, and the Ø1, Ø2 clock drivers. The -5 supply is used by the TTY interface. ## **6.3 Crystal Controlled Clock** An 8.000 MHz crystal oscillator generates the TU-ART's timebase. A two-phase, 2MHz clock is derived from the IC41P8 (02TTL) and IC42P6 (01TTL). These signals are followed by high voltage inverters to generate the 12 volt clocks for the TMS 5501s. Transistors Q1 and Q2 form edge-active pullups for the inverters. A 75 pf - 330 ohm differentiator network on the base of each transistor couples a spike from the falling edge of the TTL input into the base. This switches the transistor on briefly and pulls the collector to +12 volts. A 47 ohm series resistor in the clock lead reduces ringing and overshoot. The rising edge of the TTL input turns on the 7406 inverter which pulls the collector of the transistor (now off) back to ground. The state generator is clocked by 02TTL and 02TTL outputs from IC41P9 and IC41P8. Clock waveforms are summarized in Figure 9. ## Figure 9 Clock Waveforms ## **6.4 Address Select** Four-bit address comparison is performed by open collector exclusive or gates IC46 and IC47. Incoming address lines are deglitched and inverted by 74LØ4 inverters, then ex-ored with 4 bits from the DIP switch base address select positions. A closed switch matches a "1" on the Address bus; an open switch matches a "O" on the Address bus; when all four bits match and SOUT or SINP is active then the open collector wired - and node will go high. If the node at RN2P7 is high Base Address B is being selected. If RN2P5 is high Base Address A is being selected. When Device A is addressed IC43P6 pulls down the Device B select node to prevent bus conflict if both base addresses accidentally have been set equal. When either Device select is active IC4ØP1Ø goes low, enabling the Function Decoder ROM. Multiplexer IC35 performs Base Address reversing when its select pin goes low. In the normal case Device A select enables the CE driver of IC4, while Device B select enables the CE driver of IC5. Base address reversing enables IC5 in IC4's place and vice versa. The select pin of the MUX, IC35P1 is controlled by the signal applied to J2P1 or J3P1; or, if DIP Switch 2 is closed, by IC4P31 (the MSB of Device A's output parallel port). ## **6.5 Function Decode** TTL PROM IC28 is enabled when IC28P15 goes low (which occurs at the beginning of Input and Output cycles). IC28 is not enabled during interrupt acknowledge. When IC28 is enabled, it supplies function address signals to the 4 address pins of the 5501s. IC28P5 goes low during I/O operations involving the parallel ports and drives IC1, a decoder chip which generates Input and Output strobe signals, IC28P6 goes low during Output cycles. This signal controls the incoming bus buffers, generates a state-cycle request by pulling down IC24P10, and is strobed on the internal data bus bit D1 at SYNC time by IC43P3, IC28P7 goes low during INPUT cycles. This signal controls the outgoing bus drivers and generates a state-cycle request by pulling down IC24P9. This signal is not active (floats) during INTA cycles. IC28P9 goes low when the status port of the TMS 5501s is read. This signal controls an internal data path from the TMS 5501s to the output data latch, IC44. ## **6.6 State Sequencer** The heart of the TU-ART is the state sequencer, a four-stage shift register which times the status drivers and data in/out circuits to form an 8080-like internal bus. The input to the state sequencer, IC25P2, is the signal from IC36P6 (IOREAD + IOWRITE + INTER-RUPT ACKNOWLEDGE). While this signal is low, the state sequencer is held in a reset state by direct clear pins 1 and 13 of ICs 25 and 12. When the input goes high a high level will be shifted to IC25P5 at the first falling edge of Ø2. IC23P8 then goes high, generating a SYNC signal at Pin 19 of both TMS 55Ø1s and turning on status strobe driver IC18 through IC4ØP6 and IC43P1. The state sequencer is now clocked by the rising edge of Ø2, shifting a high level to IC25P9. IC23P1Ø goes low and remains low until the state sequencer is reset at the end of the I/O cycle. The status strobe drivers are shut off. The TMS 55Ø1 now arranges internal data paths according to the address and status information it received during SYNC time. If the TU-ART is in an IOWRITE cycle the S-1ØØ DO bus receivers IC18 and IC30 are enabled. The state sequencer is clocked for a third time by Ø2 falling edge, propagating the high level at IC25P9 to IC12P5. The Gate input of the DI bus latch is raised (IC44P11). The PRDY driver IC16 is disabled, signalling "READY" to the CPU, and releasing the bus from its WAIT condition. The final change in state occurs on the rising edge of Ø2 when IC12P8 goes low. This shuts off the DI latch gate. The state sequencer has completed its cycle and remains in this state until the processor terminates the I/O cycle. State sequencer timing is summarized in Figure 10. ## 6.7 Status Strobe The TMS 5501s have no control pins for DBIN or WR; instead the ICs monitor bits DØ and D1 of the data bus during SYNC for status information. If DØ is high during SYNC, an Interrupt Acknowledge cycle is beginning, and the 5501 will send data to the bus during "T3" of the cycle. If D1 is high an IOREAD operation is beginning and the 5501 whose CE pin was high during SYNC will access the internal register addressed by A3-AØ and present data to the bus at "T3" of the cycle. If D1 is low during SYNC, an IOWRITE operation is beginning and the 5501 whose CE pin was high during SYNC will latch data from the bus during "T3" of the cycle. Bit D1 is controlled by an open collector nand, IC 43, which is strobed by SYNC. Bit DØ is split into DØA and DØB so that INTA can be sent to the TMS 55Ø1s individually. This is necessary because CE no longer selects the chip during interrupt acknowledge. Three-state driver IC18 controls DØA and DØB during SYNC. ## Figure 10 State Sequencer Timing ## **6.8 Bus Multiplexers** The internal data bus which connects the two TMS 5501s will float while idle. At the beginning of a cycle it is strobed by the status drivers as described in the previous section. Following status the bus assumes one of five configurations (see Figure 11). - IOWRITE cycle: The S-100 DO bus receivers drive the internal data bus during WR · (T≥T2). - 2. IOREAD (EXCEPT READ STATUS PORT): The internal data bus is buffered by a set of permanently-enabled 74367 sections, then passed through another set of 74367s, enabled by the assertion of READ and STATUS. These 74367s drive the output latch IC44 which latches during T3 of the internal cycle. IC44 has three state output drivers built in which drive the S-100 D1 bus during DBIN · IOACTIVITY. - 3. IOREAD STATUS: The buffered internal data bus passes through the status bit select pocket where bits from the 55Ø1 may be arranged arbitrarily in order to control flag bit assignments. The "scrambled" bits are then passed through 74367s which have been enabled by STATUS going low. The output latch operates as before. - 4. INTA MODE Ø (8Ø8Ø): During MODE Ø INTA the buffered internal data bus bits D3-D5 are routed through 74367s straight to the output latch. The remaining bits are passively pulled high. - 5. INTA Mode 2 (Z-80): During a mode 2 INTA the buffered internal data bus bits D3-D5 plus INTA B plus A7, A6 and A5 from Base address A form inputs to a set of 74367s which drive the output latch. ## **6.9 Serial Interface** Transmit output from the TMS 5501 is inverted to RS232 levels by IC11 (1488). Output is also provided from a 7406 high voltage inverter for grounding a 20 mA current source or for TTL level output. The RS232 output idles at -12v, the 7406 output idles at ground (conducting). Receiver input is taken from an RS232 line receiver, IC9 (1489). IC9 converts RS232 levels to TTL. When a TTY keyboard is used, it switches the bias voltage on IC9 from +12 to -5 which causes TTL level switching at the output. The output of the 1489 idles at +5 volts. ## **6.10 Parallel Interface** Parallel inputs to the TMS 5501 are TTL buffered by 74367s. Parallel outputs are inverted and buffered by 74368s to keep positive logic. The 74368s may be three stated by grounding DISABLE. Strobe signals are decoded by IC1. ## **6.11 Priority Chain** The TU-ART will respond to an Interrupt Acknowledge cycle from the processor when three conditions are satisfied: 1) The processor has raised SINTA, the Interrupt Acknowledge status signal, 2) one of the TMS 5501s is requesting interrupt (high level on IC4P23 or IC5P23), and 3) no other device higher up the priority chain is requesting an interrupt. The priority chain input at J1 is used to clear IC48, the INTA enable flip flop. Suppose IC4 (Device A) requested an interrupt at the same time as IC5 (Device B). If Priority IN was being held low by a higher priority TU-ART, both sections of IC48 would remain cleared, disabling IC23P5 and IC23P6 from generating SINTA status bits. When Priority IN is allowed to float to +5, the next M1 occurrence will clock the two sections of IC48 (M1 may be the start of an INTA cycle, though it doesn't have to be). Both IC48P5 and IC48P9 go high momentarily because both DEVICE A and Device B have interrupts pending. However IC48P6 ripples through IC13P3 to force IC48P9 low in exactly the same manner as PRIORITY IN from J1. Thus only DEVICE A actually receives the INTA status bit and no bus conflict is allowed. ## Figure 11 Bus Signal Flow ## section. Application ## **Application Notes** ## 7.1 Cromemco TU-ART Interface For The Oliver Audio Engineering Mode OP-80A Paper Tape Reader (or any device requiring a parallel port with hand shake) This routine uses the TU-ART Sense line as a DATA READY flag for the parallel port: | ØØØØ: F3 | DI | DISABLE INTERRUPTS | |----------------|--------------------|--------------------------| | ØØØ1: 3E Ø4 | MVI A, <b>Ø</b> 4H | GET INT. MASK FOR SENS | | ØØØ3: D3 Ø3 | OUT Ø3 | OUTPUT IT | | ØØØ5: DBØØ | IN ØØ | GET STATUS | | ØØØ7: E6 2Ø | ANI 20 | ISOLATE INT. PENDING BIT | | ØØØ9: CA Ø1 ØØ | JZ ØØØ1H | WAIT FOR NEW DATA | | ØØØC: DB Ø3 | IN <b>Ø</b> 3 | CLEAR CAUSE OF INT. | | ØØØE: DB Ø4 | IN Ø4 | GET DATA FROM PARALLEL | | | | PORT & GENERATE NACK | User routine goes here, Example: ØØ1Ø: CD 12 E1 CALL PCHR PRINT ASCII CHAR. INPSTBA (J2 Pin 2) TO NACK 0013: C3 00 00 JMP 0000H DO AGAIN CONNECT RDA TO SENSA LINE (J2 Pin 15) CONNECT THE EIGHT DATA LINES TO INPUT BITS Ø-7 ON J2 (Pins 4-7 and 10-13) CONNECT GND TO SIGNAL GND (J2 Pin 14) CONNECT +5V TO VCC (Pin 3) ## 7.2 Using The TU-ART In 4FDC Systems The TU-ART is often used to provide additional I/O facilities in systems based around the Cromemco 4FDC Disk Controller. Since the 4FDC has a built-in I/O port which is addressed at ØØH (base address), the TU-ART CONNECT will conflict if the usual addresses of 00H and 50H are used. We recommend 20H and 80H for Device A base address and Device B base address, respectively. If CDOS is used, the TU-ART will be initialized for you. If CDOS is not used you must be certain to initialize both sections of the TU-ART (even if only one section is used) to prevent spurious interrupts. ## **ASCII** Character Codes | DEC | CHAR | DEC | CHAR | DEC | CHAR | DEC | CHAR | |-----------------|-------------|--------------|------|-----|------|-------------|------| | 000 | CTRL-@ | Ø33 | ! | Ø66 | В | Ø99 | С | | ØØ1 | CTRL-A | <b>Ø</b> 34 | " | Ø67 | C | | į | | 002 | CTRL-B | | | Ø68 | D | 100 | d | | 003 | CTRL-C | Ø35 | # | Ø69 | E | 101 | e | | 004 | CTRL-D | Ø <b>3</b> 6 | \$ | | | 102 | Ť | | [ | | Ø37 | % | Ø7Ø | F | 103 | g | | ØØ5 | CTRL-E | <b>Ø3</b> 8 | & | Ø71 | G | 104 | 'n | | <b>Ø</b> Ø6 | CTRL-F | Ø39 | t | Ø72 | H | | | | ØØ7 | CTRL-G | | | 073 | • | 105 | Ī | | ØØ8 | BS | Ø40 | ( | 074 | j | 1 <b>96</b> | j | | ØØ9 | HOR. TAB | Ø41 | ) | | | 1Ø7 | k | | 000 | 11011. 1715 | Ø42 | * | Ø75 | K | 1Ø8 | į | | Ø1Ø | LINE FEED | Ø43 | + | Ø76 | L | 1Ø9 | m | | 011 | VERT. TAB | Ø44 | | Ø77 | M | | | | Ø12 | FF | 10-5-7 | , | Ø78 | Ν | 110 | n | | Ø13 | CR | 045 | - | 079 | 0 | 111 | o | | Ø14 | CTRL-N | Ø46 | Ī | | | 112 | р | | 7 | Official | Ø47 | 1 | 080 | Р | 113 | q | | Ø15 | CTRL-O | Ø48 | Ø | Ø81 | Q | 114 | ť | | Ø16 | CTRL-P | Ø49 | 1 | Ø82 | R | | | | Ø17 | CTRL-Q | 5.5 | • | Ø83 | S | 115 | s | | Ø18 | CTRL-R | Ø5Ø | 2 | 084 | T | 116 | t | | Ø19 | CTRL-S | Ø51 | 3 | | | 117 | u | | 913 | 01112-0 | Ø52 | Ą | Ø85 | IJ | 118 | ٧ | | Ø2Ø | CTRL-T | Ø53 | 5 | Ø86 | V | 119 | ΆΛ | | Ø20<br>Ø21 | CTRL-U | Ø54 | 6 | Ø87 | W | | | | 022 | CTRL-V | 957 | • | Ø88 | X | 120 | × | | 023 | CTRL-W | Ø55 | 7 | Ø89 | Y | 121 | A | | Ø23<br>Ø24 | CTRL-X | Ø56 | 8 | 300 | • | 122 | Z | | Ψ2 <del>4</del> | OTHE-X | Ø57 | 9 | Ø9Ø | Z | 123 | ( | | <b>Ø</b> 25 | CTRL-Y | Ø58 | | Ø91 | [ | 124 | 1 | | Ø25<br>Ø26 | CTRL-Z | Ø59 | | Ø92 | , | | | | Ø27 | CTRL-[ | 955 | , | Ø93 | ] | 125 | } | | Ø27<br>Ø28 | CTRL-\ | Ø6Ø | < | Ø94 | Á | 126 | • | | Ø29 | CTRL-] | Ø61 | = | | , | 127 | DEL | | פשע | OTHE | Ø62 | > | Ø95 | _ | 1 | | | 030 | CTRL-∱ | Ø63 | ? | Ø96 | , | | | | Ø30<br>Ø31 | CTRL | Ø64 | @ | Ø97 | а | | | | Ø31<br>Ø32 | SPACE | Ø65 | Ā | Ø98 | b | | | | ₩3∠ | JI AGE | | | | | | | CTRL = Control Character CR = Carriage Return BS = Backspace FF = Form Feed DEL = Rubout ## Parts List | Capacitors | | Part No. | Re | Part No. | | |---------------|---------------------------------------|-------------------|----------------|----------------|----------| | C1 | Ø.1Ø μF | ØØ4-ØØ3Ø | R1 | 1K | ØØ1-ØØ18 | | C2 | Ø.05 μF | ØØ4-ØØ27 | R2 | 39Ø | ØØ1-ØØ13 | | C3 | Ø.10 μF | 004-0030 | R3 | 47 <b>Ø</b> | 001-0014 | | C4 | Ø.1Ø μF | ØØ4-ØØ3Ø | R4 | 1.5K | 001-0020 | | C5 | Ø.Ø5 μF | 004-0027 | R5 | 1.5K | 001-0020 | | C6 | 1Ø.ØØ μF | 004-0032 | R6 | 680 | 001-0016 | | C7 | Ø.1Ø μF | 004-0030 | R7 | 18K | 001-0032 | | C8 | Ø.1Ø μF | 004-0030 | R8 | 18K | 001-0032 | | C9 | 1Ø.ØØ μF | 004-0032 | R9 | 470 | 001-0014 | | C10 | · | 004-0030 | R1Ø | 1.5K | 001-0020 | | C11 | | ØØ4-ØØ3Ø | R11 | 1.5K | ØØ1-ØØ2Ø | | C12 | • | ØØ4-ØØ32 | R12 | 680 | 001-0016 | | C13 | · | ØØ4-ØØ3Ø | R13 | 390 | 001-0013 | | C14 | - | ØØ4-ØØ3Ø | R14 | 1K | 001-0018 | | C15 | · · · · · · · · · · · · · · · · · · · | ØØ4-ØØ3Ø | R15 | 1K | 001-0018 | | C16 | | ØØ4-ØØ3Ø | R16 | 330 | 001-0012 | | C17 | • | ØØ4-ØØ3Ø | R17 | 330 | ØØ1-ØØ12 | | C18 | - | ØØ4-ØØØ7 | R18 | 47 | ØØ1-ØØØ3 | | C19 | • | 004-0007 | R19 | 47 | ØØ1-ØØØ3 | | C20 | · · | ØØ4-ØØ32 | R2Ø | 22Ø | ØØ1-ØØ1Ø | | C2 | | 004-0027 | R21 | 1K | ØØ1-ØØ18 | | C22 | | 004-0032 | R22 | 1K | 001-0018 | | C2: | 3 | ØØ4-ØØ <b>Ø</b> 3 | R23 | 1K | 001-0018 | | C24 | 4 Ø.1Ø μF | ØØ4-ØØ3Ø | R24 | 1K | 001-0018 | | C2! | 5 Ø.1Ø μF | 004-0030 | RN1 | 4.7K DIP | 003-0017 | | C20 | 6 Ø.1Ø μF | 004-0030 | | (15 resistors) | • | | C2 | 7 Ø. <b>1Ø</b> μF | 004-0030 | RN2 | 4.7K DIP | ØØ3-ØØ17 | | C2 | 8 <b>6.80</b> μF | 004-0034 | | (15 resistors) | | | C2: | 9 <b>6.80</b> μF | 004-0034 | | | | | C3 | Ø <b>Ø.1</b> Ø μF | ØØ4-ØØ3Ø | | | <u> </u> | | C3 | | ØØ4-ØØ3Ø | " | C Sockets | Part No. | | C3 | 2 3ØØ.ØØ pF | ØØ4-ØØ15 | <del> </del> ` | 3 COOKOG | | | | Viscellaneous | Part No. | 2 | 40 pin sockets | Ø17-ØØØ6 | | <u> </u> | viiscellatieous | | 1 | 20 pin sockets | 017-0004 | | 1 Pr | inted circuit board | 020-0017 | 23 | 14 pin sockets | Ø16-ØØØ1 | | | pole DIP switch | 013-0003 | 21 | 16 pin sockets | Ø17-Ø002 | | | S-pin cable sockets | Ø17-ØØ22 | <u> </u> | | <u> </u> | | 1 | eatsink | 021-0017 | | /Tu | Part No. | | | 32 screws | 015-0000 | Diod | es/Transistors | Part No. | | ŧ | 31 nuts | Ø15-ØØ13 | | | 000 000 | | 8 2-56 screws | | 015-0003 | D1 | 1N4742 Zener | 008-0008 | | | 56 nuts | 015-0014 | D2 | 1N914 | 008-0002 | | | VIHZ crystal | Ø26-ØØØ1 | 01 | 2N39Ø6 | 009-0002 | | l l | J-ART Instruction | Ø23-Ø <b>Ø</b> 11 | Q2 | 2N39Ø6 | ØØ9-ØØØ2 | | M | anual | <u> </u> | ] | | | ## Parts List | Integrated Ci | ircuits | Part No. | Inte | egrate | d Circuits | Part No. | |-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | IC 1 74 IC 2 74 IC 3 74 IC 4 55 IC 5 55 IC 6 74 IC 7 74 IC 8 74 IC 9 75 | 42<br>367<br>368 | Part No. 010-0022 010-0080 010-0079 011-0005 011-0005 010-0080 010-0079 010-0062 010-0077 010-0028 | IC<br>IC | 25<br>26<br>27<br>28<br>29<br>30<br>31<br>32<br>33<br>34 | 74LS74<br>78Ø5<br>7812<br>749ØØ<br>74LØ4<br>74367<br>74367<br>74367<br>74367<br>74367 | Ø10-0055<br>Ø12-0001<br>Ø12-0002<br>Ø10-0083<br>Ø10-0074<br>Ø10-0080<br>Ø10-0080<br>Ø10-0080<br>Ø10-0080<br>Ø10-0069 | | IC 12 74 IC 13 74 IC 14 74 IC 15 74 IC 16 74 IC 17 74 IC 18 74 IC 19 74 IC 20 74 IC 21 74 IC 22 74 IC 23 74 | 5188<br>\$LS74<br>\$LS08<br>\$367<br>\$368<br>\$367<br>\$368<br>\$367<br>\$4367<br>\$4367<br>\$4267<br>\$4267<br>\$4267<br>\$4267<br>\$4267<br>\$4267 | Ø1Ø-ØØ76<br>Ø1Ø-ØØ55<br>Ø1Ø-ØØ64<br>Ø1Ø-ØØ8Ø<br>Ø1Ø-ØØ79<br>Ø1Ø-ØØ8Ø<br>Ø1Ø-ØØ8Ø<br>Ø1Ø-ØØ8Ø<br>Ø1Ø-ØØ8Ø<br>Ø1Ø-ØØ8Ø<br>Ø1Ø-ØØ64<br>Ø1Ø-ØØ64<br>Ø1Ø-ØØ64 | | 44<br>45<br>46<br>47 | 74LS157 74LSØ4 79Ø5 74Ø6 74LSØ4 74LSØ4 74LSØØ 74LSØ3 74LSØ3 74LSØ3 74LSØ3 74LSØ3 74LSØ3 | 010-0046<br>010-0066<br>012-0000<br>010-0028<br>010-0066<br>010-0055<br>010-0069<br>010-0067<br>010-0099<br>010-0074<br>010-0050<br>010-0050 | ## Parts Location Diagram ## LIMITED WARRANTY Cromemco, Inc. ("Cromemco") warrants this product against defects in material and workmanship to the original purchaser for ninety (90) days from the date of purchase, subject to the following terms and conditions. ## What Is Covered By This Warranty During the ninety (90) day warranty period Cromemoo will, at its option, repair or replace this Cromemoo product or repair or replace with new or used parts any parts or components, manufactured by Cromemoo, which prove to be defective, provided the product is returned to an Authorized Cromemoo Dealer as set forth below. ## **How To Obtain Warranty Service** In order to obtain warranty service, first obtain a return authorization number by contacting the Authorized Cromemco Dealer from whom you purchased the product. Then attach to the product: - 1. Your name, address and telephone number, - 2. the return authorization number, - 3. a description of the problem, and - 4. proof of the date of retail purchase. Ship or otherwise return the product, transportation and insurance costs prepaid, to the Authorized Cromemco Dealer. If you are unable to receive warranty repair from the Authorized Cromemco Dealer from whom you purchased the product, you should contact Cromemco Customer Support at: Cromemco, Inc., 280 Bernardo Ave., Mountain View, Ca. 94043. ## What Is Not Covered By This Warranty Cromemco does not warrant any products, components or parts not manufactured by Cromemco. This warranty does not apply if the product has been damaged by accident, abuse, misuse, modification or misapplication; by damage during shipment; or by improper service. This product is not warranted to operate satisfactorily with peripherals or products not manufactured by Cromemco. Transportation and insurance charges incurred in transporting the product to and from the Authorized Cromemco Dealer or Cromemco are not covered by this Warranty. THIS WARRANTY IS IN LIEU OF ALL OTHER WARRANTIES, WHETHER ORAL OR WRITTEN, EXPRESS OR IMPLIED. ANY IMPLIED WARRANTIES, INCLUDING IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE LIMITED IN DURATION TO NINETY (90) DAYS FROM THE DATE OF PURCHASE OF THIS PRODUCT. CROMEMCO SHALL NOT BE LIABLE FOR INCIDENTAL AND/OR CONSEQUENTIAL DAMAGES FOR THE BREACH OF ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING DAMAGE TO PROPERTY AND, TO THE EXTENT PERMITTED BY LAW, DAMAGES FOR PERSONAL INJURY, EVEN IF CROMEMCO HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOFTWARE, TECHNICAL INFORMATION AND FIRMWARE IS LICENSED "AS IS" AND WITH ALL FAULTS. THE AGENTS, DEALERS, AND EMPLOYEES OF CROMEMCO ARE NOT AUTHORIZED TO MAKE MODIFICATIONS TO THIS WARRANTY, OR ADDITIONAL WARRANTIES BINDING ON CROMEMCO ABOUT OR FOR PRODUCTS SOLD OR LICENSED BY CROMEMCO. ACCORDINGLY, ADDITIONAL STATEMENTS WHETHER ORAL OR WRITTEN EXCEPT SIGNED WRITTEN STATEMENTS FROM AN OFFICER OF CROMEMCO DO NOT CONSTITUTE WARRANTIES AND SHOULD NOT BE RELIED UPON. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES OR LIMITATIONS ON HOW LONG AN IMPLIED WARRANTY LASTS, SO THE ABOVE LIMITATION OR EXCLUSION MAY NOT APPLY TO YOU. THIS WARRANTY AND THE STATUTE OF LIMITATIONS SHALL RUN CONCURRENTLY WITH ANY ACCEPTANCE PERIOD. THIS WARRANTY IS NOT TRANSFERABLE. NO SUIT, LITIGATION, OR ACTION SHALL BE BROUGHT BASED ON THE ALLEGED BREACH OF THIS WARRANTY OR IMPLIED WARRANTIES MORE THAN ONE YEAR AFTER THE DATE OF PURCHASE IN THOSE JURISDICTIONS ALLOWING SUCH A LIMITATION, OTHERWISE NO SUCH ACTION SHALL BE BROUGHT MORE THAN ONE YEAR AFTER THE EXPIRATION OF THIS WARRANTY. This warranty shall not be applicable to the extent that any provision of this warranty is prohibited by any federal, state or municipal law which cannot be preempted. This warranty gives you specific legal rights, and you may also have other rights which vary from state to state.