DY-4 SYSTEMS INC +5V 900 m² 3 measurle +12 50 m² 30 ma ## DSTD-102 CPU AND SERIAL I/O **OPERATION MANUAL** #### NOTICE The proprietary information contained in this document must not be disclosed to others for any purpose, nor used for manufacturing purposes, without written permission of dy-4 SYSTEMS INC. The acceptance of this document will be construed as an acceptance of the foregoing condition. #### CHANGE NOTICE Revision 6 of the DSTD-102 contains several significant enhancements over revision 4 and earlier boards. These enhancements have been added following custommer requests to take advantage of recent technology developments. - 1. The DSTD-102 now supports 8 kbyte RAMs (Intel 2186) and 16 kbyte EPROMs. Note that the addition of this feature required the re-layout of the memory device jumper blocks JB9, JB10 and JB12. Refer to section 3.2 for a complete description. - 2. The memory decode PAL now supports six different memory configurations, including 2K, 4K, 8K and 16K configuations in the one PAL - 3. Using a jumper block the DSTD-102 will now support both "synchronous" edge triggered push button rest (available on rev 4 boards) and level sensitive resets (new). The level sensitive push button reset capability is required when using brown-out detection logic such as that on the DSTD 703. - 4. This rev allows full access to the on-board I/O devices from other cards in the system. This is particularly, useful when the DSTD-103 slave processor is being used. ## TABLE OF CONTENTS | 1.0 | SECTION 1 GENERAL INFORMATION | | |-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 1.1 | Introduction | 1 - 1 | | 1.2 | DSTD Series General Description | 1 - 1 | | 1.3 | DSTD-102 Features | 1 - 1 | | 2.0 | SECTION 2 FUNCTIONAL HARDWARE DESCRIPTION | | | 2.1 | Introduction | 2 - 1 | | 2.2 | Block Diagram Description | 2 - 1 | | | 2.2.1 CPU 2.2.2 Clock Generator 2.2.3 CTC (Counter/Circuit) 2.2.4 Memory 2.2.5 Decode Logic 2.2.6 Reset Control Logic 2.2.7 Wait State Generator 2.2.8 Serial Ports | 2 - 3 2 - 4 2 - 5 | | 3.0 | SECTION 3 USER-SELECTABLE OPTIONS | | | 3.1 | Introduction | 3 - 1 | | 3.2 | Debug/Single Step Configuration | 3 - 1 | | 3.3 | Memory Options | 3 - 1 | | | 3.3.1 Restart Address 3.3.2 Memory Configuration 3.3.3 On-board Memory Disable Latch | 3 - 1<br>3 - 2<br>3 - 6 | | 3.4 | WAIT State Generator | 3 - 6 | | 3.5 | Counter/Timer Options | 3 - 7 | | 3.6 | Serial Channel Options | 3 - 8 | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | | 3.6.1 Baud Rate Generator 3.6.2 DTE/DCE Configurations 3.6.2.1 DCE Configuration 3.6.2.2 DTE Configuration 3.6.3 Synchronous Operation | 3 - 8<br>3 - 9<br>3 - 9<br>3 - 10 | | 4.0 | SECTION 4 SPECIFICATIONS | | | 4.1 | Functional Specifications | 4 - 1 | | | 4.1.1 Word Size 4.1.2 Cycle Time 4.1.3 Memory Capacity 4.1.4 Memory Access Time 4.1.5 I/O Addressing 4.1.6 I/O Capacity 4.1.7 Interrupts 4.1.8 System Clock | 4 - 1<br>4 - 1<br>4 - 1<br>4 - 2<br>4 - 2<br>4 - 2 | | 4.2 | Electrical Specifications | 4 - 2 | | | <ul> <li>4.2.1 STD Bus Interface</li> <li>4.2.2 Serial Ports</li> <li>4.2.3 Operating Temperature</li> <li>4.2.4 Power Supply Requirements</li> </ul> | 4 - 2<br>4 - 3<br>4 - 3 | | 4.3 | Mechanical Specifications | 4 - 3 | | | 4.3.1 Card Dimensions 4.3.2 STD Bus Edge Connector 4.3.3 Serial Port Connector | 4 - 3<br>4 - 3<br>4 - 3 | | 5.0 | SECTION 5 FACTORY NOTICES | | | 5.1<br>5.2 | Factory Repair Service<br>Limited Warranty | 5 <b>-</b> 1 5 <b>-</b> 1 | | | APPENDICES | | | APPENDIX | A Option Programming Summary | | | APPENDIX | B STD-BUS Signals | | | APPENDIX | C Parts List | | | APPENDIX | D Schematic | | #### LIST OF FIGURES | F | IGURE | DESCRIPTION | PΑ | lG E | 2 | |------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------|-------------| | 1<br>2<br>C | - 1<br>- 1<br>- 1 | DSTD-102 Module<br>Functional Block Diagram<br>DSTD-102 Silk Screen | 1<br>2<br>C | - | 3<br>2<br>4 | | | | LIST OF TABLES | | | | | T | ABLE | DESCRIPTION | PA | GE | E | | 3<br>3<br>3<br>3 | - 1<br>- 2<br>- 3<br>- 4A<br>- 4B<br>- 5<br>- 6<br>- 7<br>- 8<br>- 9 | Memory Socket/Jumper Block Assignment Memory Socket Configuration Memory Address/Enable Options M1 Memory Cycle Wait States Timing 2.5Mhz M1 Memory Cycle Wait States Timing 4.0Mhz Wait State Options Baud Rate Generator Programming RS-232C DCE Jumper Configuration RS-232C DTE Jumper Configuration Synchronous DCE. DTE Jumper Configuration Serial Cable Connections | 3333333 | - | 5 | #### SECTION 1 #### 1.0 GENERAL INFORMATION #### 1.1 Introduction The dy-4 SYSTEMS' DSTD-102 CPU. Figure 1 - 1, is a Z80 based microcomputer board. It features a CPU chip, two serial communications channels, 4 counter/timers and three 28 pin memory sockets for byte-wide memory devices. #### 1.2 DSTD Series General Description The DSTD series was designed to satisfy the need for low cost OEM microcomputer modules. The DSTD-Z80 BUS uses a motherboard interconnect system concept. The modules for the STD-Z80 BUS are a compact 4.5 x 6.5 inches which provides for system partitioning by function, e.g. CPU, Memory, I/O, etc. This smaller module size makes system packaging easier, while increasing MOS-LSI densities provide high functionality per module. #### 1.3 DSTD-102 Features - . Utilizes the powerful Z80 microprocessor - Provides three 28 pin sockets which may be strapped to accept any combination of the following industry standard memory devices. | EPROM | | STAT | IC RAM | ROM | | | | |-------|-------------------|------|--------|---------|--------|--|--| | | (1kx8)<br>(1kx8) | 4118 | (1kx8) | | | | | | 2716 | (2kx8)<br>(4kx8) | 4802 | (2kx8) | MK34000 | (2kx8) | | | | 2764 | (8kx8)<br>(16kx8) | 2186 | (8kx8) | | | | | - . Four cascadable counter/timer channels - 2 serial RS-232C channels Channel A has two additional RS-232C drivers and receivers for external clocking allowing full synchronous operation. - . Transmit and Receive LEDs on Channel A - . Fully buffered signals for system expandability - . Selectable reset address to either 0000H or E000H - All on-board memory can be disabled and enabled under software control - Selectable WAIT state generator for memory devices on all M1 cycles, MEMRQ cycles or all INTAK cycles - Compatible with MDX-SST for single step operation during debugging - . 4MHz version available - . STD-Z80 bus compatible FIGURE 1 - 1 DSTD-102 MODULE #### SECTION 2 #### 2.0 FUNCTIONAL HARDWARE DESCRIPTION #### 2.1 Introduction The DSTD-102 utilizes a Z80 microprocessor as the system controller. It features three 28 pin memory sockets which enables the user to populate the module with any combination of designated ROM and EPROM. Custom address decoding allows the user to configure the memory on any 8K boundary of the 64K memory map. A PAL decoder is supplied to allow the user to choose one of six popular memory configurations, or if desired the user may implement other mixtures of memory devices simply by programming the PAL accordingly. A 4 channel counter/timer circuit is included for software controlled counting and timing functions. On-board strapping options make it possible to cascade the four CTC channels for long count sequences. The CTC may also be used as a baud rate generator for the serial channels if non-standard baud rates are required. The DSTD-102 has two serial channels implemented using the Z80-SIO LSI chip. The SIO allows for both asynchronous and synchronous (SDLC, HDLC, BISYNC, etc.) modes. Channel A can be used as both asynchronous and synchronous modes and channel B provides asynchronous operation. (Synchronous operation is available on the DSTD-102A version of the board - not the standard DSTD-102.) Channel A has additional RS-232C drivers and receivers for external clocks. In asynchronous mode both channels will operate up to 19.2k baud using the baud rate generator. The CTC may be used for higher rates. Channel A will run to 307 kilobaud in synchronous mode. A strapping option allows the user to select the reset address to be either 0000H or E000H. The E000H option is required for use of standard software and hardware products including dy-4 SYSTEMS Debug Monitor (DDM) and Disk Control Monitor (DCM) firmware products. Also these products require onboard RAM strapped to reside at location FC00H to FFFFH. The DSTD-102 is available in 2.5 MHz and 4 Mhz versions. #### 2.2 Block Diagram Description Figure 2 - 1 is a block diagram illustrating the flow of system address, data and control signals on the DSTD-102. The following paragraphs describe the function of each of the major blocks. 2 - 2 #### 2.2.1 CPU The Z80 is the system controller. It fetches, decodes and executes instructions from memory and generates the necessary address and control signals to co-ordinate data flow between the CPU and memory or between the CPU and system I/O devices. #### 2.2.2 Clock Generator The DSTD-102 has a crystal controlled oscillator to generate the basic clock signals for the CPU and peripheral chips. A divide-by-two circuit ensures a 50% duty cycle and an active pullup circuit ensures proper clock levels. An inverted clock is supplied to the bus for use by other modules. #### 2.2.3 CTC (Counter/Circuit) The Counter/Timer Circuit (MK3882/Z80-CTC) provides four independent, programmable channels for either software or hardware controlled counting and timing functions. Each channel can be configured by the CPU for various modes of operation and the built-in daisy chain priority interrupt logic provides for automatic, independent interrupt vectoring. The I/O port addresses for the CTC are hard-wired as follows: | I/O PORT ADDRESS | CTC CHANNEL | |------------------|-------------| | 7C | 0 | | <b>7</b> D | 1 | | 7E | 2 | | <b>7</b> F | 3 | A strapping option has also been included to permit any or all of the four CTC channels to be cascaded for long count sequences. Section 3 provides the necessary information for utilizing this option. For a complete description of the CTC operation, refer to either the Mostek MK3882 or Zilog Z80-CTC Technical Manual or Appendix A-15 of this manual. #### 2.2.4 Memory The DSTD-102 has been designed to accommodate any combination of the byte-wide RAM, ROM and EPROM devices. Three 28-pin sockets have been provided, each of which may be strapped for any of the allowable memory types. These user-selectable options are fully described in Section 3. #### 2.2.5 Decode Logic This section consists primarily of a PAL which decodes the high order six bits of memory address and generates the applicable chip select if on-board memory is to be selected. The PAL provides six separate memory configurations. The memory configurations are selected using an option jumper block as explained in Section 3. The DSTD-102 has a latch to disable all on-board memory under software control. On power-up and reset, the latch is preset enabling the on board memory. On-board memory is disabled by writing a '1' to I/O port 07BH. The on-board memory can be re-enabled by writing a '0' to port 07BH. #### 2.2.6 Reset Control Logic This is a strapping option that causes a hardware-forced memory starting address upon system reset. A reset address of either 0000H or E000H may be selected. This logic is required for use of standard MOSTEK hardware and software products including DDT-80, FLP-80DOS/MDX, MDX-SST, and MDX-DEBUG and dy-4 Debug Monitor (DDM) and CP/M software. Also the push button reset function may be edge triggered or level sensitive depending on jumper block JB15. The edge triggered reset is synchronised with M1 to ensure that the contents of any dynamic RAM in the system are preserved during the reset process. The level sensitive option is required when it is necessary to hold the processor in a reset state indefinitely such as in a 'brown-out' situation. #### 2.2.7 Wait State Generator This function, if enabled, causes memory read and write cycles to be lengthened by one clock period in order to allow sufficient access time when slower memory devices are used. Wait states can be enabled selectively, namely, - all memory cycles or opcode fetch cycles only or all memory cycles accessing on-board memory devices or all opcode fetch cycles and all memory cycles accessing onboard memory. An additional wait state may also be inserted during INTAK cycles. #### 2.2.8 Serial Ports The DSTD-102 has two RS-232C serial ports implemented using the Z80-SIO/MK3884. Each port has a software programmable baud rate generator. The baud rate is set by writing to port 7AH. The least significant 4 bits set the baud rate for Channel A and the most significant 4 bits are for Channel B. Both Channels will operate from 50 baud to 19.2K baud. In addition the CTC may be used to generate the receive and transmit data clocks of Channel A allowing for non-standard baud rates. The CTC can only be used for asynchronous modes because it does not generate a 50% duty cycle clock. Channel A also has additional RS-232C drivers and receivers to enable it to handle external clocks for full synchronous operation (SDLC, HDLC, BYSYNC, MONOSYNC etc.). #### SECTION 3 #### 3.0 USER-SELECTABLE OPTIONS #### 3.1 Introduction The DSTD-102 incorporates many strapping options to provide the user with a high degree of flexibility in system configurations. This section describes the use of the available jumper options. #### 3.2 Debug/Single Step Configurations The DSTD-102 supports the MDX-SST module. This module generates a NMI (non-maskable interrupt) and asserts the DEBUG signal. This debug signal when enabled forces a logic '1' onto the most significant three bits of the address bus. Thus the interrupt service routine is located at E066H. If the debug is disabled the interrupt service routine is at the normal address (0066H). To enable the debug line, install a jumper between JB8-2 and JB8-3 and between JB13-4A to JB13-4B. Ensure that the memory option strap position the monitor software at E000H. dy-4 SYSTEMS' DDM firmware supports the single step facilities. #### 3.3 Memory Options The PAL memory decoder shipped with DSTD-102 from the factory supports the options discussed in the following sections. #### 3.3.1 Restart Address The DSTD-102 is capable of starting execution at either 0000H or. E000H after reset. Reset address E000H is implemented in hardware. Since the program counter (internal to the Z80 microprocessor) always resets to 0000H, external hardware is required to force the most significant three bits of the data bus to all ones to get OEOOOH. A multiplexer and a latch to control the multiplexer are used to perform this function. The first instruction at E000H should be 'JMP E003' to set the processors internal program counter to the correct memory location. The hardware latch forcing the address bit must then be cleared. This is done automatically by the first I/O cycle that the processor performs. If no I/O port access is normally made then a dummy I/O read of an unused port address must be done otherwise memory accessed will be constrained to addresses E000H through FFFFH. To ensure proper operation after reset, the following code sequence should be placed in memory at the E000H. | E000 | C3 03 E0 | JP EOO3H | <pre>; jump instruction<br/>; to update program<br/>counter</pre> | |------|----------|-----------|----------------------------------------------------------------------| | E003 | DB nn | IN A,(nn) | <pre>; read unused I/O ; port nn to clear ; resetaddress latch</pre> | | E005 | | | ; first instruction ; of user program | When using standard dy-4 SYSTEMS' or Mostek software (including DDM, DCM, DDT-80, FLP-80, DOS/MDX or MDX-DEBUG), the reset address must be E000H. The program counter and address latch modification instructions previously described are already contained with the DDM ROM. Ensure that pins 2 and 3 of JB8 are connected when the MDX-SST module is used. #### 3.3.2 Memory Configuration The DSTD-102 incorporates three 28 pin sockets which can be independently configured to accept a variety of pin compatible memory devices. Table 3 - 1 lists each socket, its corresponding jumper block, and its address space for the standard configurations. The memory decoding is done using a PAL device. Table 3 - 2 shows for reference the signals brought to the jumper block for each of the different memory types. Table 3 - 3 illustrates the necessary jumper connections for configuring a socket to accept each memory device. Consult the factory for PAL programming details for non-standard requirements. Option numbers are binary coded using JB14. JB14, 1A-1B has a weighting of '1'; JB14, 2A-2B has a weighting of '2' and JB14, 3A-3B has a weighting of '4'. For example, if option 5 (101) is desired JB14, 1A-1B, 3A-3B are left open and JB14, 2A-2B are inserted. TABLE 3 - 1 MEMORY SOCKET/JUMPER BLOCK ASSIGNMENT | MEM TYPE | OPTION | MEM RANGE | U20(JB11) | U19(JB10) | U18(JB9) | |-----------------------------------|----------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------| | 2K<br>2K<br>4K<br>4K<br>8K<br>16K | 7(111)<br>6(110)<br>5(101)<br>4(100)<br>2(010)<br>0(000) | E000-FFFF<br>0000-1FFF<br>E000-FFFF<br>0000-3FFF<br>0000-7FFF | E000-E7FF<br>0000-07FF<br>E000-EFFF<br>0000-0FFF<br>0000-1FFF<br>0000-3FFF | E800-EFFF<br>0800-0FFF<br>F000-FBFF<br>1000-1FFF<br>2000-3FFF<br>4000-7FFF | F000-FFFF<br>1000-1FFF-<br>FC00-FFFF<br>2000-3FFF-<br>4000-7FFF<br>8000-BFFF | NOTE: For 2K, 4K and 8K devices the memory range for U18 is twice as large as for U19 and U20. Hence when using the same memory device sizes for all three sockets, memory expansion off board will not be contiguous. Option 5 is the memory configuration used for the boot proms and monitor in dy-4's STD Bus based microcomputer development systems. TABLE 3 - 2 MEMORY DEVICE JUMPER STRAPS | TY | PE | PART NO. | | P. | INS | | | |---------|-------|----------|-----|-------|-------|-----|-----------------------| | | | | 27 | 26 | 23 | 21 | 1 | | 1K x 8 | EPROM | 2758 | - | Vcc | Vpp | GND | - | | 1K x 8 | EPROM | 2759 | - | Vcc | Vpp | Vcc | - | | 2K x 8 | EPROM | 2716 | - | Vcc | Vpp | A10 | - | | 4K x 8 | EPROM | 2732 | - | Vcc | A11 | A10 | - | | 8K x 8 | EPROM | 2764 | PGM | n/c | A11 | A10 | Vpp | | 16K x 8 | EPROM | 27128 | PGM | A13 | A11 | A10 | Vpp | | 1K x 8 | RAM | 4801 | - | Vcc | /WE | GND | • | | 2K x 8 | RAM | 4802 | - | Vcc | /WE | A10 | - , | | 8K x 8 | RAM | 2186 | /WE | n/c 🗴 | A11 / | A10 | $\mathtt{RDY} \times$ | | 2K x 8 | EEROM | X2816A | - | Vcc | /WE | A10 | - | TABLE 3 - 3 MEMORY DEVICE JUMPER STRAPS | T | YPE | PART NO. | | | BLOCKS<br>nd JB12 | | | R BLOCK<br>B10 | |--------|-------|----------|-------------------------|---|-------------------|-------------------------|---|----------------| | 1K x 8 | EPROM | 2758 | B2-A6<br>B3-B4 | | A5-A6 | A2-B4<br>C1-C2 | | B3-B4 | | 1Kx8 | EPROM | | B2-A6<br>B3-B2 | | | A2-B4<br>C1-B3 | | B3-B4 | | 2K x 8 | EPROM | | B2-A6<br>B3-A3 | | A5-A6 | A2-B4<br>B1-C1 | | B3-B4 | | 4Kx8 | EPROM | | B2-A6<br>B3-A3 | | A4-A5 | A2-B4<br>B1-C1 | | B3-B2 | | 8K x 8 | EPROM | 2764 | B1-B5<br>B3-A3 | ; | A4-A5<br>A1-A6 | A3-C3<br>B1-C1 | ; | B2-B3<br>A4-B4 | | 16Kx8 | EPROM | | B1-B5<br>B3-A3<br>B2-B6 | ; | A4-A5<br>A1-A6 | A3-C3<br>B1-C1<br>C4-A2 | ; | B2-B3<br>A4-B4 | | 1K x 8 | RAM · | | B2-A6<br>B3-A6 | | | A2-B4<br>C1-C2 | | B3-C3 | | 2K x 8 | RAM | 4802 | B2-A6<br>B3-A3 | ; | A5-B5 | A2-B4<br>B1-C1 | | B3-C3 | | 8K x 8 | RAM | 2186 | | | A4-A5<br>A1-A2 | A3-C3<br>B1-C1 | ; | B2-B3<br>A1-A4 | | 2K x 8 | EEROM | X2816A | B2-A6<br>B3-A3 | | A5-B5 | A2-B4<br>B1-C1 | ; | B3-C3 | #### 3.3.3 On-board Memory Disable Latch All on-board memory can be enabled and disabled under software control. To use this feature jumper JB14 4A-4B is installed. This jumper allows the memory disable latch to be used. The latch is located at address 7BH. Writing a '0' to this latch enables on-board memory. Writing a '1' to the latch disables on-board memory. A power-up or RESET clears the latch thus enabling on-board memory. #### 3.4 WAIT State Generator Three jumpers are provided to allow the use of slow memory devices. The first jumper generates a WAIT state on all memory cycles. The second jumper generates a WAIT state for M1 memory cycles only. Table 3 - 4 lists the access times of memory devices internal and external to the card for the two different memory cycle types for both the 2.5 MHz and 4.0 MHz DSTD 102 cards. The third jumper generates a WAIT state on internal memory accesses only. This means that slower EPROMS can be used on the DSTD-102 along with a high speed RAM card. A fourth jumper allows the generation of a WAIT state on interrupt acknowledge cycles. Table 3 - 5 gives the connections for the WAIT state options. TABLE 3 - 4A M1-MEMORY CYCLE WAIT STATES TIMING 2.5MHz | | JB11 | INTERNAL | EXTERNAL | | | |----------------------------------|-------------|------------------|-----------|--|--| | FUNCTION | Connections | M1 Other | M1 Other | | | | No WAIT states | | 580 780 | 550 750 | | | | WAIT states on M1 cycles | 1A to 1B | 620 780 | 950 750 | | | | WAIT states on all memory cycles | 3A to 3B | 620 1180 950 115 | | | | | | | (in nan | oseconds) | | | TABLE 3 - 4B M1-MEMORY CYCLE WAIT STATES TIMING 4.0MHZ | | JB11 | INT | ERNAL | EXT | ERNAL | |----------------------------------|-------------|-----|---------|-------|-------| | FUNCTION | Connections | M 1 | Other | M 1 | Other | | No WAIT states | | 330 | 455 | 300 | 425 | | WAIT states on M1 cycle | 1A to 1B | 590 | 455 | 560 | 425 | | WAIT states on all memory cycles | 3A to 3B | 590 | 705 | 560 | 675 | | | | (: | in nano | secon | ds) | #### TABLE 3 - 5 WAIT STATE OPTIONS | OPTION | • | JB1 | 1 | |-----------------------------------------------|-----|----------|-------| | No WAIT states | No | Jui | npers | | All M1 cycles | 1 A | to | 1B | | All Memory cycles | ЗА | to | 3B | | Internal Memory cycles only | 4A | to | 4B | | Internal Memory cycles and external M1 cycles | | to<br>to | | | Interrupt acknowledge cycle | 2A | to | 2B | #### 3.5 Counter/Timer Options The four Counter/Timer channels may be cascaded for extended counting and timer functions. Appendix A-6 shows the jumper pin numbers for the CTC. Refer to the MK3882 Technical Manual or the Zilog Data Book for a complete description of the CTC operation. Provision is made on the Counter/Timer option block to enable the NMI input of the processor to be connected to one of the outputs of the CTC. NMI is pin 5A of JB5. In addition the CTC can be used as a baud rate generator for the serial channels to create non-standard baud rates. Two commonly unused pins on the STD bus (MEMEX and IOEXP) may be connected through JB13 and buffers to the CTC. One pin is used as an input (IOEXP) and the other is used as an output (MEMEX). #### 3.6 Serial Channel Options #### 3.6.1 Baud Rate Generator The DSTD-102 has a dual software-programmable baud rate generator. It is accessed through I/O port 7AH. This port is a write-only port. Bits 0 to 3 control channel A and bits 4 to 7 control channel B. Table 3-7 shows the programming information for the baud rate generator. Table 3 - 6 Baud Rate Generator Programming | BAUD RATE | D3/D7 | D2/D6 | D1/D5 | DO/D4 | (HEX) | |-----------|-------|-------|-------|-------|-------| | 19,200 | 1 | 1 | 1 | 1 | F | | 9,600 | 1 | 1 | 1 | . 0 | Ε | | 7,200 | 1 | 1 | 0 | 1 | D | | 4,800 | 1 | 1 | 0 | 0 | С | | 3,600 | 1 | 0 | 1 | 1 | В | | 2,400 | 1 | 0 | 1 | 0 | A | | 2,000 | 1 | 0 | 0 | 1 | 9 | | 1,800 | 1 | 0 | 0 | 0 | 8 | | 1,200 | 0 | 1 | 1 | 1 | 7 | | 600 | 0 | 1 | 1 | 0 | 6 | | 300 | 0 | 1 | 0 | 1 | 5 | | 150 | 0 | 1 | 0 | 0 | 4 | | 134.5 | 0 | 0 | 1 | 1 | 3 | | 110 | Ö | 0 | 1 | 0 | 2 | | 75 | Ō | Ö | 0 | 1 | 1 | | 50 | Ö | Ō | 0 | 0 | 0 | Thus to set port A to 9600 baud and port B to 1200 baud output a 7EH to I/O address 7AH. #### 3.6.2 DTE/DCE Configurations #### 3.6.2.1 DCE Configuration When connecting to a CRT, printer or similar equipment the serial port is wired as Data Comunications Equipment. The signal names indicate control and data flow with respect to the CRT. Table 3 - 7 itemizes the jumper configurations for this mode of operation. TABLE 3 - 7 RS-232C DCE Jumper Configuration | EIA(DCE)<br>Signal Name | SIO<br>Function | | lled<br>,JB | l Jumpers | J2/J<br>Pin Num | | | |--------------------------------------------------------|----------------------------------------------|----------------------------|----------------------------|----------------------------------------|---------------------------------|------|-------| | TX (2) RX (3) RTS (4) CTS (5) DTR (20) DCD (8) DSR (6) | RX<br>TX<br>CTS<br>RTS<br>DCD<br>DTR<br>+12V | 1A<br>4A<br>5B<br>7A<br>6A | to<br>to<br>to<br>to<br>to | 1B<br>2A<br>5A<br>4B<br>6B<br>7B<br>8B | 2<br>3<br>4<br>5<br>9<br>8<br>6 | (JB3 | only) | #### 3.6.2.2 DTE Configuration When connecting to a MODEM or similar equipment the serial port is wired as Data Terminal Equipment. The signal names indicate control and data flow with respect to the DSTD-102. Table 3 - 8 itemizes the jumper configuration for the mode of operation. TABLE 3 - 8 RS-232C DTE Jumper Configuration | EIA(DTE) | SIO | Installed Jumpers | J2/J3 | |--------------------------------------------------------|-----------------------|----------------------------------------------------------------------|----------------------------| | Signal Name | Function | JB3,JB4 | Pin Numbers | | TX (2) RX (3) RTS (4) CTS (5) DTR (20) DCD (8) DSR (6) | TX RX RTS CTS DTR DCD | 1A to 1B<br>2B to 2A<br>3A to 3B<br>4A to 4B<br>6A to 6B<br>7A to 7B | 2<br>3<br>4<br>5<br>9<br>8 | #### 3.6.3 Synchronous Operation The DSTD-102A allows synchronous operation on Channel A. That is, additional RS-232C drivers and receivers are provided for interfacing external clocks. Two configurations are possible. - i) The DCE provides both transmit and receive timing information. When the DSTD-102A is the DCE, two RS-232C drivers are required. When the DSTD-102A is the DTE two RS-232C receivers are required. - ii) The DCE provides the transmit timing information and the DTE provides the receive timing information. The DSTD-102A provides the receive timing information. The DSTD-102 uses both the RS-232C driver and the RS-232C receiver. Table 3 - 9 shows the jumpering required for each configuration. Note that the same drivers used for the external clocks are also used to drive the on-board TX and RX LED's. When these drivers are to be used for external clocking the LED's should be disconnected. TABLE 3 - 9 DCE provides both clocks. DSTD-102A is the DCE | | | JB2 | JB3 | J2 | EIA | |----|-------|--------------------|-----------|----|-----| | TX | Clock | 2A - 2B<br>1A - 2A | 9A - 9B | 10 | 15 | | RX | Clock | 3A - 4A<br>4A - 4B | 11A - 11B | 11 | 17 | DCE provides both clocks. DSTD-102A is the DTE | • | | | | | |----------|---------------------------|-----------|----------|-----| | | JB2 | JB3 | J2 | EIA | | TX Clock | 1A - 1B | 8A - 8B | 10 | 15 | | RX Clock | 3A - 3B | 10A - 10B | 11 | 17 | | | the transmit DSTD-102A is | _ | provides | the | | | JB2 | JB3 | J2 | EIA | | TX Clock | 1A - 2A | 9A - 9B | 10 | 24 | | RX Clock | 2A - 2B<br>3A - 3B | 10A - 10B | 11 | 17 | DTE provides the transmit clock, DCE provides the receive clock. DSTD-102A is DTE. | | JB2 | JB3 | J2 | EIA | |----------|--------------------|-----------|----|-----| | RX Clock | 1A - 1B | 8A - 8B | 10 | 24 | | TX Clock | 2A - 3A<br>4A - 4B | 11A - 11B | 11 | 17 | Note that the clock names given above refer to data flow with respect to the DTE. EIA refers to the DB25 pin numbers assigned to these signals by the EIA RS-232C specifications. Table 3-10 shows the cable connections to a standard RS-232C DB25S connector. Typically the cable is the same for both DCE and DTE systems with the configuration being determined by the onbased jumpers. TABLE 3-10 SERIAL CABLE CONNECTIONS | J2/J3 | RS232C/DB25S | EIA CIRCUIT | |-------|----------------|-------------| | 1 | 1 | AA | | 2 | 2 | BA | | 3 | <sup>1</sup> 3 | BB | | 4 | 4 | CA | | 5 | 5 | СВ | | 6 | 6 | CC | | 7 | 7 | AB | | 8 | 8 | CF | | 9 | 20 | CD | | 10 | 15 | DB | | 11 | 17 | DD | | 12 | 19 | | NOTE: Pin 12 (DB25S pin 19) is included to accomodate some printers that use pin 19 for flow control. DSTD-102 SPECIFICATIONS #### SECTION 4 #### 4.0 **SPECIFICATIONS** #### 4.1 Functional Specifications 4.1.1 Word Size Instructions: 8, 16, 24, or 32 bits Data: 8 bits 4.1.2 Cycle Time Clock period (T state): 400 ns for DSTD-102-2.5 250 ns for DSTD-102-4.0 Instruction Cycle: Min. 4 T states Max. 23 T states #### Memory Capacity 4.1.3 Three 28 pin sockets are provided which may be populated with any mixture of the following devices: > 2758 (1K x 8 EPROM) 2759 (1K x 8 EPROM) 2716 (2K x 8 EPROM) 2732 (4K x 8 EPROM) 2764 (8K x 8 EPROM) 27128(16Kx 8 EPROM) MK 34000 (2K x 8 EPROM) 4118 (1K x 8 Static RAM) 4801 (1K x 8 Static RAM) 4802 (2K x 8 Static RAM) 2186 (8K X 8 Pseudo Static RAM) X2816 (2K x 8 EEROM #### 4.1.4 Memory Access Time The time required to access on-board memory by external DMA controllers is 100 ns plus the access time of the memory device. This is defined as the time interval between the time that the memory address is valid on the STD-BUS and the time that the output data is valid on the STD-BUS. #### 4.1.5 I/O Addressing The on-board I/O addressing is hard wired to the following port addresses: | | | PORT | | | ADDRESS | |------|------------------------------|----------------|------------------|---------------------------|----------------------| | | | RATE G | | | 7A<br>7B | | 8430 | CTC<br>CTC<br>CTC | CH<br>CH<br>CH | 0<br>1<br>2<br>3 | | 7C<br>7D<br>7E<br>7F | | 8440 | \$10<br>\$10<br>\$10<br>\$10 | CH<br>CH<br>CH | A<br>A<br>B | DATA CONTROL DATA CONTROL | BC<br>BD<br>BE<br>BF | #### 4.1.6 I/O Capacity The Z80 CPU utilizes the lower 8 bits of its address bus for I/O addressing to yield a total of 256 possible port addresses. #### 4.1.7 Interrupts The CPU may be programmed to process interrupts in any of three different modes (mode 0, 1, or 2 as described in any Z80 Technical Manual). Mode 2 operation (vectored interrupts) is by far the most powerful and is compatible with dy-4 DSTD and MOSTEK MDX Series cards. Multi-level interrupt processing is also possible with the Z80 CPU. The level of stacking is limited only by available memory space. The DSTD-102 will also accept non-maskable interrupts which force a restart at location 0066H. | 4.1.8 | System Clock | | |-------|--------------|-----------------------| | | DSTD-102-2.5 | 2.5MHz <u>+</u> 0.05% | | | DSTD-102-4.0 | 4.0MHz <u>+</u> 0.05% | #### 4.2 Electrical Specification SPECIFICATIONS DSTD-102 4.2.1 STD Bus Interface > Bus Inputs: One 74LS load max. $I_{OL}$ = 24 mA min. @ $V_{OL}$ = 0.5 Volts $I_{OH}$ = 15 mA min. @ $V_{OH}$ = 2.4 Volts Bus Outputs: 4.2.2 Serial Ports > Inputs: One 74LS load max. +/- 12V Current Limited to 10mA Outputs: 4.2.3 Operating Temperature > O Degrees C to 50 Degrees C 95% humidity non-condensing 4.2.4 Power Supply Requirements +5V +/- 5% @ 1.2A +12V +/- 5% @ 0.1A -12V +/- 5% @ 0.1A (excluding memory power requirements) - 4.3 Mechanical Specifications - 4.3.1 Card Dimensions 4.50 in. (11.43 cm.) wide by 6.50 in. (16.51 cm) long 0.48 in. (1.22 cm.) maximum height 0.062 in. (0.16 cm.) printed circuit board thickness 4.3.2 STD Bus Edge Connector 56 pin Dual Readout; 0.125 in. centers Mating Connector Viking 3VH28/1CE5 (printed circuit) Viking 3VH28/1CND5 (wire wrap) Viking 3VH28/1CN5 (solder lug) SPECIFICATIONS DSTD-102 4.3.3 Serial Port Connector 12 Pin Dual Readout; 0.100 inch grid Mating Connector Amp 87631-8 (housing) Amp 86016-2 (contact) or equivalent SPECIFICATIONS DSTD-102 #### SECTION 5 #### 5.0 FACTORY NOTICES #### 5.1 Factory Repair Service In the event that difficulty is encountered with this unit, it may be returned directly to dy-4 for repair. This service will be provided free of charge if the unit is returned within the warranty period. However, units which have been modified or abused in any way will not be accepted for service, or will be repaired at the owner's expense. When returning a circuit board, place it inside the conductive plastic bag in which it was delivered to protect the MOS devices from electrostatic discharge. THE CIRCUIT BOARD MUST NEVER BE PLACED IN CONTACT WITH STYROFOAM MATERIAL. Enclose a letter containing the following information with the returned circuit board: Name, address and phone number of purchaser Date and place of purchase Brief description of the difficulty Mail a copy of this letter SEPARATELY to: Service Department dy-4 SYSTEMS INC., 888 Lady Ellen Place, or Ottawa, Ontario K1Z 5M1, Canada Service Department dy-4 SYSTEMS INC., 3582 Dubarry Rd. Indianapolis, IN 46226 Securely package and mail the circuit board, prepaid and insured, to the same address. #### 5.2 Limited Warranty dy-4 warrants this product against defective materials and workmanship for a period of 90 days. This warranty does not apply to any product that has been subjected to misuse, accident, improper installation, improper application, or improper operation, nor does it apply to any product that has been repaired or altered by other than an authorized factory representative. There are no warranties which extend beyond those herein specifically given. #### NOTICE The antistatic bag is provided for shipment of the dy-4 PC boards to prevent damage to the components due to electrostatic discharge. Failure to use this bag in shipment will **VOID** the warranty. # APPENDIX A OPTION PROGRAMMING SUMMARY #### APPENDIX A #### OPTION PROGRAMMING SUMMARY #### - 1 OPTIONAL JUMPER BLOCKS The following is a list of the option Jumper Blocks on the STD-102 card. | JB1 | LED connection | |------|----------------------------------------------| | JB2 | Serial Channel A Clock TTL Side | | JB3 | Serial Channel A DTE/DCE Configuration Block | | JB4 | Serial Channel B DTE/DCE Configuration Block | | JB5 | Counter Timer Jumper Block | | JB6 | LED Transmit | | JB7 | LED Receive | | JB8 | Restart Address Jumper Block | | JB9 | Memory Socket Configuration Block for U18 | | JB10 | Memory Socket Configuration Block for U19 | | JB11 | WAIT State Generator options | | JB12 | Memory Socket Configuration Block of U20 | | JB13 | CTC/Bus Interface Jumper Block | | JB14 | On-board Memory Options | | JB15 | Reset Mode | | _ | | #### A - 2 LED Connections (JB1) These jumpers are installed to drive the LED's. Note the jumpers should not be installed if Serial Channel A is used in synchronous mode and is supplying the clocks to external equipment. | | India | ates Factory | Default | |----------|-------|--------------|---------| | Driver 2 | 2 | 00 | LED 2 | | Driver 1 | 1 | 00 | LED 1 | | | | A B | | ## A - 3 Serial Channel A Clock Jumpers TTL Side (JB2) This jumper block allows the selection of the Transmit and receive clocks for Channel ${\tt A.}$ | A | В | |---|---| | | | | Transmit Clock (input) | 1 | 0 | 0 | RS232 Clock Receiver 1 | |------------------------------|---|---|---|---------------------------| | Internal Baud Rate Generator | 2 | Ó | 0 | RS232 Clock Transmitter 1 | | Receiver Clock (input) | 3 | 0 | 0 | RS232 Clock Receiver 2 | | Internal Baud Rate Generator | 4 | 0 | 0 | RS232 Clock Transmitter 2 | | Receiver Clock (input) | 5 | 0 | 0 | CTC output | | Transmit Clock (input) | 6 | 0 | 0 | CTC output | ### A - 4 Channel A DTE/DCE Configuration Block (JB3) These jumpers allow the board to be configured as Data Terminal Equipment or Data Communications Equipment when used with a standard dy-4 SYSTEMS Cable. The signals given are those of the SIO device which is labelled as Data Terminal Equipment. | | | A | В | | |---------------------------|----|----|----|-----------------------| | Transmit Data | 1 | 0 | 0 | Connector J2 Pin 2 | | Connector J2 Pin 3 | 2 | 0 | 0 | Received Data | | Request to Sent (RTS) | 3 | 0 | 0 | Connector J2 Pin 4 | | Clear to Send (CTS) | 4 | 0 | 0 | Connector J2 Pin 5 | | Connector J2 Pin 4 | 5 | ٥ | 0 | Request to Send (RTS) | | Data Terminal Ready (DTR) | 6 | 0 | 0 | Connector J2 Pin 9 | | Data Carrier Detect (DCD) | 7 | 0 | 0 | Connector J2 Pin 8 | | RS-232C Receiver 1 | 8 | 0 | 0 | Connector J2 Pin 10 | | RS-232C Transmit 1 | 9 | 0 | 0 | Connector J2 Pin 10 | | RS-232C Receiver 2 | 10 | 0 | 0 | Connector J2 Pin 11 | | RS-232C Transmit 2 | 11 | 0 | 0 | Connector J2 Pin 11 | | +12 through 3k ohms | 12 | 0- | -0 | Connector J2 Pin 6 | #### A - 5 Channel B DTE/DCE Configuration Block (JB4) This jumper block allows the channel to be configured as Data Terminal Equipment or Data Communications Equipment. | | | A B | | |---------------------------|---|-----|-----------------------| | Transmit Data | 1 | 0 0 | Connector J2 Pin 2 | | Connector J2 Pin 3 | 2 | 0 0 | Received Data | | Request to Sent (RTS) | 3 | 0 0 | Connector J2 Pin 4 | | Clear to Send (CTS) | 4 | 0 0 | Connector J2 Pin 5 | | Connector J2 Pin 4 | 5 | 0 | Request to Send (RTS) | | Data Terminal Ready (DTR) | 6 | 0 0 | Connector J2 Pin 9 | | Data Carrier Detect (DCD) | 7 | 00 | Connector J2 Pin 8 | | +12 through 3k ohms | 8 | 00 | Connector J2 Pin 6 | ## A - 6 Counter Timer Jumper Block (JB5) This jumper block allows the counter/timer channels to be cascaded for longer sequences. It also provides access to the auxiliary input and output buffers which are connected through JB12 to MEMEX and IOEXP bus signals. The SIO clock is used when the CRT is used as a baud rate generator. | | | A | В | | |---------------------------------|---|---|---|---------------------------| | Auxiliary Input | 1 | 0 | 0 | SIO Clock | | CTC Channel O input | 2 | 0 | 0 | CTC Channel O zero detect | | CTC Channel 1 Zero detect | 3 | 0 | 0 | CTC Channel l input | | CTC Channel 2 input | 4 | 0 | 0 | CTC Channel 2 zero detect | | Internal Non-Maskable Interrupt | 5 | 0 | 0 | Auxiliary Output | | CTC Channel 3 input | 6 | 0 | 0 | N/C | #### A - 7 JB6/7 LED Blocks These jumpers are installed to drive the LEDs. They should be removed when Channel A is operated in Synchronous mode. | | | A | В | | | | | |----|--------|---|----|-----|--------|-----------|-------| | TX | Driver | 0 | -0 | LED | Driver | <b>U7</b> | (JB6) | | RX | Driver | 0 | -0 | LED | Driver | U6 | (JB7) | #### A - 8 Restart Address Jumper Block JB8 Installing the jumper between pins 2 and 3 forces the restart address to E000H. Installing the jumper between pins 1 and 2 forces a restart address to 0000H. | | JB8 | | |---|-----|-------------------------| | 1 | 0 | Force 0000H | | 2 | 0 | Restart address control | | 3 | 0 | Force E000H | ### A - 9 Memory Socket Configuration Blocks JB9, JB12 | | JB9 | | | | | | | JB12 | | | | | | | | |---|------------------------|-----|-------|-------|-----|------|-------|------------------------------|-------|------|-----|-----|-----|------|-----| | | 1 | 2 | 3 | 4 | 5 | 6 | | | 1 | 2 | 3 | 4 | 5 | 6 | | | В | 0 | 1 | 7 0 - | 0 | 0 | 0 | | В | 0 | 0 | 0 | 0 | 0 | 0 | • | | A | 0 | 0 | 6 | 0 | 0 | 0-1 | | A | 0 | 0 | 0 | 0 | 0- | -0- | | | | for socket<br>(1K RAM) | | | U 1 8 | 8 | | | for socket U20<br>(2K EPROM) | | | | | | | | | | | A 1 | | | Soc | cket | Pin | 1 | (psta | atic | RA | M r | ead | y/Vp | p) | | | ] | В1 | | | Soc | cket | Pin | 27 | (Pseu | obu | sta | tic | RA | M / | WE) | | | | A2 | | | Pro | oces | sor v | vait | logic | 2 | | | | | | | | 1 | B2 | | | Soc | cket | Pin | 26 | (Vcc | /A13 | ) | | | | | | A3 | Processor Address Bit A10 | |----|----------------------------| | В3 | Socket Pin 21 (A10/L) | | A4 | Processor Address Pin A11 | | В4 | Ground | | A5 | Socket Pin 23 (A11/WE/Vpp) | | B5 | Processor Write Strobe | | A6 | +5V | | В6 | Processor Address Bit 13 | #### A - 10 Memory Socket Configuration Block JB10 A 1 Processor wait logic Socket Pin 26 (Vcc/A13) A2 A3 Socket Pin 27 (Pseudo static RAM /WE) A4 Socket Pin 1 (pstatic RAM ready/Vpp) Processor Address Bit A10 B 1 B2 Processor Address Pin A11 **B3** Socket Pin 23 (A11/WE/Vpp) B4 +5V C 1 Socket Pin 21 (A10/L) C2 Ground Processor Write Strobe C3 Processor Address Bit 13 C4 #### A - 11 Wait State Generator Configuration Block JB11 | | 1 | 2 | 3 | 4 | |---|---|---|---|---| | В | 0 | 0 | 0 | 0 | | A | 0 | 0 | 0 | 0 | A1,B1 Wait on M1 cycles A2,B2 Wait on Interrupt Acknowledge cycles A3,B3 Wait on MREQ cycles A4,B4 Wait on On-board Memory Cycles #### A - 12 CTC/BUS Interface (JB13) These jumpers are installed to allow counter/timer I/O to be accessed using two lines of the backplane that are not normally used by the Z8O STD bus cards. These signals use the BUS lines normally referred to as MEMEX and IOEXP. This jumper block also contains the Debug function enable jumper. | | A B | | |---------------|-----|---------------| | MEMEX (J1-36) | 0 0 | CTC Output | | Ground | 0 0 | Ground | | CTC Input | 0 0 | IOEXP (J1-35) | | DEBUG (J1-38) | 00 | debug f/f | #### A - 13 On Board Memory Options (JB14) Memory option weight '1', '2', and '4' selects the memory configuration for the DSTD-102. This jumper block is used in a binary coded fashion. See section 3.3.2 for details. To use the on-board memory disable feature jumper 4A - 4B has to be installed. Port 7B can then be used to control the memory. | | | A B | | |----------------------------|---|------|---------------------| | Memory Option 1 Weight '1' | 1 | 0-0 | Ground | | Memory Option 2 Weight '2' | 2 | 0 0 | Ground | | Memory Option 3 Weight '4' | 3 | 0 0 | Ground | | DSMEN Latch Input | 4 | 04-0 | DSMEN Option Output | #### A - 14 Reset Mode (JB15) Jumper JB15 is used to select the push button reset mode. The push button logic is edge sensitive if the jumper is omitted and is level sensitive if it is installed. JB15 Push Button Input o o Reset Logic #### A- 15 Programming The CTC #### 1) Channel Selection DSTD products using the Z80 CTC decode the CTC to occupy 4 contiguous port addresses. Writing to the appropriate port address will automatically select the correct register in the CTC. #### 2) Interrupt Vectors If any one of the CTC channels is going to be used with its interrupt enabled, an Interrupt Vector must be written to the CTC. The user need only supply the 5 high bits of one vector as the CTC assumes the vector points to 4 contiguous byte pairs corresponding to the 4 channels. Note that DO must equal 0 to indicte that the word being written to the CTC is an interrupt vector; this also requires vectored addresses to start at an even memory location. 3) Channel Control Register The control register bit functions are as illustrated below. DO D7 D6 D5 **D4** D3 D2 D1 INT LOAD RANGE SLOPE TRIG TC RESET 1 ENA MODE DO = O indicates the byte is an INTERRUPT VECTOR. DO = 1 indicates the byte is a CONTROL WORD. D1 = 0 the channel continues current operation. D1 = 1 the channel is immediately RESET to control word values. D2 = 0 indicates NO TIME CONSTANT to follow. D2 = 1 the next I/O byte will be a TIME CONSTANT. (1 to 256) D3 = 0 timer will FREE-RUN starting on next processor cycle. D3 = 1 indicates timer will start on EXTERNAL TRIGGER. D4 = 0 indicates external trigger on NEGATIVE-GOING edge. D4 = 1 indicates external trigger on POSITIVE-GOING edge. D5 = 0 indicates prescaler factor of 16. (timer mode only) D5 = 1 indicates prescaler factor of 256. (timer mode only) D6 = 0 indicates TIMER mode. (prescaler is enabled) D6 = 1 inidcates COUNTER mode. (prescaler disabled) D7 = O INTERRUPT DISABLED for that channel. D7 = 1 INTERRUPT on zero count ENABLED for the channel. #### APPENDIX B STD-Z80 BUS PIN OUT APPENDIX B ### STD-Z80 BUS PIN OUT AND DESCRIPTION | BUS | MNEMONIC | DESCRIPTION | | | | |---------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | | | | | | | 1 | 5 V | 5Vdc system power | | | | | 2 | 5 V | 5Vdc system power | | | | | 3 | GND | Ground - System signal ground and DC return | | | | | 4 | GND | Ground - System signal ground and DC return | | | | | 5 | -5V | -5Vdc system power | | | | | 6 | -5V | -5Vdc system power | | | | | 7 | D3 | | | | | | 8 | D7 | | | | | | 9<br>10<br>11<br>12<br>13 | D2<br>D6<br>D1<br>D5<br>D0 | Data Bus (Tri-state, input/output active high). DO-D7 constitute an 8-bit bidirectional data bus. The data bus is used for data exchange with memory and I/O devices | | | | | 14 | D4 | | | | | | 15 | A7 | | | | | | 16 | A15 | | | | | | 17<br>18 | A6<br>A14 | Address Bus (Tri-state, output, active high). | | | | | 19<br>20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>28<br>29<br>30 | A5<br>A13<br>A4<br>A12<br>A3<br>A11<br>A2<br>A10<br>A1<br>A9<br>A0<br>A8 | A0-A15 make up a 16-bit address bus The address bus provides the address for memory (up to 65k bytes) data exchanges and for I/O device data exchanges. I/O addressing uses the lower 8 address bits to allow the user to directly select up to 256 input or 256 output ports. A0 is the least signficant address bit. During refresh time, the lower 7 bits contain a valid refresh address for dynamic memories in the system. | |----------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | /WR | Memory Write (Tri-state, output, active low). /WR indicates that the CPU data bus holds valid data to be stored in the addressed memory or I/O device. | | 32 | /RD | Memory Read (Tri-state, output, active low). /RD indicates that the CPU wants to read data from memory or an I/O device. The addressed I/O device or memory should use this signal to gate data onto the CPU data bus. | | 33 | /IORQ | Input/Output Request (Tri-state, output, active low). The /IORQ signal indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. An /IORQ signal is also generated with an /M1 signal when an interrupt is being acknowledged to indicate than an interrupt response vector can be placed on the data bus. Interrupt Acknowledge operations occur during /M1 time, while I/O operations never occur during /M1 time. | | 34 | /MEMRQ | Memory Request (Tri-State output, active low). The /MEMRQ signal indicates that the address bus holds a valid address for a memory read or write operation. | | 35 | /IOEXP | I/O expansion, not used on dy-4 Systems DSTD. | 36 /MEMEX Memory expansion, not used on dy-4 Systems DSTD cards. 37 /REFRESH /REFRESH (Tri-state, output, active low). /REFRESH indicates that the lower 7 bits of the address bus contain a refresh address for dynamic memories and the /MEMRQ signal should be used to perform a refresh cycle for all dynamic RAMs in the system. During the refresh cycle A7 is a logic zero and the upper 8 bits of the address bus contains the I register. 38 /DEBUG /DEBUG (Input) used in conjunction with DDT-80 operating system and the MDX Single Step card for implementing a hardware single step. When pulled low, the /DEBUG line will set a latch that will force the upper three address lines to a logic 1. To reset this latch, an I/O operation must be performed. 39 /M1 Machine Cycle One (Tri-state, output, active low). /M1 indicates that the current machine cycle is in the opcode fetch cycle of an instruction. Note that during the execution of a 2-byte opcodes, /M1 will be generated as each opcode is fetched. These two-byte op-codes always begin with a CBH, DDH, EDH or FDH. /M1 also occurs with /IORQ to indicate an interrupt acknowledge cycle. 40 STATUS O DMA priority chain input. 41 /BUSAK Bus Acknowledge (Output, active low). Bus Acknowledge is used to indicate to the requesting device that the CPU address bus, data bus, and control bus signals have been set to their high impedance state and the external device can now control the bus. 42 /BUSRQ Bus Request (Input, active low). The /BUSRQ signal is used to request the CPU address bus, data bus, and control signal bus to go to a high impedance state so that other devices can control those buses. When /BUSRQ is activated, the CPU will set these buses to a high impedance state as soon as the Current CPU machine cycle is terminated, and the Bus Acknowledge (/BUSAK) signal is activated. 43 /INTAK Interrupt Acknowledge (Tri-state output, active low). The /INTAK signal indicates that an interrupt acknowledge cycle is in progress, and the interrupting device should place its response vector on the data bus. 44 /INTRQ Interrupt Request (Input, active low). The Interrupt Request Signal is generated by I/O devices. A request will be honored at the end of the current instruction if the internal software controlled interrupt enable flip-flop (IFF) is enabled and if the /BUSRQ signal is not active. When the CPU accepts the interrupt, an acknowledge signal (/IORQ during an /M1) is sent out at the beginning of the next instruction cycle. 45 /WAITRQ WAIT REQUEST (Input, active low). Wait request indicates to the CPU that the addressed memory or I/O devices are not ready for a data transfer. The CPU continues to enter wait states for as long as this signal is active. The signal allows memory or I/O devices of any speed to be synchronized to the CPU. | 46 | /NMIRQ | Non-Maskable Interrupt request (Input, negative edge triggered). The Non-Maskable Interrupt request has a high priority than /INTRQ and is always recognized at the end of the current instruction, independent of the status of the interrupt enable flip-flop. /NMIRQ automatically forces the CPU to restart to location 0066H. The program counter is automatically saved in the external stack so that the user can return to the program that was interrupted. Note that continuous WAIT cycle can prevent the current instruction from ending, and that a /BUSRQ will over-ride a /NMIRQ. | |----|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 47 | /SYSRESET | System Reset (Output, active low). The System Reset line indicates that a reset has been generated from either an external reset or the power-on reset circuit. The system reset will occur only once per reset request and will be approximately 2 microseconds in duration. The system reset will also force the CPU program counter to zero, disable interrupts, set the I register to OOH, set the R register to OOH and set Interrupt Mode O. | | 48 | /PBRESET | Pushbutton Reset (Input, active low). The Pushbutton reset will generate a debounced system reset. | | 49 | /CLOCK | Processor Clock (Output, active low). Single phase system clock. | | 50 | CNTRL | Auxiliary Timing | | 51 | PCO | Priority Chain Output (Output, active high.) This signal is used to form a priority interrupt daisy chain when more than one interrupt driven device is being used. A high level on this pin indicates that no other devices of higher priority are being serviced by a CPU interrupt service routine. | | 52 | PCI | Priority Chain In (Input, active high). This signal is used to form a priority interrupt daisy chain when more than one interrupt driven device is being used. A high level on this pin indicates that no other devices of higher priority are being serviced by a CPU interrupt service routine. | |----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 53 | AUX GND | Auxiliary Ground (Bussed) | | 54 | AUX GND | Auxiliary Ground (Bussed) | | 55 | +12V | +12Vdc system power | | 56 | -12V | -12Vdc system power | ### NOTES: 1. The reference to input and output of a given signal is made with respect to the CPU module. # APPENDIX C DSTD-102 PARTS LIST #### DSTD 102 PARTS LIST | PT012008 | DY4PART | OTY DESCRIPTION | DESIGNATION | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------|-------------| | | PT012008 | 1 74LS08 TTL-LS | | | FT012020 | | | | | FT012074 | | | | | F7012112 | | | | | FT012144 | | | | | F7012244 | | | | | PT012244 | | | | | FT012245 | | | | | FT012257 | | | | | FT013074 | | 1 74LS257 TTL-LS | | | PT015009 | | | | | PT015013 | | 1 MK3880n (Z80-CPU) 2.5 MHZ CPU | | | PT015017 | | 1 MK3882n (280-CTC) 2.5 MHZ CTC | | | PT016001 | | 1 MK3884n (280-SIQ/O) 2.5 MHZ SIQ/O | | | PT036002 2 75189 OR NC1489 INTERFACE | PT016001 | 2 75188 OR MC1488 INTERFACE | | | PRO36001 PRAL12L6 | | | | | PT036002 | | 1 PAL12L6 | | | PT041101 | | 2 PAL16L8 | | | PT041122 | | | R12 | | Troad Troa | | | R4 | | PT041221 | | | | | PT041302 | | | R5 | | PT041472 | | | R1,R7 | | PT041473 | | | R2,R3 | | PT041681 | | | | | PT043012 | | 1 1/4 WATT, 680 OHM, 5% RESISTOR | | | PT043017 | | 2 8 PIN. 7 RESISTOR, 4.7K OHM, SIP RESISTOR NETWORK | | | PT051004 | | 1 10 PIN. 9 RESISTOR, 4.7K OHM, SIP RESISTOR NETWORK | | | PT052003 | | 1 034-55101 OR 035-56101, 100uf, RADIAL ELECTROLYTIC CAPACITOR | | | PT052004 8 CK05BX331K,330pf, 200V CERAMIC CAPACITOR C6-13 PT052009 1 8131-100-25U-474M, .47uf, 50V, CERAMIC CAPACITOR C3 PT052010 18 .1uf, 50V(.1 LD. SP.) 8121-050-25U-104M, CERAMIC CAPACITOR C16,17,19,21-34,36 PT052013 1 .1uf,50V(.2 LD. SP.) 8121-050-25U-104M) (102 BOARD ONLY) C14 PT053000 1 TAG10M25, 10uf, 25V TANTALUM CAPACITOR C18 PT071000 1 1N4148 SIGNAL DIODE 93 PT073001 2 1N4001 RECTIFIER D1,02 PT091000 1 HLMP6300 SMALL RED LED LED2 PT091000 1 K1135A CRYSTAL OSCILLATOR GENERATOR U21 PT101000 1 K1116A 5.000 MHZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS JB1-J85,J89-JB15 PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB6,JB7-JB10c,JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2,J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U16,U17 PT126040 < | | 1 CK059X330K, 33of, 200V CERAMIC CAPACITOR | | | PT052010 | PT052004 | 8 CK05BX331K,330pf, 200V CERAMIC CAPACITOR | | | PT052010 18 .1uf, 50V(.1 LD. SP.) 8121-050-25U-104M, CERAMIC CAPACITOR C16,17,19,21-34,36 PT052013 1 .1uf,50V (.2 LD. SP.) 8121-050-25U-104M) (102 B0ARD ONLY) C14 PT053000 1 TAGIOM25, 10uf, 25V TANTALUM CAPACITOR C18 PT061003 1 2M3906 TRANSISTOR 91 PT071000 1 IN4148 SIGNAL DIODE 03 PT073001 2 IN4001 RECTIFIER D1,02 PT091000 1 HLMP6300 SMALL RED LED LED2 PT091000 1 HLMP6500 SMALL GREEN LED LED1 PT101000 1 K1135A CRYSTAL OSCILLATOR GENERATOR U21 PT1910005 1 K1116A 5.000 MIZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS JB1-JB5, JB9-JB15 PT122004 1 CH56936HIS 36 PIN DOUBLE ROW HEADER JB6, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2, J3 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20, U8 PT126040 2 | PT052009 | 1 8131-100-25U-474M, .47uf, 50V, CERAMIC CAPACITOR | | | PT053000 1 TAG10N25, 10uf, 25V TANTALUM CAPACITOR C18 PT061003 1 2N3906 TRANSISTOR 91 PT071000 1 1N4148 SIGNAL DIODE D3 PT073001 2 1N4001 RECTIFIER D1,D2 PT091000 1 HLMP6300 SMALL RED LED LED2 PT091002 1 HLMP6500 SMALL GREEN LED LED1 PT101000 1 K1135A CRYSTAL OSCILLATOR GENERATOR U21 PT101005 1 K1116A 5.000 MHZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS U30 PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB1-J85, JB9-JB15 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER JB6, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2,J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U18-U20,U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16,U17 PT344901 1 DSTD 102 DY00449 | PT052010 | | | | PT053000 1 TAG10N25, 10uf, 25V TANTALUM CAPACITOR C18 PT061003 1 2N3906 TRANSISTOR 91 PT071000 1 1N4148 SIGNAL DIODE D3 PT073001 2 1N4001 RECTIFIER D1,D2 PT091000 1 HLMP6300 SMALL RED LED LED2 PT091002 1 HLMP6500 SMALL GREEN LED LED1 PT101000 1 K1135A CRYSTAL OSCILLATOR GENERATOR U21 PT101005 1 K1116A 5.000 MHZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS U30 PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB1-J85, JB9-JB15 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER JB6, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2,J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U18-U20,U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16,U17 PT344901 1 DSTD 102 DY00449 | | 1 .1uf,50V (.2 LD. SP.) 8121-050-25U-104N) (102 BOARD ONLY) | | | PT071000 | PT053000 | 1 TAG10M25, 10uf, 25V TANTALUM CAPACITOR | | | PT073001 2 | PT061003 | 1 2N3906 TRANSISTOR | | | PT091000 | PT071000 | 1 1N4148 SIGNAL DIODE | | | PT091002 1 HLMP6500 SMALL GREEN LED PT101000 1 K1135A CRYSTAL OSCILLATOR U21 PT101005 1 K1116A 5.000 MHZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS U30 PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB1-J85, JB9-JB15 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER JB6, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR CAMP ONLY) J2, J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9, U23, U26 PT126040 2 640379-3 40 PIN I.C. SOCKET U16, U17 PT344901 1 DSTD 102 DY00449-H-A1-6 U16, U17 | PT073001 | 2 1N4001 RECTIFIER | | | PT101000 1 K1135A CRYSTAL OSCILLATOR GENERATOR U21 PT101005 1 K1116A 5.000 MHZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS JB1-J85, JB9-JB15 PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB6, JB7-JB10c, JB15 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER JB6, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2, J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9, U23, U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20, U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16, U17 PT344901 1 DSTD 102 DY00449-H-A1-6 | | | | | PT101000 1 K11334 CKTSTHE GSGTELTOK GENTAL OSCILLATOR U30 PT101005 1 K1116A 5.000 MHZ CRYSTAL OSCILLATOR U30 PT111073 1 S208-1 CARD EJECTOR WITH PINS JB1-J85, JB9-JB15 PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB6, JB7-JB10c, JB15 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER JB6, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2, J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9, U23, U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20, U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16, U17 PT344901 1 DSTD 102 DY00449-H-A1-6 | PT091002 | | | | PT101003 1 K11107 3.000 TIME CROWNE COUNTY PT111073 1 S208-1 CARD EJECTOR WITH PINS PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB1-J85, J89-J815 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER J86, J87-J810c, J815 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2, J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9, U23, U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20, U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16, U17 PT344901 1 DST0 102 DY00449-H-A1-6 | PT101000 | | | | PT111073 1 S208-1 CARD EJECTOR WITH PINS PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB1-J85, JB9-JB15 PT122004 1 CHS6936WIS 36 PIN SINGLE ROW HEADER J86, JB7-JB10c, JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2, J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9, U23, U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20, U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16, U17 PT344901 1 DSTD 102 DY00449-H-A1-6 U16, U17 | | | U3 <b>0</b> | | PT122003 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER JB1-J85, J89-J815 PT122004 1 CH56936WIS 36 PIN SINGLE ROW HEADER J86, J87-J810c, J815 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2, J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9, U23, U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20, U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16, U17 PT344901 1 DSTD 102 DY00449-H-A1-6 | | 1 S208-1 CARD EJECTOR WITH PINS | | | PT122004 1 CHS693&UIS 36 PIN SINGLE ROW HEADER JB6,JB7-JB10c,JB15 PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2,J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9,U23,U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20,U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16,U17 PT344901 1 DSTD 102 DY00449-H-A1-6 U16,U17 | | 3 CHD6960WIS 60 PIN DOUBLE ROW HEADER | | | PT123003 2 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) J2,J3 PT126020 3 640464-3 20 PIN I.C. SOCKET U9,U23,U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20,U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16,U17 PT344901 1 DST0 102 DY00449-H-A1-6 | | 1 CHS6936UIS 36 PIN SINGLE ROW HEADER | | | PT126020 3 640464-3 20 PIN I.C. SOCKET U9,U23,U26 PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20,U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16,U17 PT344901 1 DSTD 102 DY00449-H-A1-6 | | | | | PT126028 4 640362-3 28 PIN I.C. SOCKET U18-U20,U8 PT126040 2 640379-3 40 PIN I.C. SOCKET U16,U17 PT344901 1 DSTD 102 DY00449-H-A1-6 | | 3 640464-3 20 PIN I.C. SOCKET | | | PT126040 2 640379-3 40 PIN 1.C. SOCKET U16,U17 PT344901 1 DSTD 102 DY00449-H-A1-6 | | | | | PT344901 1 DSTD 102 DY00449-H-A1-6 | | 2 640379-3 40 PIN I.C. SOCKET | U16,U17 | | | - | 1 DSTD 102 DY00449-H-A1-6 | | | LIVIIONS 1 INC LEGIONE | PT711003 | 1 102 MANUAL | | #### APPENDIX C #### DSTD 102 PARTS LIST | DY4PART | QTY | DESCRIPTION | DESIGNATION | |----------|-----|--------------------------------------------------------------|--------------------| | PT012008 | 1 | 74LS08 TTL-LS | U15 | | PT012014 | 1 | 74LS14 TTL-LS | U5 | | PT012020 | 1 | 74LS20 TTL-LS | U10 | | PT012074 | 2 | 74LS74 TTL-LS | U3,U14 | | PT012112 | 1 | 74LS112 TTL-LS | U11 | | PT012164 | 1 | 74LS164 TTL-LS | U4 | | PT012243 | 1 | 74LS243 TTL-LS | U27 | | PT012244 | 2 | 74LS244 TTL-LS | U28,U29 | | PT012245 | 3 | 74LS245 TTL-LS | U22.U24.U25 | | PT012257 | 1 | 74LS257_TTL-LS | U13 | | PT013074 | 1_ | 74\$74 TTL-\$ | U12 | | PT015010 | 1 | MK3880n-4 (Z80A-CPU) 4.00 MHZ CPU | U17 | | PT015014 | 1 | MK3882n-4 (280A-CTC) 4.00 MHZ CTC | U8 | | PT015020 | 1 | MK3884n-84 (280A DART) 4.00 MHZ DART | U16 | | PT016001 | 2 | 75188 OR MC1488 INTERFACE | U6,U7 | | PT016002 | 2 | 75189 OR MC1489 INTERFACE | U1,U2 | | PT036001 | _1_ | PAL12L6 | U23 | | PT036002 | 2 | PAL16L8 | U9,U26 | | PT041101 | _1_ | 1/4 WATT, 100 OHM, 5% RESISTOR | R12 | | PT041122 | 1 | 1/4 WATT, 1.2K OHM, 5% RESISTOR | R4 | | PT041220 | 1 | 1/4 WATT. 22 OHM. 5% RESISTOR | R6 | | PT041221 | 1 | 1/4 WATT, 220 OHM, 5% RESISTOR | <del>R5</del> | | PT041302 | 2 | 1/4 WATT, 3K OHM, 5% RESISTOR | R1,R7 | | PT041472 | 2 | 1/4 WATT, 4.7K OHM, 5% RESISTOR | R2,R3 | | PT041473 | 1 | 1/4 WATT, 47K OHM, 5% RESISTOR | R10 | | PT041681 | _1_ | 1/4 WATT, 680 ONM, 5% RESISTOR | R13 | | PT043012 | 2 | 8 PIN. 7 RESISTOR. 4.7K OHM. SIP RESISTOR NETWORK | RN2,RN3 | | PT043017 | _1_ | 10 PIN, 9 RESISTOR, 4.7K OHM, SIP RESISTOR NETWORK | RN4 | | PT051004 | _1_ | 034-55101 OR 035-56101, 100uf, RADIAL ELECTROLYTIC CAPACITOR | C25 | | PT052003 | _1_ | CK05BX330K, 33bf, 200V CERAMIC CAPACITOR | | | PT052004 | 8 | CK05BX331K,330pf, 200V CERAMIC CAPACITOR | C6-13 | | PT052009 | 1 | 8131-100-25U-474M, .47uf, 50V, CERAMIC CAPACITOR | C3 | | PT052010 | 18 | .1uf. 50V(.1 LD. SP.) 8121-050-25U-104M, CERAMIC CAPACITOR | C16,17,19,21-34.36 | | PT052013 | 1 | .1uf,50V (.2 LD, SP.) 9121-050-25U-104N) (102 BOARD ONLY) | C14 | | PT053000 | 1 | TAGIOM25, 10uf, 25V TANTALUM CAPACITOR | C18 | | PT061003 | 1 | 2N3906 TRANSISTOR | 0! | | PT071000 | _1_ | IN4148 SIGNAL DIODE | D3 | | PT073001 | 2 | 1N4001 RECTIFIER | 01,02 | | PT091000 | 1_ | HLMP6300 SMALL RED LED | LED2 | | PT091001 | _1_ | HLMP6400 SMALL YELLOW LED | LED1 | | PT101000 | 1 | K1135A BAUD RATE GENERATOR | U21 | | PT101007 | 1 | K1116A 9.000 MHZ CRYSTAL OSCILLATOR | U30 | | PT111073 | 1_ | S208-1 CARD EJECTOR WITH PINS | | | PT122003 | 2 | CHD6960WIS 60 PIN DOUBLE ROW HEADER | J91-J85,J89-J815 | | PT122004 | _1_ | CHS6936WIS 36 PIN SINGLE ROW HEADER | JB6.JB7-JB10c.JB15 | | PT123003 | 2 | 87516-2 12 PIN RIGHT ANGLE CONNECTOR (AMP ONLY) | J2.J3 | | PT126020 | _ 3 | 640464-3 20 PIN I.C. SOCKET | U9.U23.U26 | | PT125028 | 4 | 640362-3 28 PIN I.C. SOCKET | U18-U20,U8 | | PT126040 | 2 | 640379-3 40 PIN I.C. SOCKET | U16.U17 | | PT344901 | _1_ | DSTD 102 DY00449-H-A1-7 | | | PT711003 | . 1 | 102 MANUAL | | FIGURE C-1 DSTD-102-4 SILK SCREEN APPENDIX D SCHEMATIC | | IÇ | POWE | R PINS | | | |------------|------|------|--------|----|-----| | TYPE | • 12 | -12 | • 5 | -5 | GND | | 74L508 | | | 14 | | 7 | | 74LS14 | | | 14 | | 7 | | 74LS20 | | | 14 | | 7 | | 74L574 | | | 14 | | 7 | | 74574 | | | 14 | | 7 | | 74LS112 | | | 16 | | 6 | | 74LSI64 | | | 14 | | 7 | | 74LS243 | 9) | | 14 | | 7 | | 74L5244 | | | 20 | | 10 | | 74LS257 | | | 16 | | ₽ | | 74LS645 | | | 20 | | 0 | | 2716/2764 | | | 28 | | 14 | | 75186 | 14 | 1 | | | 7 | | 75189 | | | 14 | | 7 | | KII35A | 9 | | 2 | | 11 | | PAL12L6 | | | 20 | | 10 | | ZBO CTC | | | 24 | | 5 | | Z80 SIO | | | 9 | | 31 | | ZBO CPU | | | E ( | | 29 | | XTAL LOCOT | | | 14 | | 7 | | | | SST | -D <sub>1</sub> : = = | | | | |--------|-------|-------|-----------------------|-------|--------|-------------| | SCALE | | DRN D | NICHOLLS | CHK | | DATE 411/52 | | APP'D | | TOL | | MAT'L | | FINISH | | TITLE | DSTD | 102 | (POWE | ₹ & | GND. | TABLE) | | DWG NO | , DAO | 044 | 9-I- | Δ1- | 6 1155 | 6 SH OF 3 | C CANADIAN ELECTRONICS PACKAGING 7 111 -**\(\frac{1}{2}\)** ·---4 0 84 100 977/ W Ş 1418 250 PE O'THUS AND DWA SAC Oute N O SEE N O MA O ECN ODZ6 000, 000 000, 10th 4 U22 BATE DRIE CHE DATE 30 Adv. 7: ų 드 **₹**; 98.0 Per 3.0 P ļ . 0.00 010 ŧ A1 (m AROY OZOZ 247〇新田 27/5 SAN CAN 13. E (8) UZ ZCO CAN THE STATE OF 8 8k ŽĮ. En ( 2007) CTI SACRET The same of sa » по DY00449-I -A3-6 "% A ECN OOZG -0410-105 ( SELIM TAO) 101 000 000 / sent 1480 THE POST PAR 1 A PART VALLE 620 800 B per Ny labor CHE 1000 1027 -O 39-7 į 022--Darie -0134 0 39-0 10 20 7 25 9-8t O 4.65 -0 JZ-12 9-22 Pare .o.E.m 4 4 **Z80** APPLICATION NOTES AND TECHNICAL ARTICLES #### Tutorial #### INTRODUCTION Interrupts provide a means of processing information on a random or asynchronous basis. The Z80 CPU and peripheral family support interrupts using a daisy-chain approach. As opposed to parallel priority resolution, the daisy chain uses an efficient, minimal-hardware method of prioritizing multiple interrupting devices. In addition, a parallel priority resolution scheme can be configured with the Z80 through the use of a priority encoder and other external hardware. Coupled with the powerful vectored interrupt -capabilities of the Z8O, this approach allows the system designer great flexibility in implementing an interrupt driven system. This document describes the Z80 CPU interrupt process and evaluates the design of the dalsy-chain interrupt scheme. The reader can refer to the following documents for additional information: - Z80 Assembly Language Programming | Manuai | | | | (03-0002-01) | |----------|-------|------------|-----------|--------------| | Z80/Z80A | CPU | Technical | Manual | (03-0029-01) | | Z80/Z80A | 510 | Technical | Manual | (03-3033-01) | | Z80/Z80A | P10 | Technicai | Manual | (03-0008-01) | | Microcom | puter | r Componen | ts Data 🐇 | A South and | | Book | | 3.0 | + 1/2 % | (03-8032-01) | Z80 CPU The Z80 uses two types of interrupts: maskable (INT input) and non-maskable (NMI input). Maskable interrupts may be nested. The simplest maskable interrupt implementation does not provide for the nesting of Interrupts, thereby obligating an Interrupt service routine to complete its processing , and return to the main program before another interrupt can be serviced. With nested was as interrupts, an interrupt service routine can be interrupted either by an interrupt that invokes the same routine (reentrant type) or . by a higher priority interrupt that invokes a different, interrupt service routine. ... The Z80: family components allow the user to implement, a powerful interrupt-driven system utilizing these concepts. Francis Lab When both types of interrupts are employed, the Z80 CPU will service them in a specific sequence. Both the INT and NMI inputs are sampled by the CPU on the rising edge of CLK in the last T state of the last Machine (M) cycle of any instruction. However, if BUSRQ is active at the same time, it will be processed before any interrupts. Figure 1 lilustrates the Z80 interrupt service sequence. Figure 1. Z80 Flow Diagram Interrupt Sequence #### Non-Maskable Interrupts The non-maskable interrupt (NMI) is different from the maskable interrupt in several respects. NMI is always enabled and cannot be disabled by the programmer. It is employed when very fast response is desired independent of the maskable interrupt status and can be used for interrupt conditions like a power fall detect. NMI is an edge-sensitive signal that has a lower priority than BUSRO and higher priority than INT. When the CPU acknowledges an occurrence of NMI, the processor begins a normal opcode fetch. How- This application note refers to products as Z80 "A", "B" etc. to specify the speed grade. We are no longer using those characters for the speeds. For more details, please refer to the ordering information section. ever, the data read from memory is ignored and instead the CPU restarts its operation from location 66H. The restart operation involves pushing the Program Counter onto the stack, jumping to location 66H, and continuing to process there. During this time, the status of the maskable interrupt condition is preserved and maskable interrupts are disabled, until either an El instruction is executed or a RETN instruction is used to exit the $\overline{\text{NMI}}$ service routine. The RETN instruction is discussed in detail in the Z80 CPU Technical Manual. Figure 2 shows the timing used for $\overline{\text{NMI}}$ interrupts. Figure 2. Non-maskable Interrupt Request Operation Maskable Interrupts Maskable interrupts ( $\overline{\text{INT}}$ ) are acknowledged with a lower priority than the $\overline{\text{MII}}$ but allow the programmer more flexibility. $\overline{\text{INT}}$ is enabled under software control by way of the EI instruction and disabled via the DI instruction. When the Z80 CPU samples $\overline{\text{INT}}$ and it is active, the processor begins an interrupt acknowledge cycle so long as $\overline{\text{BUSRQ}}$ and $\overline{\text{MII}}$ are not active. The processor does not use an interrupt acknowledge signal but instead issues the acknowledge by executing a special $\overline{\text{MI}}$ cycle. During an interrupt acknowledge cycle, $\overline{\text{RD}}$ is inactive, $\overline{\text{IORO}}$ is active, and two wait states are automatically added. Since the Z80 peripheral devices have logic to interpret this special cycle with no additional external circuitry, a minimal amount of hardware is needed by the system and there is no loss in efficiency. Figure 3 shows the detailed timing for the Z80 CPU interrupt acknowledge cycle. Figure 3. Interrupt Acknowledge Cycle 611-1809-0003 530 12/1/80 Maskable Interrupt Mode 1 skable Interrupt Mode 0 611-1809-( There are also three modes of operation for servicing maskable interrupts. These are Mode 0, Mode 1, and Mode 2. Any particular mode is selected by the programmer using the iM instruction. Figure 4 illustrates the processing sequence for each interrupt mode. Figure 4. Maskable Interrupt Sequences Maskable interrupt Mode 0 In the maskable interrupt Mode 0 (as with the 8080 interrupt response mode), the interrupting device places an instruction on the data bus for execution by the Z80 CPU. The instruction used is normally a Restart (RST) instruction, since this is an efficient one-byte call to any of eight subroutines located in the first 64 bytes of memory. (Each subroutine is a maximum of eight bytes.) However, any instruction may be given to the Z80 CPU. The first byte of a multibyte instruction is read during the interrupt acknowledge cycle. Subsequent bytes are read in by normal memory read cycles. The Program Counter remains at its preinterrupt state, and the user must insure that memory will not respond to these read sequences, since the instruction must come from the interrupt hardware. Timing for the additional bytes of a multibyte instruction is the same as for a single byte instruction (see Mi in Figure 2). When an interrupt is recognized by the CPU, succeeding interrupts are automatically disabled. An Ei Instruction can be executed anytime after the interrupt sequence begins. The subroutine can then be interrupted, allowing nested interrupts to be used. The nesting process may proceed to any level as long as all pertinent data is saved and restored correctly. Upon RESET, the CPU automatically sets interrupt Mode 0. Maskable interrupt Mode 1 Interrupt Mode I provides minimally complex peripherals access to interrupt processing. It is similar, to the NMT interrupt, except that the CPU automatically CALLs to location 38H instead of 66H. As with the NMI, the CPU pushes the Program Counter onto the stack automatically (Figure 2). Maskable Interrupt Mode 2 (Vectored Interrupts) The Z80 CPU interrupt vectoring structure allows the peripheral device to identify the starting location of the Interrupt service routine. Mode 2 is the most powerful of the three maskable interrupt modes. It allows an the manifest call to any memory location by a single 8-bit vector supplied by the peripheral. In this mode, the peripheral generating the interrupt places the vector onto the data bus in response to an interrupt acknowledge. The vector then becomes the least significant eight bits of the 16-bit indirect pointer, whereas the I register in the CPU forms the most significant eight bits. This address points to an even address in the vector table which then becomes the starting address of the interrupt service routine. interrupt processing thus starts at an arbitrary 16-bit address, allowing any location in memory to begin the service routine. Since the vector is used to identify two adjacent bytes that form a 16-bit address, the CPU requires an even starting address for the vector's low byte. Figure 5 shows the sequence of events for processing vectored interrupts. > The I register is loaded by the user from the A register. There is no restriction on its value other than its pointing to a valid memory location. #### NOTES: - 1. Interrupt vector generated by peripheral is read by CPU di ing interrupt acknowledge cycle. Vector combined with I register o - address pointing to vector table - 3. Two bytes are read sequentially from vector table - 4. Processor control is transferred to interrupt service routing and execution continues. Figure 5. Vector Processing Sequence Return from --Maskabie Interrupt When execution of the interrupt service routine is complete, return to the main program (or another service routine) occurs differently in each mode. in Mode O, the method of return depends on which instruction was executed by the CPU. If an RST instrucofion is used, a simple RET suffices. In Mode 1, the CPU treats the interrupt as a CALL instruction, so an RET is used. Mode 2, however, uses the vector information from the peripheral chip to identify the source of the recognized interrupt, and a method of resets ting the peripheral's interrupt condition must be found. This is accomplished by using the RETI instruction. If Mode 2 is used by the programmer, the RETi instruction must be executed in order to utilize the daisy chain properly. Figure 6 shows the RETI Instruction timing for the Z80 CPU. A more complete description of how RETI affects the peripherais is given in Chapter 3. Figure 6. Return From Interrupt Timing (RETI) for Mode 2 Interrupts MITTER PROCESS I BY Z80 PERIPHER Using interr Halt Exit Using Interrupts Whenever a software hait instruction is executed, the CPU enters the Hait state by executing No-OPs (NOPs) until an interrupt or RESET is received. Each NOP consists of one MT cycle with four T states. The CPU samples the state of the NMI and NTI lines on the rising edge of each T4 clock (Figure 7). When an Interrupt exists on either line, the subsequent cycle will be either a memory read operation ( $\overline{\text{NMI}}$ ) or an interrupt acknowledge ( $\overline{\text{INT}}$ ). The timing in Figure 7 shows a maskable interrupt causing the CPU to exit the Hait state. Figure 7. Exit Halt State with Maskable Interrupt INTERRUPT PROCESSING BY Z80 PERIPHERALS Understanding maskable interrupt processing requires a familiarity with how the Z80 peripherals respond to the CPU interrupt sequence. The Z80 family products were designed around the daisy-chain interrupt configuration, which utilizes minimal external hardware (compared to parallel contention resolution interrupt priority networks). Many devices handle interrupts via a handshake arrangement, e.g. the use of Interrupt request and Interrupt acknowledge signals. This is the most straightforward and probably the fastest method of implementing prioritization using more than one interrupting device. However, this method requires a separate interrupt request signal for each peripheral device and either a separate acknowledge: signal for each device or a software acknowledge. Extra hardware is needed to provide contention resolution should two or more devices request an interrupt simultaneously. With the Z80 product family, however, such extra hardware is unnecessary and the software does not need to remove the interrupt request from the peripheral device. This is made possible through use of the daisy-chain priority network, which can best be visualized as a type of bucket brigade. The Z80 peripheral products implement, this daisy chain with just three extra signal lines on each chip: Interrupt enable input (IEI), Interrupt enable output (IEO), and interrupt request (INT). The Interrupt request line is an open-drain circuit that is OR wired to the INT pins of the other devices in the chain and connected to the INT pin on the Z80 CPU. This line provides the interrupt request to the CPU. The IEI and IEO lines provide the means for establishing priority among several requesting devices. The priority of a device is determined by its position in the chain. The IEI pin of the highest priority device in the chain is connected to +5 volts. The IEO pin of the same device is connected to the IEI pin of the next highest priority device. The 1EO pin of that device goes to the 1E1 pin of the next lower device, as shown in Figure 8, and so on to the last device in the chain, where the IEO pin is left open. When a device has an interrupt pending, it activates its INT output which requests service from the CPU and brings its IEO pin Low, thereby preventing the lower devices in the chain from responding to further interrupt operations. When the CPU acknowledges the interrupt, the requesting device removes its interrupt request (INT) signal. After the interrupt processing is completed, the peripheral will reset itself with an RETI instruction, which will bring IEO High and restore the chain to its quiescent state. Figure 8. Z80 Peripheral Device Interrupt Processing Sequence 611-1809-0003 करी देखकार है। अपनि कहा समुद्रक है दुन्हें मधीन भीत्र तर्गान्त 200.0 1 2 My 10 DAIST DESIG CONSI set and disables IEO to prevent lower priority devices in the chain from responding to an interrupt cycle. IUS is cleared when IEI is High and the peripheral decodes a valid "ED-4D" instruction. Thus, = INTACK \* INT\_COND \* IEI \* IUS \* (IP + "ED") 1 EO a) State Diagram of Z80 Peripherals During Interrupt Cycle. b) Truth Table of Daisy Chain During Idle or Interrupt Acknowlege Condition. c) Truth Table of Daisy Chain During "ED" Decode of Opcode Fetch. Note That IP Is Not Part of IEO Condition. Figure 10. Z80 Peripheral Interrupt States DAISY CHAIN DESIGN There are several aspects of the Z80 family daisy chain implementation that deserve CONSIDERATIONS further attention. and the fact of the case First, since the peripheral devices must be able to monitor the data bus in order to decode the RETI Instruction properly, a means of allowing them access to the data bus must be provided if buffers are used. This can be done by simply enabling the buffers from the data bus to the peripheral for all conditions except I/O read and Interrupt acknowledge. Since the peripheral must assert an 8-bit vector during interrupt acknowledge, the buffers must also accommodate this. Second, because the peripheral devices have a finite time during which IEI and IEO can stabilize within, the propagation delay of the devices must be taken into consideration. Since a device can change its interrupt status until reaching the active edge of Mi during interrupt acknowledge, the time from this edge until IORO becomes active is the time in which the daisy chain must stabilize. Figure 11 shows the timing relationships involved in this process. Figure 11. Interrupt Acknowledge Peripheral Propagation Delay Interrupt Acknowledge Operation The Z80 peripherals are acknowledged by the CPU and then serviced by an appropriate interrupt service routine. The acknowledge to the peripherals is accomplished by the CPU executing a special MI cycle in which TORQ goes active instead of MREQ and RD. Whenever MT goes active, all peripheral devices are inhibited from changing their interrupt status. This allows time for IEO to propagate through the other devices in the chain before 1000 goes active. As soon as 1000 and MI go active, the peripheral device that has its IEI High and an interrupt pending gates an 8-bit vector onto the data bus. (See Figure 9 for timing details.) This 8-bit vector, which was programmed into the peripheral device, is combined with the contents of the I register in the CPU to form a 16-bit address value. During the time that MI and TORO are active, the requesting device removes the TNT signal (since the CPU has acknowledged it) and waits for a return operation. If the peripheral device has its iEI pin High and has had an interrupt acknowledged, then it completes the interrupt cycle and releases IEO (when it sees an RETI instruction (ED-4D sequence) on the data bus). This restores the chain to its normal state so that lower priority interrupts can occur. The Z80 peripherals monitor $\overline{\text{M1}}$ and $\overline{\text{RD}}$ for the interrupt acknowledge cycle. Since $\overline{\text{RD}}$ goes active before $\overline{10\text{RQ}}$ , the peripheral devices assume an interrupt acknowledge cycle if $\overline{\text{M1}}$ is active and $\overline{\text{RD}}$ is not. This reduces the time required for the internal device logic to respond to $\overline{10\text{RQ}}$ when it goes active. Thus, a very powerful interrupt-driven system can be implemented with minimal hardware, simple software, and high efficiency using the Z80 family components. Figure 9. Peripheral Interrupt Acknowledge Return from Interrupt Operation When the CPU executes an RETI instruction, the device with an interrupt under service resets its interrupt condition, provided that IEI is High. All Z80 peripheral products sample the data bus for this instruction when $\overline{\text{MI}}$ goes active along with $\overline{\text{RD}}$ . The RETI instruction decode by the peripheral device has certain characteristics that the designer should be aware of. Since a peripheral can request an interrupt (activate INT and bring IEO Low) at any time, it is possible for a device whose interrupt is currently under service to have its IEI pin Low. This is undesirable, since such a condition prevents the peripheral from resetting IUS properly. To overcome this problem, all Z80 family peripherals bring IEO High momentarily when the ED is seen during the ED-4D instruction fetch. The device whose interrupt is under service does not allow IEO to go High, but when it sees IEI High, it will reset itself when the 4D byte is fetched. Figure 10 shows the relationship of IP and IUS to INT, IEI, and IEO. IP is set by an interrupt condition on the peripheral (such as the transmit buffer becoming empty) whenever interrupts are enabled. However, IP being set will only cause INT to go active (requesting an interrupt) if IUS is not set and IEI is High. IP is not necessarily cleared by the interrupt acknowledge cycle. Some specific action must be taken within the service routine, such as filling a transmit buffer. Under these conditions. IUS becomes eturn ce has Its ipt ackiterrupt is an RETI data its normal upts can ₹D for the ₹D goes tevices le if M1 :es the ie logic ve. en system ware, using The Z80 CPU automatically inserts two wait states during INTACK, allowing a worst-case time for a chain of four devices to become settled (when using Z80A CPU and peripherals at 4MHz). If more devices are in the chain, some other means of stabilizing the chain must be provided. This can be done either by adding additional wait states to the INTACK cycle or by providing logic to the peripherals that allows faster propagation time down the chain. Figure 12 shows circuitry that provides both additional wait states and an interrupt look-ahead circuit when more than four peripheral devices are connected to the daisy chain. When adding wait states to the Z80 CPU interrupt acknowledge cycle, care must be taken to insure that \$10R\tilde{Q}\$ goes active at the proper time. Normally, the CPU activates \$10R\tilde{Q}\$ on the falling edge of the clock during the first wait cycle. If external logic is used to insert additional wait states, these are appended to the two wait states already generated by the CPU. Because \$10R\tilde{Q}\$ goes active during the first wait state and the peripherals assert their vectors when \$10R\tilde{Q}\$ must be inhibited until the daisy chain becomes stable. This can be done simply by adding a few gates to the wait logic (Figure 13). \$10R\tilde{Q}\$ is the delayed \$10R\tilde{Q}\$ that activates the peripheral devices. Figure 12A. Daisy Chain Look-Ahead Logic for More Than Four Peripheral Devices Smilt Comes nter-EO to Will and en such when- ive set 1/1/80 The propagation delay through the peripheral devices applies during the return from Interrupt condition, also. Worst-case timing involves the lowest priority device that has an interrupt under service and the highest priority device that has an interrupt pending. When the ED part of the RETI opcode is fetched, the peripheral devices must decode it, and the highest priority device must bring its IEO pin High. This IEO high signal must then propagate through the chain down to the lowest priority device before the 4D part of RETI is decoded. Figure 14 shows the timing relationships involved. This timing is not as critical as the interrupt acknowledge timing at 4 MHz, but should be considered if wait states are being added to the INTACK cycle. If using nested interrupts with a large dalsy chain, the programmer should be careful not to place the RETI opcodes too close together. Since RETI is 14 cycles long, this is generally not a problem unless a very long chain is used. Figure 13. Wait State Logic for Interrupt Acknowledge Cycle. Counter Preset Value Should Be 5-n. Where n = # Wait State Added #### NOTES: - Setup time for IEI to "4D" decode ≈ 200ns (4.0 MHz). Must look at IEI during ED-4D because nested interrupts allow more than 1 IUS latch to be set at one time. - allow more than 1 105 latten to be set at one time. Delay time from ED decode with IP set to IEO high 300ns (typ) 400ns (max) @2.5 MHz. This in in additionable time for other devices in chain. $T_r \, \geq \, T_d \text{ED(IEO}_r) \, + \, T_d \text{IEI(IEO}_r) \, \bullet \, \text{iN-2i} \, + \, T_s \text{IEI(4D)}$ #### for N-2 devices $T_{d}ED(IEO_{r}) = Delay time from "ED" decode to IEO rise$ $T_{d}IEI(IEO_{r}) = Delay time from IEI high to IEO rise.$ T<sub>s</sub>IEI(4D) = Setup time for IEI during "4D" decode. (For last device in chain.) Figure 14. Daisy Chain Interrupt Timing (RETI Condition) SPECIAL CAS OF INTERRUP SPECIAL CASES OF INTERRUPTS Interfacing Zilog 8500 series peripheral products (CIO, FIO, SCC, etc.) to the Z80 CPU is a little different from interfacing the Z80 peripherals to the CPU. The primary difference between the Z80-type peripherals and the 8500-type peripherals is in the interrupt acknowledge circuitry. Functionally, they are the same, as can be seen in the timing diagrams of Figure 15. However, the 8500 peripherals do not sample MI, RD, and IORO for the Interrupt acknowledge, but have an explicit INTACK pin to signal the interrupt acknowledge. Also, since the 8500 peripherals have a software reset for the interrupt under service filpflop, these devices do not require a special return opcode to do that operation. The user need only be concerned with the interrupt acknowledge timing when using the 8500-type peripherals. Figure 16 shows a circuit that provides wait states for the Z80 CPU interrupt acknowledge cycle in addition to INTACK generation. The INTACK generation of the INTACK generation of the INTACK generation of the INTACK generation of the INTACK generation. In each case, the 8500 peripheral component requires INTACK and RD to be active in order for the interrupt vector to be made available to the CPU. The logic shown provides for this. This circuitry also permits extended interrupt acknowledge times to allow for the dalsy chain propagation delay and the vector response delay, so that larger chains can be implemented. Figure 15. Timing for 8500 Peripherals During Interrupt Acknowledge. Figure 18. Interface Logic For Connecting 8500 Series Peripherals To Z80 System Interrupt (\*\*) During RESET A RESET to the Z80 CPU does several things as far as interrupts are concerned. The I register, which contains the upper eight bits of the 16-bit interrupt address value, Is reset to 0, and the Interrupt mode Is set to Mode 0. Maskable Interrupts are disabled until the programmer Instructs the CPU to execute an El instruction, Just as If a DI Instruction were executed. If an NMT occurs during the RESET operation, the CPU executes one instruction after the RESET condition and before acknowledging the NMT. Processing then continues as usual. SECTION Protocol reithe mutio the deiter: become terminate sele lii tw ch mo ch tei This # Using the Z80° SIO In Asynchronous Communications #### SECTION #### Introduction. The Z80 Serial Input/Output (SIO) controller is designed for use in a wide variety of serial-to-parallel input and parallel-to-serial output applications. In this application note, only asynchronous applications are considered. The emphasis is almost completely on software # Application Note implementation, with only modest reference to hardware considerations. While reference is made only to the Z80 SIO, the entire text also applies to the Z80 DART, which is functionally identical to the Z80 SIO in asynchronous applications. #### rotocol Communication, either on an external data link or to a local peripheral, occurs in one of two basic formats: synchronous or asynchronous. In synchronous communication, a message is sent as a continuous string of characters where the string is preceded and terminated by control characters; the preceding control characters are used by the receiving device to synchronize its clock with the transmitter's clock. In asynchronous communication, which is described in this application note, there is no attempt at synchronizing the clocks on the transmitting and receiving devices. Instead, each fixed-length character (rather than character string) is preceded and terminated by "framing bits" that identify the beginning and end of the character. The time between bits within a character is approximately constant, since the clocks or "baud rates" in the transmitter and receiver are selected to be the same, but the time between characters can vary. Thus, in asynchronous communication, each character to be transmitted is preceded by a "start" framing bit and followed by one or more "stop" framing bits. A start bit is a logical 0 and a stop bit is a logical 1. The receiver will look for a start bit, assemble the character up to the number of bits the SIO has been programmed for, and then expect to find a stop bit. The time between the start and stop bits is approximately constant, but the time between characters can vary. When one character ends, the receiving device will wait idly for the start of the next character while the transmitter continues to send stop or "marking" bits (both the stop bits and the marking bits are logical 1). Figure 1 illustrates this. A very common application of asynchronous communication is with keyboard devices, where the time between the operator's keystrokes can vary considerably. Figure 1. Asynchronous Data Format This application note refers to products as Z80 "A", "B" etc. to specify the speed grade. We are no longer using those characters for the speeds. For more details, please refer to the ordering information section. Reference Material ## Protocol (Continued) If the transmitter's clock is slightly faster than the receiver's clock, the transmitter can be programmed to send additional stop bits, which will allow the receiver to catch up. If the receiver runs slightly faster than the transmitter, then the receiver will see somewhat larger gaps between characters than the transmitter does, but the characters will normally still be received properly. This tolerance of minor frequency deviations is an important advantage of using asynchronous I/O. Note however that errors, called "framing errors," can still occur if the transmitter and receiver differ substantially in speed, since data bits may then be erroneously treated as start or stop bits. #### Modes The SIO may be used in one of three modes: Polled, Interrupt, or Block Transfer, depending on the capabilities of the CPU. In Polled mode the CPU reads a status register in the SIO periodically to determine if a data character has been received or is ready for transmission. When the SIO is ready, the CPU handles the transfer within its main program. In Interrupt mode, which is far more common, the SIO informs the CPU via an interrupt signal that a single-character transfer is required. To accomplish this, the CPU must be able to check for the presence of interrupt signals (or "interrupt requests") at the end of most instruction cycles. When the CPU detects an interrupt it branches to an interrupt service routine which handles the single-character transfer. The beginning memory address of this interrupt service routine can be derived, in part, from an "interrupt vector" (8-bit byte) supplied by the SIO during the interrupt acknowledge cycle. In Block Transfer mode, the SIO is used in conjunction with a DMA (direct memory access) controller or with the Z80 or Z8000 CPU block transfer instructions for very fast transfers. The SIO interrupts the CPU or DMA only when the first character of a message becomes available, and thereafter the SIO uses only its Wait/Ready output pin to signal its readiness for subsequent character transfers. Due to the faster transfer speeds achievable, Block Transfer mode is most commonly used in synchronous communication and only rarely in asynchronous formats. It is therefore not treated with specific examples in this application note. Since Polled mode requires CPU overhead regardless of whether or not an I/O device desires attention, Interrupt mode is usually the preferred alternative when it is supported by the CPU. Note that the choice of Polled or Interrupt mode is independent of the choice of synchronous or asynchronous I/O. This latter choice is usually determined by the type of device to which the system is communicating. ## SIO Configurations The SIO comes in four different 40-pin configurations: SIO/0, SIO/1, SIO/2, and SIO/9. The first three of these support two independent full-duplex channels, each with separate control and status registers used by the CPU to write control bytes and read status bytes. The SIO/9 differs from the first three versions in that it supports only one full-duplex channel. The product specifications for these versions explain this in full. There are 41 different signals needed for complete two-channel implementation in the SIO/0, SIO/1, and SIO/2, but only 40 pins are available. Therefore, the versions differ by either omitting one signal or bonding two signals together. The dual-channel asynchronous-only Z80 DART has the same pin configuration as the SIO/0. #### SIO-CPU Hardware Interfacing The serial-to-parallel and parallel-to-serial conversions required for serial I/O are performed automatically by the SIO. The device is connected to a CPU by an 8-bit bidirectional data path, plus interrupt and I/O control signals. The SIO was designed to interface easily to a Z80 CPU, as shown in Figure 2. Other microprocessors require a small amount of external logic to generate the necessary interface signals. The SIO provides a sophisticated vectoredinterrupt facility to signal events that require CPU intervention. The interrupt structure is based on the Z80 peripheral daisy chain. Non-Z80 microprocessors that are unable to utilize external vectored interrupts require some additional external logic to utilize efficiently this interrupt facility. Some non-Z80 system designs do not utilize the vectored interrupt structure of the SIO at all. Instead, these require the CPU to poll the SIO's status through the data bus or to use non-vectored SIO interrupts. Microprocessors such as the 8080 and 6800 need some signal translation logic to generate SIO read/write and clock timing. CPU signals which synchronize a peripheral device read or write operation are gated to form the proper I/O signals for the SIO. The SIO is selected by some processor-dependent function of the address bus in a memory or I/O addressing space. #### Reference Material In the next section we begin with a discussion of features common to all forms of asynchronous I/O. This is followed by discussions of polled asynchronous I/O and interrupt asynchronous I/O. Next is a series of frequently asked questions about the SIO when used in asynchronous applications. Finally, an example of a simple interrupt-driven asynchronous application is given and discussed in detail. For a complete understanding of the material covered, the following publications are needed: - Z80 SIO Product Specification or Z80 DART Product Specification - Z80 SIO Technical Manual - Z80 Family Program Interrupt Structure - Z80 CPU Technical Manual - Z80 Assembly Language Programming Figure 2. SIO Hardware Interfacing All of the SIO options to be discussed here are software controllable and are set by the CPU. Thus, use of the SIO begins with an initialization phase where the various options are set by writing control bytes. These options are established separately for each of the two channels supported by the SIO if both channels are used. Before giving an overview of how initialization is done, we will describe some of the basic characteristics of SIO operations that are common to both the Polled and Interrupt-driven modes. Addressing the SiO The CPU must have a means to identify any specific I/O device, including any attached SIO. In a Z80 CPU environment, this is done by using the lower 8 bits of the address bus (A<sub>0</sub>-A<sub>7</sub>). Typically, the A<sub>1</sub> bit is wired to the SIO's B/Ā input pin for selecting access to Channel A or Channel B, and the A<sub>0</sub> bit is wired to the SIO's C/D input pin for selecting the use of the data bus as an avenue for transferring control/status information (C) or actual data messages (D). The remaining bits of the address bus, A<sub>2</sub>-A<sub>7</sub>, contain a port address that uniquely identifies the SIO device. These latter six lines are usually wired to an external decoding chip which activates that SIO's Chip Enable (CE) input pin when its address appears on A<sub>2</sub>-A<sub>7</sub> of the address bus. The bar notation drawn above the names of certain signal lines, such as B/A and C/D, refer to signals which are interpreted as active when their logic sense—and voltage level—is Low. For example, the B/A pin specifies Channel B of the SIO when it carries a logic 1 (high voltage) and it specifies Channel A when it carries a logic 0 (low voltage). Asynchronous Format Operations Bits per Character. The SIO can receive or transmit 5, 6, 7, or 8 bits per character. This can be different for transmission and reception, and different for each channel. ASCII characters, for example, are usually transmitted as 7 bits. The SIO can in fact transmit fewer than 5 bits per character when set to the 5-bit mode; this is discussed further in the section entitled "Questions and Answers." Parity. A parity bit is an additional bit added to a character for error checking. The parity bit is set to 0 or 1 in order to make the total number of 1s in the character (including parity bit) even or odd, depending on whether even or odd parity is selected. The SIO can be set either to add an optional parity bit to the "bits per character" described above, or not to add such a bit. When a parity bit is included, either even or odd parity can be chosen. This selection can be made independently for each channel. Start and Stop Bits. There are two types of framing bits for each character: start and stop. When transmitting asynchronously, the SIO automatically inserts one start bit (logic 0) at the beginning of each character transmitted. The SIO can be programmed to set the number of stop bits inserted at the end of each character to either 1, 11/2, or 2. The receiver always checks for 1 stop bit. Stop bits refer to the length of time that the stop value, a logic 1, will be transmitted; thus 11/2 stop bits means that a 1 will be transmitted for the length of clock time that 11/2 bits would normally take up. A logic 1 level that continues after the specified number of stop bits is called a "marking" condition or "mark bits." CPU-SIO Character Transfers The SIO always passes 8-bit bytes to the CPU for each character received, no matter how many "bits per character" are specified in the SIO initialization phase. If the number of "bits per character" is less than eight, parity and/or stop bits will be included in the byte sent to the CPU. The received character starts with the least-significant bit (D<sub>0</sub>) and continues to the most-significant bit; it is immediately followed by the parity bit (if parity is enabled) and by the stop bit, which will be logic 1 unless there is a framing error. The remainder of the byte, if space is still available, is filled with logic 1s (marking). If the "bits per character" is eight, then the byte sent to the CPU will contain only the data bits. In all cases, the start bit is stripped off by the SIO and is not transmitted to the CPU. Clock Divider The SIO has five input pins for clock signals. One of these inputs (CLK) is used only for internal timing and does not affect transmission or reception rates. The other four clock inputs (RxCA, TxCA, RxCB, and TxCB) are used for timing the reception and transmission rates in Channels A and B. Only these last four are involved in "clock dividing." A clock divider within the SIO can be programmed to cause reception/transmission clocking at the actual input clock rate or at 1/16, 1/32, or 1/64 of the input clock rate. The receiver and transmitter clock divisions within a given channel must be the same, although their input clock rates can be different. The x1 clock rate can be used only if the transitions of the Receive clock are synchronized to occur during valid data bit times. Auto Enables Special Receive Conditions Modem Control 26-0003-0342 #### Auto Enables The SIO has an Auto Enables feature that allows automatic SIO response and telephone answering. When Auto Enables is set for a particular channel, a transition to logical 0 (Low input level) on the respective Data Carrier Detect (DCD) input will enable reception, and a transition to logical 0 on the respective Clear To Send (CTS) input will enable transmission. This is described below under the heading "Modem Control." #### Special Receive Conditions There are three error conditions that can occur when the SIO is receiving data. Each of these will cause a status bit to be set, and if operating in Interrupt mode, the SIO can optionally be programmed to interrupt the CPU on such an error. The error conditions are called "special receive conditions" and they include: - Framing error. If a stop bit is not detected in its correct location after the parity bit (if used) or after the most-significant data bit (if parity is not used), a framing error will result. The start bit preceding the character's data bits is not considered in determining a framing error, although character assembly will not begin until a start bit is detected. - Parity error. If parity bits are attached by the external I/O device and checked by the SIO while receiving characters, a parity error will occur whenever the number of logic I data bits in the character (including the parity bit) does not correspond to the odd/even setting of the parity-checking - Receiver overrun error. SIO buffers can hold up to three characters. If a character is received when the buffers are full (i.e., characters have not been read by the CPU), an SIO receiver overrun error will result. In this case, the most recently received character overwrites the next most recently received character. function. #### Modem Control Five signal lines on the SIO are provided for optional modem control, although these lines can also be used for other general-purpose control functions. They are: RTS (Request To Send). An output from the SIO to tell its modem that the SIO is ready to transmit data. DTR (Data Terminal Ready). An output from the SIO to tell its modem that the SIO is ready to receive data. CTS (Clear To Send). An input to the SIO from its modem that enables SIO transmission if the Auto Enables function is used. DCD (Data Carrier Detect). An input to the SIO from its modem that enables SIO reception if the Auto Enables function is used. SYNC (Synchronization). A spare input to the SIO in asynchronous applications. This input may be used for the Ring Indicator function, if necessary, or for general-purpose inputs. In most applications of asynchronous I/O that use modems, the RTS and DTR control lines and the Auto Enables function are activated during the initialization sequence, and they are left active until no further I/O is expected. This causes the SIO to tell its modem continuously that the SIO is ready to transmit and receive data, and it allows the modem to enable automatically the SIO's transmission and reception of data. Figure 3 illustrates this. Figure 3. Modem Control (Single Channel) A change in the status of certain external inputs to the SIO will cause status bits in the SIO to be set. In the Polled Mode, these status bits can be read by the CPU. In the Interrupt mode, the SIO can also be programmed to interrupt the CPU when the change occurs. There are three such "external/status" conditions that can cause these events: - DCD. Reflects the value of the DCD input. - **CTS.** Reflects the value of the CTS input. - Break. A series of logic 0 or "spacing" bits. Note that the DCD and CTS status bits are the inverse of the SIO lines, i.e., the DCD bit will be 1 when the $\overline{DCD}$ line is Low. Any transition in any direction (i.e., to logic 0 or to logic 1) on any of these inputs to the SIO will cause the related status bit to be latched and (optionally) cause an interrupt. The SIO status bits are latched after a transition on any one of them. The status must be reset (using an SIO command) before new transitions can be reflected in the status bits. ## SECTION 3 Character Reception R ь cl Cŧ bi cł ге ru the va Th the als wh De #### Initialization The SIO contains eight write registers for Channel B (WR0-WR7) and seven write registers for Channel A (all except write register WR2). These are described fully in the Z80 SIO Technical Manual and are summarized in Appendix B. The registers are programmed separately for each channel to configure the functional personality of the channel. WR2 exists only in the Channel B register set and contains the interrupt vector for both channels. Bits in each register are named D7 (most significant) through D0. With the exception of WRO, programming the write registers requires two bytes: the first byte is to WRO and contains pointer bits for selection of one of the other registers; the second byte is written to the register selected. WRO is a special case in that all of the basic commands can be written to it with a single byte. There are also three read registers, named RR0 through RR2, from which status results of operations can be read by the CPU (see Appendix B). Both channels have a set of read registers, but register RR2 exists only in Channel B. Let us now look at the typical sequence of write registers that are loaded to initialize the SIO for either Polled or Interrupt-driven asynchronous I/O. Figure 4 illustrates the sequence. Except for step E, this loading is done for each channel when both are used. Steps E and F are described further in the section on "Interrupt-Driven Environments." Registers WR6 and WR7 are not used in asynchronous I/O. They apply only to synchronous communication. The related publications on the SIO should be referred to at this point. They will be necessary in following the discussion of functions. In particular, the following material should be reviewed: Z80 SIO Technical Manual, pages 9-12 ("Asynchronous Operation") Z80 SIO Technical Manual, pages 29-37 ("Z80 SIO Programming") - A. Load WRO. This is done to reset the SiO. - B. Load WR4. This specifies the clock divider, number of stop bits, and parity selection. Since register WR4 establishes the general form of VO for which the SIO is to be used, it is best to set WR4 values lirst. - C. Load WR3. This specifies the number of receive bits per character, Auto Enable selection, and turns on the receiver enabling bit. - D. Load WR5. This specifies the number of transmit bits per character, turns off the bit that transmits the Break signal, turns on the bits indicating Data Terminal Ready and Request To Send, and turns on the transmitter enabling bit. - E. Load WR2. (Interrupt mode only and Channel B only.) This specifies the interrupt vector. - F. Load WR1. (interrupt mode only.) This specifies various interrupt-handling options that will be explained later. NOTES: Steps A through F are performed in sequence. \*Channel B only. \*Interrupt mode only. Politing mode begins I/O after step D. Figure 4. Typical Initialization Sequence (One Channel) #### SECTION #### Polled Environments. In a typical Polled environment, the SIO is initialized and then periodically checked for completion of an I/O operation. Of course, if the checking is not frequent enough, received characters may be lost or the transmitter may be operated at a slower data rate than that of which it is capable. Initialization for Polled I/O follows the general outline described in the last section. We now give an overview of routines necessary for the CPU to check whether a character has been received by the SIO or whether the SIO is ready to transmit a character. #### Character Reception To check whether a character has been received, and to obtain a received character if one is available, the sequence illustrated in Figure 5 should be followed after the SIO is initialized. We assume that reception was enabled during initialization; if it was not, the Rx Enable bit in register WR3 must be turned on before reception can occur. This must be done for each channel to be checked. Bit D<sub>0</sub> of register RR0 is set to 1 by the SIO if there is at least one character available to be received. The SIO contains a three-character input buffer for each channel, so more than one character may be available to be received. Removing the last available character from the read buffer for a particular channel turns off bit D<sub>0</sub>. If bit D<sub>0</sub> of register RR0 is 0, then no character is available to be received. In this case it is recommended that checks be made of bit D<sub>7</sub> to determine if a Break sequence (null character plus a framing error) has been received. If so, a Reset External/Status Interrupts command should be given; this will set the External/Status bits in register RR0 to the values of the signals currently being received. Thus, if the Break sequence has terminated, the next check of bit D<sub>7</sub> will so indicate. It may also be desirable to check bit 3 of register RR0 which reports the value of the Data Carrier Detect (DCD) bit. In any case, if bit $D_0$ of register RR0 is 0, polled receive processing terminates with no character to receive. Depending on the facilities of the associated CPU, this step may be repeated until a character is available (or possibly a time-out occurs), or the CPU may return to other tasks and repeat this process later. If bit $D_0$ of register RR0 is 1, then at least one character is available to be read. In this case, the value of register RR1 should first be read and stored to avoid losing any error information (the manner in which it is read is explained later). The character in the data register is then read. Note that the character must be read to clear the buffer even if there is an error found. Finally, it is necessary to check the value stored from register RR1 to determine if the character received was valid. Up to three bits need to be checked: bit 6 is set to 1 for a framing error, bit 5 is set to 1 for a receiver overrun error (which occurs when the receive buffers are overwritten, i.e., no character has been removed and more than three characters have been received), and bit 4 is set to 1 for a parity error (if parity is enabled at initialization time). In case of a receiver overrun or parity error, an Error Reset command must be given to reset the bits. Figure 5. Polled Receive Routine #### Character Transmission To check that an initialized SIO is ready to transmit a character on a channel, and if so to transmit the character, the steps illustrated in Figure 6 should be followed. We assume that the Request To Send (RTS) bit in WR5, if required by the external receiving device, and the Transmit (Tx) Enable bit were set at initialization. Depending on the external receiving device, the following bits in register RRO should be checked: bit 3 (DCD), to determine if a data carrier has been detected; bit 5 (CTS), to determine if the device has signalled that it is clear to send; and bit 7 (Break), to determine if a Break sequence has been received. If any of these situations have occurred, the bits in register RRO must be reset by sending the Reset External/Status Interrupts command, and the transmit sequence must be started again. Next, bit 2 of register RR0 is checked. If this bit is 0, then the transmit buffer is not empty and a new character cannot yet be transmitted. Depending on the capabilities of the CPU, this is repeated until a character can be transmitted (or a timeout occurs), or the CPU may return to other tasks and start again later. If bit 2 of register RR0 is 1, then the transmit buffer is empty and the CPU may pass the character to be transmitted to the SIO, completing the transmit processing. On the Z80 CPU, this is done with an OUT instruction to the SIO data port. Figure 6. Polled Transmit # Assumptions for an Example Now let us consider some examples in more detail. We assume we are given an external device to which we will input and output 8-bit characters, with odd parity, using the Auto Enables feature. We will support this device with I/O polling routines following the patterns illustrated in Figures 5 and 6. We assume that the CPU will provide space to receive characters from the SIO as fast as the characters are received by the SIO, and that the CPU will transfer characters as fast as the output can be accomplished by the SIO. We specify this example by giving the control bytes (commands) written to the SIO and the status bytes that must be read from the SIO. Recall that to write a command to a register, except register WRO, the number of the register to be written is first sent to register WRO; the following byte will be sent to the named register. Similarly, to read a register other than RRO (the default), the number of the register to be read is sent to register WRO; the following byte will return the register named. #### Initialization We begin with the initialization code for the SIO. This follows the outline illustrated in Figure 4. In the following sample code, each time register WRO is changed to point to another register, the Reset External/Status Interrupts command is given simultaneously. Whenever a transition on any of the external lines occurs, the bits reporting such a transition are latched until the Reset External/Status Interrupts command is given. Up to two transitions can be remembered by the SIO. Therefore, it is desirable to do at least two different Reset External/Status Interrupts commands as late as possible in the initialization so that the status bits reflect the most recent information. Since it doesn't hurt, we include these commands each time WR0 is changed to point to another register. This is an easy way to code the initialization to insure that the appropriate resets occur. In the example below, the logic states on the $C/\overline{D}$ control line and the system data bus $(D_7-D_0)$ are illustrated, together with comments. #### Initialization (Continued) | ) | C/D | D <sub>7</sub> | |---|-----|----------------| | | 1 | Ô | | | 1 | 0 | | | | | | | 1 | 1 | | | | | | | 1 | 0 | | | 1 | 1 | | | | ŕ, | | | 1 | 0 | | | | | | | 1 | 1 | | | | • | #### Reset and Error Sequences In the relow, we tre Data Carrie sequence" RRO to reflet the pins. The Reset Emand and the comma register WF | D <sub>7</sub> | D <sub>6</sub> | |----------------|----------------| | 0 | 0 | | | احجسما | Permits the sta This comr for such thin 4-6 of regist occurs and #### Receive and Transmit Routines Now we w of the receiv preceding d Reception." The framii Initialization (Continued) | C/D | D <sub>7</sub> | D <sub>6</sub> | Bit<br>D <sub>S</sub> | s sent<br>D <sub>4</sub> | to the<br>D <sub>3</sub> | | D <sub>1</sub> | D <sub>0</sub> | |-----|----------------|----------------|-----------------------|--------------------------|--------------------------|---|----------------|----------------| | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | | . • | | | | | | | | | | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | | , | | 45. | | | | | | | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | | | ٠ | | | | | | | | 1 | 0 | 0 | ٥ | 1 | 0 | 1 | 0 | 1 | | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | #### Effects and Comments Channel Reset command sent to register WR0 (D5-D3). Point WR0 to WR4 (D<sub>2</sub>-D<sub>0</sub>) and issue a Reset External/ Status Interrupts command (D<sub>5</sub>-D<sub>3</sub>). Throughout the initialization, whenever we point WR0 to another register, we will also issue this command for the reasons noted above. Set WR4 to indicate the following parameters (from left to right): - A. Run at 1/64 the input clock rate ( $D_7$ - $D_6$ ). - B. Disable the sync bits and send out 2 stop bits per character (D<sub>5</sub>-D<sub>2</sub>). - C. Enable odd parity (D1-D0). Point WR0 to WR3. Set WR3 to indicate the following: - A. 8-bit characters to be received (D<sub>7</sub>-D<sub>6</sub>). - B. Auto Enables on (D<sub>5</sub>). - C. Receive (Rx) Enable on (Do). Point WR0 to WR5. Set WR5 to indicate the following: - A. Data Terminal Ready (DTR) on (D7). - B. 8-bit characters to be transmitted (D6-D5). - C. Break not to be transmitted (D<sub>4</sub>). - D. Transmit (Tx) Enable on (D3). - E. Request To Send (RTS) on (D1). Reset and Error Sequences In the receive and transmit routines that follow, we treat errors such as a transition on the Data Carrier Detect line by calling for a "reset sequence" to set the values in read register RR0 to reflect the current values found at the pins. This sequence consists of giving the Reset External/Status Interrupts command and beginning the driver over again. The command takes the form of a write to register WR0: | | | | | | D <sub>2</sub> | | | |---|---|---|---|---|----------------|---|----| | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0. | Permits the status bits in RRO to reflect current status. This command does not turn off the latches for such things as parity errors stored in bits 4-6 of register RR1. When such an error occurs and the latches must be reset, we will call for an "error sequence." This sequence consists of giving the Error Reset command and beginning the driver over again. The command also takes the form of a write to register WRO: | | | | D <sub>4</sub> | | | | | |---|---|---|----------------|---|---|---|---| | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | Resets the latches in register RRI. When specifying the result of reading register RRO or RR1 or specifying data, we will indicate the values read as follows: | | | | $D_4$ | | | | | |---|---|---|-------|---|---|---|---| | D | D | D | D | D | D | D | D | Read a byte from the designated register.. Receive and Transmit Routines Now we will first give an example of the receive routine. This parallels the preceding discussion of "Character Reception." The framing error in this routine is reported on a character-by-character basis and it is not necessary to execute an "error sequence" if it is the only error received. However, it is not harmful to do so. Next, we give an example of transmission code that parallels the above discussion on "Character Transmission." Receive and Transmit Routines (Continued) | C/D | D <sub>7</sub> | D <sub>8</sub> | Bits<br>D <sub>5</sub> | sent c | nd rec | | Dı | D <sub>0</sub> | |-----|----------------|----------------|------------------------|----------------|----------------|----------------|----|----------------| | į | D | D | D | D | D | D | ·D | D | | | | | | | , | | | | | . 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | | | 4. | | | | | 1 | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4 | D <sub>3</sub> | D <sub>2</sub> | Dì | D <sub>0</sub> | | ` ' | | | | | | | | , | | 0 | D <sub>7</sub> | $D_6$ | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | Di | D <sub>0</sub> | #### Effects and Comments (Receive Routine) Read a byte from RRO (the default read register); if $D_0 = 0$ then no character is ready to be received. In this case, if $D_7$ (Break) or $D_3$ (Data Carrier Detect) have changed state, then execute a "reset sequence." If $D_0 = 0$ and $D_7$ and $D_3$ have not changed state, then no character is ready to be received; either loop on this read or try again later. Point WR0 to read from RR1; we will now check for errors in the character read. Note that Reset External/Status Interrupt Commands are not done normally to avoid losing a line-status change. Read a byte from RR1; if either bit $D_6=1$ (framing error), $D_5=$ (receive overrun error), or $D_4=1$ (parity error), the character is invalid and an "error sequence" should be executed after the following step. Read in the data byte received. This must be done to clear the SIO buffer even if an error is detected. | C/D | $D_7$ | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | $D_1$ | DG | |-----|-------|----------------|----------------|----------------|----------------|----------------|-------|----| | 1 | D | D | D | D | D | D | D | D | | | 4 | | | | | | | | | 0 - | D | D | D | D | D | D | D | D | Bits sent and received #### Effects and Comments (Transmit Routine) Read a byte from RR0; if either bit $D_3$ (Data Carrier Detect), $D_5$ (Clear To Send) or $D_7$ (Break) have changed state, a "reset sequence" should be executed. If $D_3$ , $D_5$ and $D_7$ have not changed state, then if $D_2 \! = \! 0$ , the transmit buffer is not yet empty and a transmit cannot take place; either loop, reading RR0, or try again later. Send the data byte to be transmitted. SECTION #### Interrupt-Driven Environments. In a typical interrupt-driven environment, the SIO is initialized and the first transmission, if any, is begun. Thereafter, further I/O is interrupt driven. When action by the CPU is needed, an SIO interrupt causes the CPU to branch to an interrupt service routine after the CPU first saves state information. In common usage, if I/O is interrupt driven, all interrupts are enabled and each different type of interrupt is used to cause a CPU branch to a different memory address. There is perhaps one frequent exception to this: parity errors are sometimes checked only at the end of a sequence of characters. The SIO facilitates this kind of operation since the parity error bit in read register RR1 is latched; once the bit is set it is not reset until an explicit reset operation is done. Thus, if a parity error has occurred on any character since last reset, bit 4 in register RR1 will be set. It is then possible to set register WR1 so that parity errors do not cause an error interrupt when a character is received. The user then has the obligation to poll for the value of the parity bit upon completion of the sequence. SIO initialization for Interrupt mode normally requires two steps not used in Polled mode: an interrupt vector (if used) must be stored in write register WR2 of Channel B and write register WR1 must be initialized to specify the form of interrupt handling. It is preferable to initialize the interrupt vector in WR2 first. In this way an interrupt that arrives after the enabling bits are set in WR1 will cause proper interrupt servicing. Interrupt Vectors The interrupt vector, register WR2 of Channel B, is an 8-bit memory address. When an interrupt occurs (and note that an interrupt can only occur after interrupts have been enabled by writing to register WR1) the interrupt vector is normally taken as one byte of an address used by the CPU to find the location of the interrupt service routine. It is also possible to cause the particular type of interrupt condition to modify the address vector in WR2 before branching, resulting in a branch to a different memory location for each interrupt condition. This is a very useful construct; it permits short, special-purpose interrupt routines. The alternative, to have one generalpurpose interrupt routine which must determine the situation before proceeding, can be quite inefficient. This is usually undesirable since the speed of interrupt-service routines is often a critical factor in determining system performance. Interrupt Vectors (Continued) > WRl an ir the t chan rupt. prior prior Chan 3-1 Chan to 1 Chan: to 1 Chani 3-1 Chanr 3-1 Chanr. ta 0 Chann to Ot Chann 3-1 t For ( tor hac Affects interru transiti Tł inter each. ### Initialization After conthe same necessary of Chan register to be en interrup. Now leasangle device to characte Enables provide We do registers Technica bit assigi Input/Ou at the en (bits 3- an inte the inte tained l In ge illustrat six step Interrupt Vectors (Continued) There are at most eight different types of interrupts that the SIO may cause, four for each of the two channels. If bit 1 in register WR1 of Channel B has been turned on so that an interrupt will modify the interrupt vector, the three bits (1-3) of the vector will be changed to reflect the particular type of interrupt. These interrupts follow a hardware-set priority as follows, starting with the highest priority: Channel A Special Receive Condition sets bits 3-1 of WR1 to 111, Channel A Character Received sets bits 3-1 to 110. Channel A Transmit Buffer Empty sets bits 3-1 to 100. Channel A External/Status Transition sets bits 3-1 to 101. Channel B Special Receive Condition sets bits 3-1 to 011, Channel B Character Received sets bits 3-1 to 010. Channel B Transmit Buffer Empty sets bits 3-1 to 000. Channel B External/Status Transition sets bits For example, suppose that the interrupt vector had the value 11110001 and the Status Affects Vector bit is enabled, along with all interrupt-enable bits. When an External/Status transition occurs in Channel A, the three zeros (bits 3-1) would be modified to 101, yielding an interrupt vector of 11111011. The value of the interrupt vector, as modified, may be tained by reading register RR2 in Channel B. Note that when a character is received, either the Special Receive Condition or Rx Character Available interrupt will occur, depending on whether or not an error occurred; the two will never occur simultaneously. Therefore, these two interrupts have equal priority. Note also that you can select not to be interrupted on some of the eight conditions; in this case, the presence of a particular condition for which interrupts are not desired can be determined by polling. Suppose that interrupts have been enabled for all possible cases, and that the Status Affects Vector bit has also been enabled, allowing a different routine to handle each possible interrupt. As each interrupt causes a branch to a location only two bytes higher than the last interrupt, it is not possible to place a routine directly at the location where the vectored interrupt branches. In a Z80 CPU environment, these addresses refer to a table in memory which contains the actual starting location of the interrupt service routine. Also, since the state information saved by a CPU is rarely all of the information necessary to properly preserve a computation state, a typical interrupt service routine will begin by saving additional information and end by restoring that information. This is shown briefly in the examples of code in Appendix A. It is possible to connect several SIOs using the interrupt mechanism and the IEI and IEO lines on the SIO to determine a priority for interrupt service. This mechanism is discussed on page 42 of the Z80 SIO Technical Manual and in the Z80 Family Program Interrupt Structure Manual. We do not go into it further in this application note. Initialization In general, the initialization procedure illustrated in Figure 4 can still be followed. All six steps (A through F) are required here. After completing the first four steps, which are the same as initialization for polled I/O, it is necessary to load an interrupt vector into WR2 of Channel B. Information is then written into register WR1 specifying which interrupts are to be enabled and whether a specific kind of interrupt should modify the interrupt vector. Now let us give an example. As in the polled example, we assume that we are given a device to which we will input and output 8-bit characters, with odd parity, using the Auto Enables feature. We also assume the CPU will provide space to store characters as received. We do not discuss the SIO commands and registers in detail. This is done in the Z80 SIO Technical Manual. A summary of the register bit assignments taken from the Z80 SIO Serial Input/Output Product Specification is included at the end of this note. Recall that to write a register other than register WR0, the number of the register to be written is first sent to register WR0, and the following byte will be sent to the named register. Similarly, to read a register other than RR0 (the default), the number of the register to be read is first written to register WR0 and the next byte read will return the contents of the register named. In our example below, each time register WRO is changed to point to another register, the Reset External/Status Interrupts command is also given. Whenever a transition on any of the external/status lines occurs, the bits reporting the transition are latched until the Reset External/Status Interrupts command is given. Up to two transitions can be remembered by the internal logic of the SIO. Therefore, it is desirable to do at least two different Reset External/Status Interrupt commands as late as possible in the initialization so that the status bits reflect the most recent information. Since it doesn't hurt, we give these commands each #### Initialization (Continued) time WR0 is changed to point to another register. This is an easy way to code the initialization to assure that the appropriate resets occur. The columns below show the logic states on the $C/\overline{D}$ control line and the system data bus (D7-D0), together with comments. | C/D | D <sub>7</sub> | De | D <sub>5</sub> | its sen<br>D4 | SIO<br>D <sub>2</sub> | Dı | D <sub>0</sub> | | |-----|----------------|----|----------------|------------------|-----------------------|-----|----------------|-----| | 1 | 0 | 0 | 0 | i | 1 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 1 | 0 | . 1 | 0 | 0 | | | | | | | | | | | | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | | | | | | | | | | | | 1 | 0 | 0 | 0 | 1 | 0, | 0 | 1 | 1 | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | | | , | | | | | | 1 | | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | | | | | | | ,<br>, | | - | | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 . | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | * * * | 14<br>2<br>14 14 | | | | | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | #### Effects and Comments Channel Reset command sent to register WR0 (D5-D3). Point WR0 to WR4 (D2-D0) and issue a Reset External/Status Interrupts command (D5-D3). Throughout the initialization, whenever we point WRO to another register we will also issue a Reset External/Status Interrupts command for the reasons noted above. Set WR4 to indicate the following parameters (from left to right): - A. Run at 1/64 the clock rate (D7-D6). - B. Disable the sync bits and send out 2 stop bits per character (D5-D2). - C. Enable odd parity (D1-D0). Point WR0 to WR3. Set WR3 to indicate the following: - A. 8-bit characters to be received (D7-D6). - B. Auto Enables on (D<sub>5</sub>). - C. Rx Enable on (D<sub>0</sub>). Point WR0 to WR5. - Set WR5 to indicate the following: A. Data Terminal Ready (DTR) on (D7). - B. 8-bit characters to be transmitted (D6-D5). - C. Break not to be transmitted (D<sub>4</sub>). - D. Tx Enable on (D<sub>3</sub>). - E. Request To Send (RTS) on (D1). Point WR0 to WR2 (Channel B only). Set the interrupt vector to point to address 11100000 (which is hex E0 and decimal 224). Once interrupts are enabled, they will cause a branch to this memory location, modified as described above if the Status Affects Vector bit is turned on (which it will be here). This vector is only set for Channel B, but it applies to both channels. It has no effect when set in Channel A. Point WR0 to WR1. Set WR1 to indicate the following: - A. Cause interrupts on all characters received, treating a parity error as a Special Receive - Condition interrupt (D<sub>4</sub>-D<sub>3</sub>). B. Turn on the Status Affects Vector feature, causing interrupts to modify the status vector-meaningful only on Channel B, but will not hurt if set lor Channel A (D<sub>2</sub>). - C. Enable interrupts due to transmit buffer being empty $(D_1)$ . - D. Enable External/Status interrupts (D<sub>0</sub>). gic states on as m data bus RO (D<sub>5</sub>-D<sub>3</sub>). et Exteriroughout to another Status s (from left p bits per 0000 rrupts nemory tatus e here). iusing Ingful r | <b>Z80</b> | SlOrecint: | PUSH | AF ;save registers which will be used in this routine | | |-------------------|------------|-----------|--------------------------------------------------------------------------------|--| | Assembler<br>Code | • • | IN<br>LD | A,(SlOdeta) : fetch the character received (X) ,A : store result for later use | | | (Continued) | | POP<br>El | AF ; restore saved registers ; enable interrupts | | | No. | | RETI | return from interrupt | | Of course, this last routine is probably far too simple to be useful. It is more likely that an interrupt routine will fill up a buffer of characters. A more complex example of a receive interrupt routine is contained in the SlOextint: PUSH AF LD A,00010000B OUT (SlOctrl), A IN A,(SlOctrl) LD (X), A POP AF AF . chapter entitled "A Longer Example." We now give a simple interrupt routine for an External/Status Interrupt, again assuming that the status contents of SIO register RRO are stored in temporary location X: ;save registers which will be used in this routine ;send a Reset External/Status Interrupts command routine which would transmit a buffer-full of information at a time. A more complex exam- ple is included in the section entitled "A :fetch register RRO ;store result for later analysis :restore saved registers ;enable interrupts ;return from interrupt Finally, we give the processing for a transmit interrupt routine in the case where no more characters are to be transmitted. It is likely that this code would just be a portion of a more general transmit interrupt SlOtrnint: PUSH AF LD A,00101000B OUT (SlOctrl) ,A POP AF EI RETI RETI Longer Example." ;save registers which will be used in this routine ;send a Reset Tx Interrupt Pending command restore saved registers; Enable Interrupts; Return From Interrupt #### SECTION #### Questions and Answers. #### 5 Q: Can a sloppy system clock cause problems in SIO operation? #### Hardware Considerations - A: Yes; the specifications for the system clock are very tight and must be met closely to prevent SIO malfunction. The clock high voltage must be greater than V<sub>CC</sub> 0.6V but less than +5.5V. The clock low voltage must be greater than –0.3V but less than +0.45V. The transitions between these two levels must be made in less than 30 ns. This does not apply to the RxC and TxC inputs which are standard TTL levels. - Q: When is a received character available to be read? - A: Data will be available a maximum of 13 system clock cycles from the rising edge of the RxC signal which samples the last bit of the data. - Q: What is the maximum time between character-insertion for transmission and next-character transmission? - A: This will vary depending on the speed of the line over which the character is being transmitted. - Q: Are the control lines to the SIO synchronous with the system clock so that noise may exist on the buses any time before setup requirements are satisfied? - A: Yes. - Q: In asynchronous use must receiver and transmitter clock rates be the same? - A: No, the SIO allows receive and transmit for each channel to use a different clock (thus up to four different clocks for receiving and transmitting data can be used on each SIO). However, the clock multiplier for each channel must be the same. - Q: Do Wait states have to be added when using the SIO with other processors other than the Z80 CPU? - A: No, provided that setup times specified for the SIO are met. - Q: If the Auto Enables bit in register WR3 is set, will a change in state on the DCD (Data Carrier Detect) or CTS (Clear To Send) lines still cause an interrupt? - A: Yes, provided that External/Status Interrupts are enabled (bit 0 in register WR1). - Q: Is the MI line used by the SIO if no interrupts are enabled? - A: No, and in this case the MI input should be tied high. - Q: Will the SIO continue to interrupt for a condition if the condition persists and the interrupt remains enabled? - A: Yes. - Q: What is the maximum data rate of the SIO? - A: It is 1/5 the rate of the system clock (CLK). For example, if the system clock operates at 4 MHz, the SlO's maximum transfer rate is 800K bits (100K bytes) per second. - Q: What pins are edge sensitive and should be strapped to avoid strange interrupts? - A: The external synchronization (SYNC) pins and any other external status pins that are not used, including CTS, and DCD. - Q: What happens if the transmitter or receiver is disabled, while processing a character, by turning off its associated enable bit (bit 3 in register WR5 for transmit or bit 0 in register WR3 for receive)? - A: The transmitter will complete the character transmission in an orderly fashion. The receiver, however, will not finish. It will lose the character being received and no interrupt will occur. #### Register Contents - Q: Does the Tx Buffer Empty (bit 2 in register RR0 get set when the last byte in the buffer is in the process of being shifted out? - A: No. The bit is set when the transmit buffer has already become empty. Similarly, the Tx Buffer Empty interrupt will not occur until the buffer is empty. The same is true for reception: the Rx Character Available bit (bit 0 in register RR0) is not set until the entire character is in the receive buffer, and the Rx Character Available interrupt will not occur until the entire character has been moved into the buffer. - Q: If an Rx Overrun error occurs (and bit 5 of register RR1 becomes latched on) because a new character has arrived, which character gets lost? - A: The most recently received character overwrites the next most recently received character. - Q: Does the Reset External/Status Interrupts command reset any of the status bits in register RR0? - A: No. However, when a transition occurs on any of the five External/Status bits in register RRO, all of the status bits are latched in their current position until a Reset External/Status Interrupts command is issued. Thus, the command does permit the appropriate bits of register RRO to reflect the current signal values and should be done immediately after processing each transition on the channel. ecified for r WR3 is CD (Data Send) s Inter-WR1). no inter- should t for a ad the ck lock um s) pi VC) pins g a ed transmit fashion. h. It will d no ter eived errupts in curs on la nand is mit the flect be ich Special Receive Condition Interrupts A Special Receive Condition interrupt occurs (a) if a parity error has occurred, (b) if there is a receiver overrun error (data is being overwritten because the channel's three-byte receiver buffer is full and a new character is being received), or (c) if there is a framing error. The processing in this case is the following: - 1. Issue an Error Reset command (to register WR0) to reset the latches in register RR1. - Read the character from the read buffer and discard it to empty the buffer. It may be desirable to read and store the value of register RR1 to gather statistics on performance or determine whether to accept the character. In some applications, a character may still be acceptable if received with a framing error. In specifying the result of reading register RRO, RR1, or specifying data, we will indicate the values as follows: | • | • | • | | | _ | Dı | | |---|---|---|---|---|----|----|---| | D | D | D | D | D | Ď. | D | D | Read a byte from the designated register. We now present an example of processing a Special Receive Condition interrupt. | Bits sent and received | | | | | | | | | |------------------------|----------------|----|----------------|----------------|----------------|----------------|-------|----------------| | C/D | D <sub>7</sub> | Dg | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | Dı | D <sub>0</sub> | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | | | Ĺ | | | | | | 1 | D | D | D | D | D | D | D | D | | | | | | | | _ | | | | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | | | | 0 | ם | ם | ו מו | ח | ם | מ | l o i | D. | #### Effects and Comments If we need to know what kind of error occurred, we point WRO to read from RR1. Note that the Reset External/Status Interrups command is not used. This avoids losing a valid interrupt. Read a byte from RR1; one or more of bit $D_6$ (framing error), $D_5$ (receive overrun error), or $D_4$ (parity error) will be 1 to indicate the specific error. Give an Error Reset command to reset all the error latches. Read in the data byte received. This must be done to clear the receiver buffer, but the character will generally be disregerded. Received (Rx) Character Interrupts When an Rx Character Available interrupt occurs, the character need only be read from the read buffer and stored. If parity is enabled with character lengths of 5, 6, or 7 bits, the received parity bit will be transferred with the character. Any unused bits will be 1s. External/ Status Interrupts To respond to an External/Status Interrupt, all that is necessary is to send a Reset External/Status Interrupts command. However, if you wish to find the specific cause of the interrupt, it is necessary to read register RRO. In this case, the complete processing takes the following form: | Bits sent and received | | | | | | | | | | | |------------------------|----------------|----------------|----------------|----------------|----------------|----------------|-------|----------------|--|--| | C/D | D <sub>7</sub> | D <sub>8</sub> | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ | $D_0$ | | | | 1 | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | $D_1$ | D <sub>0</sub> | | | | | | | | | | | | | | | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | #### Effects and Comments Read register RR0; bit $D_7$ (Break), $D_5$ (Clear To Send), or $D_3$ (Data Carrier Detect) will have had a transition to indicate the cause of the interrupt. Give a Reset External/Status Interrupts command to set the latches in RRO to their current values and stop External/Status Interrupts until another transition occurs. Transmit (Tx) Buffer Empty Interrupts The final kind of interrupt is a Tx Buffer Empty interrupt. If another character is ready to be transmitted on this channel, a Tx Buffer Empty interrupt indicates that it is time to do so. To respond to this interrupt, you need only send the next character. If no other character is ready to transmit, it may be desirable to mark the availability of the transmit mechanism for future use. In addition, you should send a Reset Tx Interrupt Pending command. This command prevents further transmitter inter- rupts until the next character has been loaded into the transmitter buffer. The Reset Tx Interrupt Pending command to WRO takes the following form: D7 D6 D5 D4 D3 D2 D1 D0 0 0 1 0 1 0 0 0 0 Reset Tx Interrupt Pending command; no Tx Empty Interrupts will be given until after the next character has been placed in the transmit buffer. #### Z80 Assembler Code To take these examples further, let us use Z80 Assembler code to implement the routines for a single channel. We assume that the location stored in register WR2 points to the appropriate interrupt service routine. We also assume that the following constants have already been defined: **SIOctrl.** The address of the SIO's Channel B control port (we assume Channel B in order to include code to initialize the interrupt vector). **SIOdata.** The address of the SIO's Channel B data port. X. An address pointing to locations in memory that will be used to store various values. We will write data as binary constants; the "B" suffix indicates this. In most cases, binary constants will be referred to by the command names. We begin with the initialization routine: This is followed by a simple receive interrupt routine that will fetch the character received and store it in a temporary location. | | INIT: | LD | C,SlOctrl | ;place the address of the SIO in the C register for ; use in subsequent output | |-----|-------|------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | | | LD<br>OUT | A,00011000B<br>(C) ,A | load Channel Reset command in A register give Channel Reset command | | e . | | LD<br>OUT<br>LD<br>OUT | A,00010100B<br>(C) ,A<br>A,11001101B<br>(C) ,A | ;write to register WR0 pointing it to register WR4 ;output basic I/O parameters to WR4 | | | | LD<br>OUT<br>LD<br>OUT | A,00010011B<br>(C) ,A<br>A,11100001B<br>(C) ,A | ;write to register WR0 pointing it to register WR3 ;output receive parameters to WR3 | | | | LD<br>OUT<br>LD<br>OUT | A,00010101B<br>(C) ,A<br>A,11101010B<br>(C) ,A | ;write to register WR0 pointing it to register WR5 ;output transmit parameters to WR5 | | | | LD<br>OUT<br>LD | A,00010010B<br>(C) ,A<br>A,11100000B | ;write to register WR0 pointing it to register WR2; (Channel B only) ;output the interrupt vector to WR2; in this case it is | | | | OUT | (C) ,A | ; decimal location 224 | | | . • | LD<br>OUT<br>LD<br>OUT | A,00010001B<br>(C) ,A<br>A,00010111B<br>(C) ,A | ;write to register WR0 pointing it to register WR1 ;output interrupt parameters to WR1 | | | | RET | , | ;return from initialization routine | Now let us look first at some sample codes for the Special Receive Condition interrupt routine, following the example above. | SlOspecint: | PUSH | AF | ;save registers which will be used in this routine | |-------------|-----------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LD | A,00000001B<br>(SIOctrl) .A | ;write to register WR0 pointing it to register RR1 | | | IN<br>LD | A,(SlOctrl)<br>(X),A | ; fetch register RR1<br>; store result for later error analysis | | | LD | A,00110000B | send an Error Reset command to reset dévice ; latches | | • | OUT | (SlOctrl) ,A | and the second s | | | IN | A,(SlOdata) | ;letch the character received—we will discard this<br>; character since an error occurred during its<br>; reception | | | POP<br>El | AF | restore saved registers; enable interrupts | | | RETI | | return from Interrupt | el B Special Uses nory ary - Q: If the CPU does not have the return from interrupt sequence (RETI instruction on the Z80 CPU), how may the SIO be informed of the completion of interrupt handling? - A: This may be done by writing the Return From Interrupt command (binary, 00111000) to WRO in Channel A of the SIO. - Q. If the CPU can be interrupted but cannot be used with vectored interrupts, how should processing be done? - A: Immediately after being interrupted, proceed in a manner similar to polling the SIO for both receive and transmit. Alternatively, the Status Affects Vector bit (bit 2 in register WR1) may be set and a 0 byte placed into the interrupt vector (register WR2 in Channel B). Then, the contents of the interrupt vector can be used to determine the cause of the interrupt and the channel on which the interrupt occurred. This can be queried by reading register RR1 of Channel B. Also, M1 should be tied High and no equivalent to an interrupt acknowledge should be issued. - Q: How can the Wait/Ready (W/RDY) signal be used by the CPU in asynchronous I/O? - A: The W/RDY signal is most commonly used in Block Transfer Mode with a DMA, and this use is described in the Z80 DMA Technical Manual. However, W/RDY may be directly connected to the Z80 CPU WAIT line in order to use the block I/O instructions OTDR, OTIR, INDR, and INIR. In this case, the SIO can be used for block transfer reception. To do this, the SIO is configured to interrupt on the first character received only (by settings bits 4 and 3 of register WR1 to 01) and additional characters are sensed using the W/RDY line. The block I/O instructions decrement a byte counter to determine when I/O is complete. - Q: Can the SYNC pin have any use in asynchronous I/O? - A: It may be used as a general-purpose input. For example, by connecting it to a modem ring indicator, the status of that ring indicator can be monitored by the CPU. - Q: How can the SIO be used to transmit characters containing fewer than 5 bits? - A: First, set bits 6 and 5 in register WR5 to indicate that five or fewer bits per character will be transmitted. The SIO then determines the number of bits to actually transmit from the data byte itself. The data byte should consist of zero or more 1s, three 0s, and the data byte with 11110001 will cause only the last bit to be transmitted: ## Contents of data byte (d = arbitrary value) | D <sub>7</sub> | $\dot{D}_6$ | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ | D <sub>0</sub> | | |----------------|-------------|-------|-------|-------|-------|-------|----------------|-----| | ľ | 1 | 1 | 1 | Õ | 0 | 0 | ď | 1 | | 1 | 1 | 1 | 0 | 0 | 0 | d | ď | 2 | | 1 | 1 | 0 | 0 | 0 | ď | d | d | 3 - | | 1 | 0 | 0 | 0 | d | d | d. | d | 4 | | 0 | 0 | 0 | d | ď | ď | ď | d | 5 | \*The rightmost number of bits indicated will be transmitted. - **Q:** Can a Break sequence be sent for a fixed number of character periods? - A: Yes. Break is continuously transmitted as logic 0 by setting bit 4 of register WR5. You can then send characters to the transmitter as long as the Break level is desired to persist. A Break signal, rather than the characters sent, will actually be transmitted, but each bit of each character sent will be clocked as if it were transmitted. The All Sent bit, bit 0 of register RR1, is set to 1 when the last bit of a character is clocked for transmission, and this may be used to determine when to reset bit 4 of register WR5 and stop the Break signal. - Q: If a Break sequence is initiated by setting bit 4 of register WR5, will any character in the process of being transmitted be completed? - A: No. Break is effective immediately when bit 4 of WR5 is set. The "all sent" bit in register RR1 should be monitored to determine when it is safe to initiate a Break sequence. 6 #### A Longer Example. In this section, we give a longer example of asynchronous interrupt-driven full-duplex I/O using the SIO. The code for this example is contained in Appendix A, and the basic routines are flow charted in Figures 7-12. The example includes code for initialization of the SIO, initialization of a receive buffer interrupt routine, and a transfer routine which causes a buffer of up to 80 characters of information to be transmitted on Channel A and a buffer of up to 80 characters of information to be received from Channel A. The transfer routine stops when either all data is received or an error occurs. Completion of an operation on a buffer for both receive and transmit is indicated by a carriage return character. Additional routines (not included in this example) would be needed to call the initialization code and initiate the transfer routine. Therefore, we do not present a complete example; that would only be possible when all details of a particular communication environment and operating system were known. The code begins by defining the value of the SIO control and data channels, followed by location definitions for the interrupt vector. There is then a series of constant definitions of the various fields in each register of the SIO. This is followed by a table-driven SIO initialization routine called "SIO\_init," shown in Figure 7, which uses the table beginning at the location "SIOItable." The SIO\_Init routine initializes the SIO with exactly the same Figure 8. Interrupt-Driven Transmit Routine Figure 7. Interrupt-Driven Initialization Routine Figure 9. Transmitter Buffer Empty Interrupt Routine A Longer Example (Continued) parameters as the interrupt-driven example in the previous section. The table-driven version is presented simply as an alternative means of coding this material. A short routine for filling the receive buffer with "FF" (hex) characters and buffer definitions follows the SIO\_Init routine. This in turn is followed by the transfer routine, Figure 8, which begins transmitting on Channel A; transmission and reception is thereafter directed by the interrupt routines. After the transfer routine begins output, it checks for various error conditions and loops until there is either completion or an error. Then the four interrupt routines follow: TxBEmpty, Figure 9, is called on a transmit buffer interrupt; it begins transmission of the next character in the buffer. A carriage return stops transmission. RecvChar, Figure 10, is called on a normal receive interrupt; it places the received character in the buffer if the buffer is not full and updates receive counters. The routines SpRecvChar, Figure 11, and ExtStatus, Figure 12, are error interrupts; they update information to indicate the nature of the error. The code of this example can be used in a situation where data is being sent to a device which echoes the data sent. In such a case, the transmit and receive buffers could be compared upon completion for line or transmission errors. Figure 11. Special Receive Condition Interrupt Routine Figure 10. Receive Character Interrupt Routine Figure 12. External/Status Interrupt Routine ## Appendix A ## Interrupt-Driven Code Example | SIO P | ort Ident | ifiers and S | ystem Address Bus Addresses | WR3 Com | mands | Mark March | | |--------------------------|-----------|----------------|-----------------------------------------|------------|-------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | B5: | EQU | 00H | ;Receive 5 bits/character | | SIO: | EQU | 40H | | RENABL: | EQU | 01H | :Receiver enable | | SIOAData: | FOU | SIO+1 | * | ENRCVR: | EQU | 01H | :Receiver enable | | | EQU | SIO+2 | | SCLINH: | EQU | 02H | ;Sync character load inhibit | | SIOBData: | | SIO+3 | The second second second second | ADSRCH: | | 04H | ;Address search mode | | SIOBCtrl: | | SIO+4 | | RCRCEN: | | 08H | ;Receive CRC enable | | 01000 | 200 | J.C | | HUNT: | EQU | 10H | Enter hunt mode | | | • | | | AUTOEN: | | 20H | ;Auto enables | | | | Table of in | terrupt Vectors | B7: | EQU | 40H | ;Receive 7 bits/character | | <del></del> | | | | B6: | EQU | H08 | ;Receive 6 bits/character | | The table<br>should be o | | | the lowest priority vector, which | B8: | EQU | <b>0</b> C0H | ;Receive 8 bits/character | | | | | | WR4 Com | mands | | | | | ORG | ODOH | starts at address with low | SYNC: | EQU. | 00H | Sync modes enable | | • | | | ; byte = 11010000 | NOPRTY: | EQU | 00H | ;Disable parity | | ntTab: | DEFW | TxBEmpty | ;interrupt types for Channel B | ODD: | EQU | OOH | ;Odd parity | | | DEFW | ExtStat | | MONO: | EQU | 00H | ;8 bit sync character | | | DEFW | RxChar | | . C1: | EQU | 00H | ;X1 clock mode | | | DEFW | SpRxCond | | PARITY: | EQU | OIH | Enable parity | | | | , | | EVEN: | EQU | 02H | Even parity | | | DEFW ' | | interrupt types for Channel A | Si: | EQU | 04H | ; I stop bit/character | | | DEFW | ExtStat | | SIHALF: | EQU | H80 | ; I and a half stop bits/charac | | | DEFW | RxChar | | , S2: | EQU | 0CH | ;2 stop bits/character | | | DEFW | SpRxCond | | BISYNC: | EQU | IOH | ;16 bit sync character | | * | | | | SDLC: | EQU | 20H | ;SDLC mode | | | | | <del></del> | ESYNC: | EQU | 30H | External sync mode | | | Cor | nmand Iden | itifiers and Values | C16: | EQU | 40H | :X16 clock mode | | | | | | C32: | EQU | 80H | ;X32 clock mode | | Includes | all contr | ol bytes for a | asynchronous and synchronous I/O. | C64: | EQU | <b>0</b> C0H | ;X64 clock mode | | VR0 Comm | ands | | 1 · · · · · · · · · · · · · · · · · · · | WR5 Com | nands | | ender de la companya de la companya de la companya de la companya de la companya de la companya de la companya<br>La companya de la co | | 0: | EQU | 00H | ;SIO register pointers | T5: | EQU . | 00H | :Transmit 5 bits/character | | 11: | EQU | 01H | | XCRCEN: | EQU | 01H | Transmit CRC enable | | 12: | EQU | 02H | | RTS: | EQU | 02H . | Request to send | | 13: | EQU | <b>0</b> 3H | | SELCRC: | EQU | 04H | Select CRC-16 polynomial | | <b>14</b> : | EQU | 04H | | XENABL: | EQU . | 08H | ;Transmitter enable | | 15: | EQU | 05H | | BREAK: | EQU | 10H | ;Send break | | 16: | EQU | 06H | | T7: | EQU | 20H | ;Transmit 7 bits/character | | <b>?7</b> : | EQU | 07H | | T6: | EQU | 40H | ;Transmit 6 bits/character | | * | | | ***** | T8: | EQU | 60H | Transmit 8 bits/character | | IC: | EQU | 00H | ;Null Code | DTR: | EQU | 80H | ;Data terminal ready | | SA: | EQU | 08H | ;Send Abort (SDLC) | Din. | LQU | 0011 | ,Data terminal ready | | ESI: | EQU | 10H | ;Reset Ext/Stat Int | | | Initializa | tion | | CHRST: | EQU | 18H | Channel Reset | | | | | | IONRC: | EQU | 20H | Enable Int On Next Rx Char | SIOInit: | | HL, Int_Tab | | | TIP: | EQU | 28H | Reset Tx Int Pending | | LD | A,H | | | R: | EQU . | 30H | :Error Reset | | LD | I,A | | | FI: | EQU | 38H | :Return From Int | | LD . | A,L | | | | EQU | 40H | Reset Rx CRC Checker | | LD | (L_Loc),A | | | TCG: | EQU | 80H | :Reset Tx CRC Generator | | LD | HL, SIOltable | | | TUEL: | EQU | 0C0H | ;Reset Tx Under/EOM Latch | Init_Loop: | LD, | A,(HL) | ;loop for initialization | | | | | | | INC | HL | | | VRI Comm | ands | | | | CP | 0 | | | /AIT: | EQU | H00 | ;Wait function | | RET | Z | | | RCVRI: | EQU | 00H | Disable Receive interrupts | • | OUT | (SIOACtrl), A | and the second second | | XTIE: | EQU | 00H | External interrupt enable | | OUT | (SIOBCtrl),A | | | MTRIE: | EQU | 02H | • | | JR | Init_Loop | • | | AVECT: | EQU | 02H<br>04H | :Transmit interrupt enable | CIONAL | | | stable for initialization | | | | | Status affects vector | S10Itable: | DEFB | CR | table for initialization | | IRSTC: | EQU | H80 | :Rx interrupt on first character | | DEFB | R4 + RESI | DADITY | | AVECT: | EQU | HOI | :Rx interrupt on all characters | * | DEFB | | + PARITY + S2 | | D 11/0- | EOT: | | ; (parity affects vector) | | DEFB | R3 + RESi | | | DAVCT: | EQU | 18H | :Rx interrupt on all characters | | DEFB | | EN + ENRCVR | | | | | ; (parity doesn't affect vector) | | DEFB | R5 + RESI | | | RONRT: | EQU | 20H | ;Wait/Ready on receive | | DEFB | DTR + RTS - | T8 + XENABL | | | EQU | 40H | Ready function | | DEFB | R2 + RESI | | | /RDYEN: | | 80H | ;Wait/Ready enable | l_Loc: | DEFS | 1 | ;location of int table | | | | | • | ILOC; | DEFB | RI + RESI | address | | /R2 Comm | ands | | | | DEFB | | RIE + SAVECT + PAVECT | | <b>/</b> : | EQU | 00H | | | | | | | • | £QU | JUIL | | | DEFB | 0 | | ``` Receiver Buffer Initialization Receive Character Routine (see Figure 10) Buf_Init: I.D A, BufLength ;fill receiver buffer RxChar: PUSH AF BC LD ; with FF characters PUSH HL,RBuffer LD ; to detect errors LD LD A,OFFH A,SIOAData LD C,A A,(C) (HL),A LD ;a loop for Buf_Init lN INC HL ;get character LD B.A DINZ Buf_1 A,(RBufCtr) RET CP BufLength BufLength: EQU ;buffer length JR Z,Over XBuffer: DEFS BufLength :Tx buffer starting location INC RBuffer: DEFS BufLength ;Rx buffer starting location ;bump counter LD (RBufCtr), A XBufPti: DEFS ;Tx pointer LD A,B HL,(RBufPtr) RBufPtr: DEFS ;Rx pointer LD ;bump pointer RBufCtr: ;Rx counter (HL),A INC LD (RBufPtr), HL Transmit Routine (see Figure 8) CP JR Initiates transmission of a buffer-full of data and terminates when NZ.RxExit an error is detected or a complete buffer has been received. LD A.Complete RxStat: DEFS ;Receive Status Word (RxStat), A TxStat: DEFS JR RxExit ;Transmit Status Word Complete: EQU 1 Over: LD A,Overflow ; indicate error CR: EQU ODH LD (RxStat),A Break: EQU 80H RxExit: POP BC EOM: EOU 80H POP AF Overflow: EOU OFFH Εl Transfer: I.D HL,XBuffer RETI setup to begin Tx INC HI. (XBufPtr),HL LD Special Receive Condition Routine (see Figure 11) LD HL, RBuffer SpRxCond: PUSH LD (RBufPtr), HL PUSH BC XOR (RBufCtr), A LD I.D A,SIOAData LD (TxStat),A LD C,A LD LD (RxStat),A A,Ri ;get RR1 INC LD A,SIOAData ;start Tx task OUT (C),A LD C,A IN HL,(XBuffer) ;first character A.(C) LD LD (RxStat), A LD ;save status A,(HL) LD :Reset Errors OUT (C),A DEC Tloop: LD CP A,(TxStat) ;await Tx completion or error OUT (C),A DEC RET NZ IN A,(C) get character LD A,(RxStat) POP BC CP Overflow POP AF RET ΕI CP Complete RETI RET NZ, Tioop External/Status Routine (see Figure 12) RET ExtStatus: PUSH Transmitter Buffer Empty Routine (see Figure 9) PUSH BC TxBEmpty PUSH AF LD A,SIOACtri PUSH LD C,A A,(C) PUSH HL IN ;get RR0 LD (TxStat), A I.D HL,(XBufPtr) LD A,RESI LD A,SIOAData C,A :Reset Ext Stat Int LD OUT (C),A LD A,(HL) POP BC OUTI POP AF CP JR ΕI NZ, TxBExit ;last character? END LD A,RTIP ;Reset Tx Int Pending INC OUT (C),A to control port TxBExit: LD (XBufPtr),HL ;save pointer POP POP POP AF Εİ ``` 561 ole ıracter ad inhibit racter racter racter ts/character r scter e iomial cter cter RETI ## Appendix B Read Register Bit Functions ## Appendix C Write Register Bit Functions ## **公Zil**CC #### INTRODUCTION This application brief describes the use of the Z80 S10 with the increasingly popular Synchronous Data Link Control (SDLC) communications protocol. A general description of the SDLC protocol and implementation of the protocol using the S10 are discussed. Descriptions for transmit and receive operations are given for use with simple contol frame sequences. ### **Application Brief** The reader should be familiar with hardware aspects of the S10 such as interfacing to the CPU and a modem. A more detailed description of the SDLC protocol is given in the IBM publication Synchronous Data Link Control General information (document # GA27-3093-2). A description of the Z80 S10 can be found in the Z1log Data Book (document # 00-2034-A). #### DESCRIPTION Data communication today requires a communication protocol that can transfer data quickly and reliably. One such protocol, Synchronous Data Link Control (SDLC), Is the link control used by the IBM Systems Network Architecture (SNA) communication package. SDLC is actually a subset of the international Standards Organization (ISO) link control called High Level Data Link Control (HDLC), which is used for international data communications. SDLC is a Bit-Oriented Protocol (BOP). It differs from Byte-Control Protocols (BCPs), such as bisync, in having a few bit patterns for control functions instead of several special character sequences. The attributes of the SDLC protocol are position dependent rather than character dependent, so control is determined by the location of the byte as well as by the bit pattern. A character in SDLC is sent as an octet, a group of eight bits. Several octets combine to form a message frame in such a way that each octet belongs to a particular field. Each message frame consists of an opening flag, address, control, information, Frame Check Sequence (FCS), and closing flag fields. The flag field contains a unique binary pattern, Ollillio, which indicates the beginning and end of a message frame. This pattern simplifies the hardware interface in receiving devices so that multiple devices connected to a common link do not conflict with one another. The receiving devices respond only after a valid flag character has been detected. Once communication is esta- blished for a particular device, the other devices ignore the message until the next flag character is detected. The address field contains one or more octets that are used to select a particular station on the data link. An address of all is is a global address code that selects all the devices on the link. When a primary station sends a frame, the address field is used to select a secondary station. When a secondary station sends a message to the primary station, the address field contains the secondary station address, i.e., the source of the message. The control field follows the address field and contains information about the type of frame being sent. The control field consists of one octet and is always present. The information field consists of zero or more 8-bit octets and contains any actual data transferred. However, because of the limitations of the error-checking algorithm used in the frame-check sequence, maximum recommended block size is approximately 4096 octets. The Frame Check Sequence (FCS) follows the Information field or the control field, depending on the type of message frame sent. The FCS is a 16-bit Cyclic Redundancy Code (CRC) of the bits in the address, control, and information fields. The FCS is based on the CRC-CCITT code, which uses the polynomial $(X^{16}+X^{12}+X^5+1)$ . The Z80 S10 contains the circultry necessary to generate and check the FCS field. This application note refers to products as Z80 "A", "B" etc. to specify the speed grade. We are no longer using those characters for the speeds. For more details, please refer to the ordering information section. Zero Insertion/deletion is a feature of SDLC that allows any data pattern to be sent. Zero Insertion occurs when five consecutive is in the data pattern are transmitted. After the fifth 1, a 0 is inserted before the next bit The data is not affected in any way is sent. except that there is an extra 0 in the data stream. The receiver counts the is and deletes the O following the five consecutive is, thus restoring the original data pattern. Zero insertion and deletion is necessary because of the hardware constraint of searching for a flag character or abort sequence. Six is preceded and followed by a O indicate a flag character. Seven to 14 is signify an abort, while an idle line (inactive) is indicated by 15 or more is. Under these three conditions, zero insertion/deletion is inhibited. Figure 2 illustrates the various line conditions. SDLC protocol differs from other synchronous protocols with respect to frame timing. In bisync, for example, a host computer might interrupt transmission temporarily by sending sync characters instead of data. This suspended condition could continue as long as the receiver does not time out. With SDLC. however, it is illegal to send flags in the middle of a frame to idle the line. Such an occurrence causes an error condition and disrupts orderly operation. Therefore, the transmitting device must send a complete frame without interruption. If a message cannot be completed, the primary station sends an abort and resumes message transmission later. These conditions are discussed later in the Programming section of this brief. Figure i. A Typical SDLC Message Frame Format xxxx111111111111111... ldie c) idle Condition b) Abort Condition Figure 2. Bit Patterns for Various Line Conditions 566 , 2- synchronous iming. In puter might by sending This susas long as With SDLC. ags in the e. Such an dition and refore, the a complete f a message ry station sage trans-3 discussed on of this 10 PROGRAMMING THE SIO implementation of the SDLC protocol with the Z80 S10 is simplified by the design of the S10. This section discusses four areas of S10 programming: initialization, transmit operation, receive operation, and exception condition processing. initialization defines the basic mode of operation for the SIO. Table I shows the sequence of steps used to initialize the SIO, along with the necessary parameters. Since vectored interrupts are used, the SIO is programmed with the status affects vector (SAV) bit (WRI, bit 2) set. Other function bits that can be included are the external interrupt enable bit (WR1, bit 0), which results in an interrupt for each DCD or CTS change, T<sub>X</sub> underrun or abort change; address search bit (WR3, bit 2), which when set, prevents the SIO from responding to data received unless the address byte matches the contents of WR6 or the global (FFH) address; auto enable bit (WR3, bit 5), which causes the inactive CTS level to disable the transmitter and the inactive DCD level to disable the receiver; and DTR (WR5, bit 7) and RTS (WR5, bit 1), which can be used to control a modem or other such device. Table 1. SIO Initialization Sequence | Register | Data | Function | |----------|-----------|-----------------------------------------------------------------------| | . 0 | 00011000 | Channel reset | | 2 | (Vector) | interrupt vector<br>lower eight bits | | | | (channel B only) | | 4 | 00100000 | SDLC mode | | 1 | 11111000 | Interrupt control | | 6 | (Address) | R <sub>Y</sub> address field | | 7 | 0111110 | Flag field | | 5 | 11101011 | T <sub>X</sub> character length,<br>enable, CRC enable<br>RTS and DTR | | 3 | 11001001 | R <sub>X</sub> character length,<br>enable, and CRC<br>enable | #### TRANSMIT OPERATION After the S10 has been initialized and enabled, it can begin sending SDLC frames by software activation of the transmitter. Activating the transmitter includes resetting the transmitter inactive semaphore (a program indicator), resetting the $T_\chi$ CRC accumulation. tion, sending a character to the SiO, and resetting the $T_X$ underrun/EOM latch in the SiO. Figure 3 shows the sequence for transmitting a typical control message frame using interrupts. \* - Transmit Buffer Empty + = External/Status Change Figure 3. A Typical Transmit Control Frame Sequence When the SIO is loaded with the first data character (address byte), it stores the character in the Ty buffer until the current flag character has completed shifting. After the address byte is transferred into the shift register, a Transmit Buffer Empty (TBE) Interrupt occurs. The program them loads the control character into the SIO and continues processing. The next TBE interrupt is ignored by the program (and no further data is sent to the SIO), but a Reset T<sub>X</sub> interrupt Pending command is issued to the SiO to clear the TBE Interrupt condition. Also, the program Message completed (MC) semaphore is set so that appropriate action can be taken when the next TBE Interrupt occurs. When the last data character (the control byte) has been shifted out of the SiO, the $T_X$ underrun/EOM latch is set because the SiO buffer was not loaded with a character on the previous TBE interrupt. As a result, an External/ Status Change (ESC) interrupt occurs and the SiO begins transmitting the FCS bytes automatically. In the ESC inter- rupt service routine, the program checks for other condition changes including CTS, DCD, and abort, and passes the status on to the program at the next-higher level. After the FCS bytes have been shifted out, the SIO generates a TBE interrupt to indicate that a flag character is being transmitted. The TBE interrupt service routine interprets the MC semaphore and determines that the frame has completed transmission. The program then clears the MC semaphore, sets the Transmitter inactive semaphore, starts a timer for a response from the receiving device, and clears the TBE interrupt condition. At this point, transmission of an SDLC mesage frame is complete and another message frame may be sent. If the transmitter is to be turned off, the program must allow at least a two-character time delay before disabling the transmitter. This can be accomplished by connecting the SIO $T_X$ clock line to the input of a counter and having the counter interrupt the CPU when the bit count expires. #### RECEIVE OPERATION The SDLC receive sequence is slightly less complex than the transmit sequence. To begin, the SiO enters Hunt mode when any of three conditions occurs: receive enable, abort detect, or a software command. In Hunt mode the SiO searches for flag characters, and when it detects a flag, the SiO generates an ESC interrupt. This interrupt can be used to signal line activation or the end of an abort condition, depending upon the previous receive condition. For example, when the SiO has been initialized, the receive circuitry Is enabled and Immediately begins searching for flag characters (Hunt mode operation). When the first flag is detected, the SIO exits from Hunt mode, which results in an ESC interrupt, and the SIO begins searching for the address field. If the SIO is programmed for Address Search mode and an address is received that does not match the programmed address byte in the SIO, the SIO does nothing until the next flag is found, after which the SIO again searches for an address match. #### SDLC RX #### NOTES \* The SRC routine normally reads the data character to clear the SiO buffer. This should be done after the program issues an Error Reset command. \*RCA = Receive Character Available <sup>++</sup>SRC = Special Receive Condition (higher priority than RCA) Figure 4. A Typical Receive Control Frame Sequence hecks for CTS, DCD, on to the fted out, o indicate nsmitted. Interprets that the The prosets the starts a iving decondition. GDLC mes- or message off, the haracter nsmitter. ting the a counter CPU when searching rather 10 in an ESC ching for ogrammed idress is ogrammed ; nothing which the id upt If the address field matches the address byte programmed into the SIO, the SIO generates a Receive Character Available (RCA) interrupt when the address byte is ready to be transferred from the \$10 to the CPU. If the \$10 is programmed to interrupt on all receive characters, if generates an RCA interrupt for each character received thereafter. It should be noted that the SIO generates the RCA interrupt when a character reaches the top of the receive FIFO rather than when a character is transferred from the shift register to the FIFO. This means that if the FIFO is full of data, each character generates a separate RCA interrupt. This results in a more consistent software routine that does not need to check the receive FIFO, provided there is enough time between character transfers to allow the routine to complete the processing for each character. After the last FCS byte of a frame is received and processed, the SIO generates a Special Receive Condition (SRC) Interrupt, which is of higher priority than the RCA Interrupt. In the SRC service routine, RRI is read to determine the cause of the interrupt and the appropriate program semaphores are updated. Normal completion results in no FCS or overrun errors and the End-of-Frame Wake: Clear T<sub>X</sub> Inactive semaphore Reset T<sub>X</sub> CRC Data to SIO (Address field byte) Reset T<sub>X</sub> Underrun/EOM latch Transmit Buffer Empty (TBE): If (MC cleared) If (buffer not empty) Data to SIO Else, Set MC semaphore Reset TBE condition Else, Clear MC Set T<sub>X</sub> Inactive Reset TBE condition Start Response timer bit is set. Upon completion of the SRC interrupt service routine, the program issues an Error Reset command to the SIO and reads the data port to discard the received data. If the data is not read and discarded, an RCA interrupt occurs. Now, a complete message frame and the first FCS byte are in the receive buffer. Figure 4 shows the sequence for a typical control frame received by the SIO. If the address field byte is to be discarded, a program semaphore should initially be set to signal this to the RCA routine. After the address field has been received, the semaphore is cleared and reception continues normally. Note that upon completion of a frame, an RCA interrupt is generated for the first FCS byte and an SRC interrupt is generated for the last CRC byte. Table 2 lists the contents of the interrupt service routines used with the SiO. The wake routine is not an interrupt service routine but is a routine called by the program on the next higher level to begin frame transmission. Once the wake routine is called, the program on the next higher level monitors the Tx active semaphore to determine when the current frame completes transmission and the next frame transmission can begin. External/Status Change (ESC): Clear DCD, CTS, abort semaphores If (abort) Set abort semaphore Else If (DCD change) Set DCD semaphore Else If (CTS change) Set CTS semaphore Receive Character Available (RCA): If (EOF) Read and discard data Else, Store data Special Receive Condition (SRC): Read SIO RRI If (EOF) Set EOF semaphore Else If (CRC error) Set R<sub>X</sub> CRC error semaphore Else If (R<sub>X</sub> overrun) Set R<sub>X</sub> overrun semaphore Issue Error Reset Read data & discard Table 2. SIO SDLC Interrupt Service Routines # EXCEPTION CONDITION OPERATION Most of the exception conditions encountered in the SDLC protocol have been discussed in the previous sections. They include abort detect and DCD or CTS change. This section further describes some of the more unusual conditions. DCD and CTS Change. The program handles DCD and CTS change by updating its semaphores each time an ESC interrupt occurs. In this manner, the program on the next higher level monitors the semaphores and determines a course of action based on what these semaphores indicate. Abort and idle Line Detect. Abort and idle line detect are a bit more complicated, since they result in similar interrupt operations. An abort occurs during a valid message frame. If the abort time is greater than 14 bits, an idle line is detected. This detection can be done by activating a timer when the ESC interrupt that signals a marking line occurs. If another ESC interrupt occurs before the timer times out, the line is in an abort condition. If the timer times out before another ESC interrupt occurs, then the line is idle and the program can pursue an appropriate course of action. A possible mechanism for implementing the timer function is to use a programmable counter that is tied to the receive clock line to count bits. The counter is programmed for eight clock transitions and is started as soon as the SIO interrupts the CPU with an abort condition. Only eight clock transitions need to be counted because by the time the SIO generates the ESC interrupt, at least seven is have already passed. Figure 6 shows the abort/ idle line timing and the interrupts resulting from the line changes. Figure 6. Abort/Idle Line Conditions #### CONCLUSION This brief describes implementation of the SDLC protocol using the SIO in an interrupt-driven environment. Descriptions for transmit and receive operations are given for use with simple control frame sequences. For frames that transfer data, the sequences are similar except for transmit, where a data character is sent to the SIO for a TBE interrupt. For receive, multiple RCA inter- rupts occur for each data byte received. The Z80 S10 enhances system performance by minimizing CPU intervention during data transfers using the SDLC protocol. Performance can be improved further by using the Z80 DMA with the S10, resulting in an efficient system configuration that reduces CPU interaction to a minimum. #### **APPENDIX** Following is the listing of a simple SIO test program that uses the SDLC protocol. This program uses vectored interrupts to send a short SDLC control frame consisting of Address 9EH, Control 19H, and Data 81H. The response timer times the response of the receiving station after a message has been sent. If the response timer expires, the program on the next higher level normally retransmits the message frame (if the retransmit count has not yet expired). This program transmits continuously until the processor is reset or interrupted by an external source. LOC OBJ CODE M STMT SOURCE STATEMENT ASM 5.9 1 ; SIO SDLC TEST PROGRAM 3 ;[0] · 01-21-81/MDP INITIAL CREATION ``` an appro- ple mech- metion is is tied to pits. The pck tran- is the SIO indition, ed to be generates in is have e abort/ resulting ``` he ESC In- e occurs. before the an abort out before the line LOC ``` В SDLC WITH THE BAUD RATE CLOCK SUPPLIED BY 9 HARDWARE INTERNAL TO THE SYSTEM. 10 11 EQUATES 13 ADDRESS: EQU 9EH ADDRESS FIELD 14 CTRL: EGU 19H CONTROL FIELD 15 DATA: EQU B1H ; INFORMATION FIELD MSGLEN: EQU 16 MESSAGE LENGTH 17 RAM; 2000H RAM ORIGIN EQU RAMBIZ: 1000H RAM SIZE EQU 19 SIDDA: EGU SIO PORT A 20 SIODA+1 SICCA EQU SIO PORT A CTRL 21 SICOB: EQU SIODA+2 SIO PORT B DATA 22 SICCB: EQU SIODB+1 SID PORT B CTRL 23 CIOC: EQU CID PORT CIOC+1 24 25 CIOB; EQU CIO PORT B CIOA: EQU CIOC+2 CIO PORT A 26 CIOCTL: EQU CIOC+3 CIO CTRL PORT 27 BAUD: EQU 9600 ASYNC BAUD RATE 28 RATE EGU BAUD/100 29 30 CICCNT: EQU 9216/RATE LITE: ILIGHT PORT EQU OFOH 31 RSPCNT: EQU 100 RESPONSE TIMER VALUE 32 33 SIO PARAMETERS 34 SIOWRO: EQU 35 CHRES: 184 EQU 1 CH. RESET CMD 36 37 ESC RESET CMD ESCRES: 10H EQU 38 TBERES: EQU 28H ; TBE RESET CMD RETIA: 39 EGU 38H RETI CH. 40 ENINRX: EQU 20H ENAB. INT. NEXT RX 41 SRCRES: EQU HOE SRC RESET CMD 42 RCRCRE: EQU 40H IRX CRC RESET CMD 43 TCRCRE: EQU BOH ITX CRC RESET CMD EDMRES: EQU осон LEOM RESET CMD 45 SIOWR1: EQU 47 WREN: EQU BOH WAIT/RDY ENABLE 48 RDY: EQU ; READY FUNCT. ; WAIT/RDY ON RX 40H 49 WRONR: EQU 20H 50 RXIFC: EQU IRX INT. FIRST CHAR 10H 51 RXIAP: EQU ;RX INT. ALL + PARITY 52 RXIA: EGU 18H RX INT. ALL 53 SIOSAV: EQU STATUS AFFECTS VECT 4 (CH. B ONLY) 55 EQU TX INT. ENABLE 56 EXTI: EQU EXT. INT. ENABLE 57 SIGWR2: EQU 58 : (CH. B DNLY) 59 60 SIOWR3: EGU 61 RX8: EQU осон :RX 8 BITS 62 RX4: EQU вон RX 6 BITS 63 RX7: EQU 40H RX 7 BITS 64 RX 5 BITS RYS FOU n 65 20H AUTOEN: EGU JAUTO ENABLES 66 HUNT: EQU 10H HUNT MODE 67 RXCRC: EQU 8 RX CRC ENABLE 6B ADSRCH: EQU ADDR SEARCH 69 SYNINH: EQU 2 SYNC LOAD INHIBIT 70 71 RXEN: EQU 1 RX ENABLE 72 SIGWR4: EQU 73 74 X64: EQU осон # 64X CLOCK X32: EQU 80H 75 E₫U 40H : 16X CLOCK X1: EQU 0 ; 1X CLOCK ``` TEST. SDLC OBJ CODE M STMT SOURCE STATEMENT id. ance by g data Perforng the n effies CPU s, the ormally he re, This ii the an ex- -25-81 617-1564-0007 ASM 5.9 THIS PROGRAM SENDS ADDRESS 9EH, CONTROL 19H, INTERRUPT MODE. THE SIG IS INITIALIZED TO USE AND DATA BIH CONTINUOUSLY USING THE 280 VECTORED ``` TEST. SDLC OBJ CODE M STMT SOURCE STATEMENT ASM 5. 9 LOC JEXT. SYNC ENABLE EXTSYN: EQU 30H 77 78 79 20H SDLC MODE SDLC: EQU : 16 BIT SYNC SYN16: EQU 10H SYNB: # BIT SYNC 80 EQU осн 12 STOP BITS STOP2 EQU 81 8 ; 1. 5 STOP BITS 82 STOP 15: EQU 83 STOP1: EQU :1 STOP BIT 84 SYNCEN: EQU SYNC ENABLE 85 EVEN: EQU 2 ; EVEN PARITY 86 PARITY: EGU 1 ; PARITY: ENABLE 87 SIOWR5: 88 EQU ĒQU BOH ACTIVATE DTR 89 DTR: 90 TXB: EQU H06 TX 8 BITS 91 TX6: EQU 40H TX 6 BITS TX7: EQU 20H ; TX 7 BITS 93 TX5: EQU ; TX 5 BITS 10H 94 BREAK: EQU ; TX BREAK ITX ENABLE 95 TXEN: EQU 8 96 97 CRC-16 MODE CRC16: EQU EQU ACTIVATE RTS RTS: 98 TXCRC: EQU ; TX CRC ENABLE 100 SIOWR6: EQU ; LOW SYNC OR ADDR 101 7 ; HIGH SYNC OR FLAG 102 SIGWR7: EQU 103 SIOFLO = FLAGS FOR SID STATUS 104 105 BIT --- SET CONDITION 106 107 108 0 TX ACTIVE MESSAGE COMPLETE 109 CTS ACTIVE 110 DCD ACTIVE 111 ABORT DETECT RX OVERRUN ERROR RX CRC ERROR 115 RX END OF FRAME *E 116 *** MAIN PROGRAM *** 118 119 ORG 0000 120 ; CO MAIN PROGRAM BEGIN 0000 C32000 121 122 INTERRUPT VECTORS 124 (MUST START ON EVEN BOUNDARY) 125 $. AND. OFFFOH. OR. 10H 0010 126 127 INTVEC: 128 SIOVEC: 9000 129 DEFW CHBTBE 0010 0012 D100 130 DEFW CHBESC 0014 0101 131 DEFW CHBRCA 0016 0F01 132 DEFW CHBSRC 0018 3B01 133 DEFW CHATBE CHAESC 001A 4301 134 DEFW CHARCA DEFW 001C 4B01 135 DEFW CHASRC 001E 5101 136 137 BEGIN: 138 0020 314020 137 SP, STAK ; INIT SP VECTOR INTERRUPT MODE 0023 ED5E 140 ΙM UPPER VECTOR BYTE 0025 3E00 141 LD A. INTVEC/256 0027 ED47 142 LD 143 214520 HL. BUFFER 0029 LD 369E 144 LD STORE ADDRESS 002C (HL), ADDRESS 002E 23 145 INC STORE CTRL BYTE 002F 3619 146 LD (HL), CTRL 0031 23 147 INC HL 0032 3681 148 LD (HL), DATA ISTORE DATA BYTE ; INIT DEVICES CALL 0034 CD4C00 149 INIT ``` | R | | |---|--| 9 LE | , | | |---|--| | | | MODE | 1.00 | OR LOGBE | M 67MT | | TEST. SDLC | | | |--------------|------------------|------------|----------|------------|-----------------------------|----------------------------------------------| | LQC<br>0037 | 218720 | | SUURCE | BTATEMENT | | ASM 5. 9 | | 0037<br>003A | 228520 | 150<br>151 | | LD<br>LD | HL,RBUF<br>(RBPTR),HL | SETUP READ BUFFER | | | | 152 | LOOP: | LD | (KBFIK)) AL | | | QC3D | 213D00 | 153 | | LD | HL, LOOP | SETUP STACK FOR RETURN | | 0040 | E5 | 154 | | PUSH | HL | Table Billion For Karokit | | 0041 | CD7D00 | 155 | | CALL | WAKE | WAKE TX | | 0044 | 3A4020 | 156 | LOOP1: | | | • | | 0047 | CB47 | 157<br>158 | | LD<br>Bit | A.(SIOFLG) | CHECK TX ACTIVE FLAG | | 0049 | 20F9 | 159 | | JR | NZ, LOOP1 | LOOP IF TX ACTIVE | | 004B | C9 | 160 | | RET | | FLOOP IF IX ACTIVE | | | | 161 | | | | | | | • | 162 | INIT: | | | | | 004C | 217001 | 163<br>164 | SIOINI | :<br>LD | | | | 004E | 0E01 | 165 | , | LD | HL,SIOTA<br>C,SIOCA | ; INIT CH. A | | 0051 | ,060A | 166 | | LD | B, SIOEA-SIOT | · | | 0053 | 'EDB3 | 167 | | OTIR | | ··· | | 0055 | 217A01 | 168 | | LD | HL, SIOTB | INIT CH. B | | 005B<br>005A | 0E03<br>0610 | 169 | | LD | C, SIOCB | <u>. </u> | | 005C | EDB3 | 170<br>171 | | LD<br>OTIR | B. SIOEB-SIOT | .13 | | 005E | 3E00 | 172 | | LD | A, 0 | CLEAR FLAG BYTE | | 0060 | 324020 | 173 | • | LD | (SIOFLG), A | ICLEMA PLAG BYIE | | 00/0 | | 174 | CIDINI | | | | | 0063<br>0065 | DBOB<br>AF | 175 | | IN | A, (CIOCTL) | INSURE STATE O | | 0066 | DOB | 176<br>177 | | XOR<br>OUT | A<br>(CIOCTL), A | POINT TO REG O | | 0048 | DBOB | 178 | | IN | A, (CIOCTL) | CLEAR RESET OR STATE O | | 006A | AF | 179 | | XOR | A | FOLLAR REDET OR STATE O | | 004B | D30B | 180 | | OUT | (CIOCTL),A | POINT TO REG O | | 004D<br>004E | 30, | 181 | | INC | A | WRITE RESET | | 0070 | D30B<br>AF | 182<br>183 | | OUT<br>XOR | (CIOCTL), A | | | 0071 | рзов | 184 | | | A (CIOCTL), A | CLEAR RESET COND. | | 0073 | 218A01 | 185 | | LD | HL, CLST | INIT CIO | | 0076 | 040E | 186 | | LD | B, CEND-CLST | 721121 020 | | 007B | OEOB | 187 | | LD | C, CIOCTL | | | 007A<br>007C | EDB3<br>C9 | 188 | | OTIR | | | | 0070 | 67 | 189<br>190 | | RET | | | | | | 191 | WAKE: | | | | | 007D | 3A4020 | 192 | | LD | A. (SIOFLG) | SET ACTIVE FLAG | | . 0080 | CBC7 | 193 | | | 0. A | | | 0082<br>0085 | 324020 | 194 | | LD | (SIOFLO), A | | | 0088 | 214520<br>224320 | 195<br>196 | | LD<br>LD | HL, BUFFER | SET BUFFER PTR | | 0088 | 3E03 | 197 | | | (BUFPTR), HL<br>A, 2+MSGLEN | SET BYTE COUNT | | OOSD | 324120 | 198 | | | (BYTES), A | ASEL BYTE COONT | | 0090 | 3E80 | 199 | | LD | A, TCRCRE | CLEAR TX CRC | | 0092<br>0094 | D303<br>CD9C00 | 200 | | | (SIOCB), A | | | 0097 | 3EC0 | · 201 | | | CHBTBE | START TRANSMIT | | 0099 | D303 | 203 | | | A,EOMRES<br>(SIOCB),A | RESET EOM LATCH | | 009B | C9 | 204 | | RET | (DIOCD//A . | | | | • | 205 | *E | | | | | | | 206 | | • | | | | | | 207<br>208 | 11 | INTERRUP | T SERVICE ROL | JTINES | | | * | 209 | CHBTBE: | | 1 | $\chi^{\prime}_{ij}$ (2) | | 0090 | CD5901 | 210 | U11010C. | | BAVE | CH. B TX BUFFER EMPTY | | 009F | 214020 | 211 | | | HL, SIOFLO | POINT TO FLAG BYTE | | 00A2 | CB4E | 212 | | | 1,(HL) | CHECK MC FLAG | | 00A4<br>TE | 201D | 213 | | JR i | NZ, CHBTB2 | BRANCH IF MESSAGE COMPLE | | 00A6 | 3A4120 | 214 | | LD / | A (BVTEC) | Allean Burn | | 00A9 | B7 | 215 | | ' | A, (BYTES)<br>A | CHECK BYTE COUNT | | OOAA | 280F | 216 | | | Z, CHBTB1 | BRANCH IF DATA DONE | | OOAC | 3D | 217 | | | 4 | PRESENT AF DATA DUNE | | OOAD | 324120 | 218 | | | (BYTES), A | | | 00B0 | 2A4320<br>7E | 219<br>220 | | | L, (BUFPTR) | | | 0084 | D305 | 220 | | | A,(HL)<br>(SIODB),A | | | | | | | 301 | COLUDB / I M | | | | | | | _ | | |--------------|----------------|-------------------|-----------|--------------|-----------------------------------------| | LOC | OB.I CODE | M | TEST. SDI | LC | | | 00B6 | 23 CODE | M STMT SOURCE | | | ASM 5. 9 | | 00B7 | | | INC | HL | | | OOBA | | 223 | LD | (BUFPTR), HL | 그리다 그는 사람들은 그리스 선생활 | | AGOO | | 224 | RET | | | | ООВВ | CBCE | 225 CHBTE | | | | | OOBD | | 226 | SET | 1, (HL) | SET MC FLAG | | OOBE | | 227 | LD | A, EOMRES | | | | | 228 | OUT, | (SIOCB), A | | | 00C1 | 1809 | 229 | JR | СНВТВЗ | | | | | 230 CHBTE | | | | | 0003 | CBBE | 231 | RES | 1,(HL) | CLEAR MC FLAG | | 0005 | | 232 | RES | 0, (HL) | SET TX INACTIVE | | 00C7 | 3E64 | 233 | LD | A, RSPCNT | START RESPONSE TIMER | | 0009 | 324220 | 234 | LD | (RSPTMR),A | | | | | 235 CHBTB | 3: | | | | 0000 | 3E28 | 236 | LD . | A, TBERES | RESET TRE INT. PEND. | | OOCE | | 237 | OUT | (SIOCB), A | | | OODO | C <del>7</del> | 238 | RET | | | | | | 239. | • | | | | | | 240 CHBES | C: | | | | 00D1 | CD5901 | 241 | CALL | SAVE | CH. B EXTERNAL/STATUS CHO | | OOD4 | | 242 | LD | HL, SIOFLG | GET FLAG BYTE | | 00D7 | CB96 | 243 | RES | 2, (HL) | - Jei Lene Dile | | 00D9 | CB9E | 244 | RES | 3, (HL) | | | OODB | CBA6 | 245 | RES | 4, (HL) | | | OODD | DBO3 | 246 | IN | A. (SIOCB) | READ RRO | | OODF | 47 | 247 | LD | B, A | | | 00E0 | CB58 | 248 | BIT | 3, B | STORE IN %B | | 00E2 | C4FB00 | 249 | CALL | | CHECK DCD BIT | | 00E5 | CB68 | 250 | | NZ, SETDCD | · · · · · · · · · · · · · · · · · · · | | 00E3 | C4FE00 | | BIT | 5, B | CHECK CTS BIT | | OOEA | | 251<br>252 | CALL | NZ, SETCTS | | | | CB7B | 252 | BIT | 7, B | CHECK ABORT BIT | | | C4F800 | 253 | CALL | NZ, SETABT | | | OOEF | CB4E | 254 | BIT. | 1, (HL) | CHECK MC FLAG | | 00F1 | 2800 | 255 | JR | Z, CHBES1 | BRANCH IF CLEAR | | | | 256 CHBES: | 1: | | | | | 3E10 | 257 | LD | A, ESCRES | RESET ESC | | 00F <b>5</b> | D303 | 258 | OUT | (SIOCB), A | THEORY ESC. | | 00F7 | C9 | 259 | RET | / / 17 | | | | | 260 SETABI | | | | | OOFB | CBE6 | 261 | SET | 4, (HL) | | | OOFA | · C9 | 262 | RET | · -/ \/ IL/ | | | | | 263 SETDCI | | | | | OOFB | CBDE | 264 | SET | 3 (11) | | | OOFD | C9 | 265 | | 3, (HL) | | | | | | RET | • | | | OOFE | CBD6 | 266 SETCTS<br>267 | | 5 (18) | | | 0100 | CBDG<br>C9 | | SET | 2, (HL) | 4 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | | 0100 | U 7 | 268 | RET | • | | | | | 269 | | | | | 0101 | CDEGG4 | 270 CHBRCA | | | | | 0101 | CD5901 | 271 | CALL | SAVE | ; CH. B RX CHAR AVAIL. | | 0104 | DBO2 | 272 | IN | A, (SIODB) | | | 0106 | 2AB520 | 273 | LD | | GET READ BUFF PTR | | 0109 | 77 | 274 | LD | (HL),A | | | 010A | 23 | 275 | INC | HL | | | 010B | 228520 | 276 | LD | (RBPTR), HL | | | 010E | C9 | 277 | RET | | | | | | 278 | · · — • | | | | | | 279 CHBSRC | : | | | | 010F | CD5901 | 280 | CALL | SAVE | CH. B SPECIAL RX COND. | | 0112 | 3E01 | 281 | LD | A, 1 | TOTAL BECTAL KY COND. | | 0114 | D303 | 282 | OUT | (SIOCB), A | , DEAD OD! | | 0116 | DBO3 | 283 | IN | | READ RR1 | | 0118 | 47 , | 284 | LD | A, (SIOCB) | | | 0117 | 214020 | 285 | | B, A | SAVE IN %B | | 011C | CBB6 | | LD<br>LD | HL, SIOFLG | | | 011E | CB78 | 286 | RES | 6, (HL) | CLEAR CRC ERROR FLAG | | | | 287 | BIT | 7, B | CHECK EOF BIT | | 0120 | C43801 | 288 | CALL | NZ, SETEFF | BRANCH IF NOT EOF | | 0123 | CB70 | 289 | BIT | 6, B | CHECK CRC ERROR | | 0125 | C43501 | 290 | CALL | NZ, SETCRC | | | 0128 | CB68 | 291 | BIT | 5, B | CHECK OVRRUN BIT | | 012A | C43201 | 292 | CALL | NZ, SETOVR | | | | | 293 CHBSR1: | | | | | 012D | 3E30 | 294 | LD | A, SRCRES | ; ERROR RESET CMD | | | · | | | | · · · · · · · · · · · · · · · · · · · | 0: 01: 01: 01! 016F | | | | т | EST. SDL | .c | | | | | |---------------|----------|--------------|-------------|-------------|--------------|------------|----------|----------|-----| | LOC | OBJ CODE | M STMT S | | | | | ASM | 5.9 | 1 | | 012F | D303 | 295 | | OUT | (SIOCB), A | | | | | | 0131 | C9 | 296 | | RET | | | | | | | | | 297 | SETOVR: | | | | | | | | 0132 | CBEE | 298 | | SET | 5,(HL) | • | | | | | 0134 | C9 | 299 | | RET. | _ | | | | | | | | | SETCRC: | | • | | | | | | 0135 | CBF6 . | 301 | | SET | 6, (HL) | | | | | | 0137 | C9 | 302 | | RET | * | , | | | | | | | | SETEFF: | | | | | | | | 0138 | CBFE | 304 | | SET | 7, (HL) | | 100 | | | | 013A | C9 | 305 | | RET | | 4.4 | | | | | | | 306 | | | | 100 | | | | | | | | CHATBE: | | | | | • | | | 013B | CD5901 | 308 | | CALL | SAVE | ; CH. A | TX BUFFI | ER EMPTY | | | 013E | 3E28 | 309 | | LD | A, TBERES | * 4 | | * | | | 0140 | D301 | 310 | | OUT | (SIOCA), A | | | | | | 0142 | C9 | 311 | | RET | | • | * , * * | | | | | | 312 | | | | | | | | | | | | CHAESC: | | | | | 100 | | | 0143 | CD5901 | 314 | | CALL | SAVE | J CH. A | EXTERNAL | _/STATUS | CHG | | 0146 | 3E10 | 315 | | LD | A, ESCRES | 7 | | | | | 0148 | D301 | 316 | | DUT | (SIOCA), A | 1 | | | | | 014A | C9 | 317 | | RET | | | | ř | | | | | 318 | | | | | 7.5 | | | | 0145 | | | CHARCA: | | | | 247 | | | | 014B | CD5901 | 320 | | CALL | SAVE | J CH. A | RX CHAR | AVAIL. | | | Q14E | 0000 | 351 | | IN | A. (BIODA) | | | | | | 0150 | CS | 322 | | RET | | * * | | | | | | | 353 | | | | 1 | | | | | A 4 E 4 | ADECA4 | | CHABRC: | | *. | * 4 1 | | | | | 0151 | CD5901 | 325 | | CALL | SAVE | ı CH. B | SPECIAL | RX COND. | | | 0154 | 3E30 | 326 | | LD | A. SRCRES | | | | | | 0156 | D301 | 327 | | OUT | (SIDCA);A | | -1 | | | | 0158 | C9 | 328 | | RET | | | | | | | | | 329 | | | | | | | | | | | 330 | | BAVE RE | GISTER ROUTI | NE | | | | | | | 331 | 3415. | | | | 4 | | | | 0159 | E3 | | BAVE: | =- | 4 mm 1 | | | | | | 0154.<br>015A | D5 | 333 | | EX | (SP), HL | . SP = | HL. | | | | 0158 | C5 | 334 | | PUSH | DE | | DE. | | 1- | | 015C | F5 | 335 | | PUSH | BC | i | ВC | | | | 0150 | DDE5 | 336 | • | PUSH | AF . | 1 | AF | | | | 015F | FDE5 | 337 | | PUSH | IX | ; | 1 X | | | | 0161 | CD6F01 | - 338<br>339 | | PUSH | IY | • • | ΙΥ | | | | 0164 | FDE1 | 340 | | CALL<br>POP | <b>G</b> D | , | PC | | | | 0166 | DDE1 | 341 | | 202<br>202 | IY<br>IX | • | | • | | | 0168 | F1 | 342 | | POP | AF | | | | | | 0169 | Ci | 343 | | POP | BC . | | | | | | 016A | D1 | 344 | | POP | DE | | | A | | | 0168 | Ēi | 345 | | POP | HL | | | | | | 016C | FB | 346 | | EI | пь | | | | | | 016D | ED4D | 347 | | RETI | | | | | | | | | 348 | • | | | | | • | | | | | | <b>:</b> O: | | | | | | | | 016F | E9 | 350 | _ | JP | (HL) | | | | | | | | | E | | | | | | | | | | 352 | _ | | | | | | • | | | | | , ( | CONSTAN | rs | | | | * | | | | 354 | _ | | . – | | | | | | | | | IOTA: | | | | | | | | 0170 | 00 | 356 | | DEFB | SIOWRO | ; CHAN. | PERET | | | | 0171 | 18 | 357 | | | CHRES | r writtin. | | | | | 0172 | 01 | 358 | | DEFB | SIOWR1 | ; CHAN | CHARACS. | | | | 0173 | D2 | 359 | | DEFB | WREN+RDY+RX | | JIIIIII | | • | | 0174 | 04 | 360 | | DEFB | SIOWR4 | MODE | | | | | 0175 | 4F | 361 | | DEFB | X16+STOP2+E | | | | | | 0176 | 05 | 362 | | EFB | SIOWR5 | TX PAI | RAMS. | | | | 0177 | AA | 363 | | EFB | DTR+TX7+TXEN | | | | | | 0178 | 03 | 364 | | EFB | SIOWR3 | RX PAR | RAMS. | | | | 0179 | 41 | 365 | | )EFB | RX7+RXEN | | | | | | | | 366 S | | QU | \$ | | | | | | | | 367 | | | | | , | | | | | | | , | | | | | | | ``` TEST. SDLC ASM 5. 9 LOC OBJ CODE M STMT SOURCE STATEMENT 368 SICTB: SIOWRO ; CHAN. RESET 017A 00 369 DEFB DEFB CHRES 017B 18 370 ; VECTOR REG. SIOWR2 017C 02 371 DEFB DEFB SIOVEC, AND, 255 017D 10 372 , MODE DEFB SIOWR4 017E 04 373 X1+SDLC+SYNCEN 017F 20 374 DEFB SIOWRI CHAN. CHARACS. 0180 01 375 DEFR RXIA+SIOSAV+TXI+EXTI 376 DEFB 0181 1F DEFB SIOWR6 ; ADDRESS 377 0182 06 378 DEFB ADDRESS 9E 0183 07 379 DEFB SIOWR7 FLAG 0184 0185 7E 380 DEFB 01111110B 05 381 DEFB SIOWR5 ; TX PARAMS. 0186 0187 EB 382 DEFB DTR+TX8+TXEN+R S+TXCRC SIOWR3 RX PARAMS. 0188 383 DEFB DEFB RX8+RXEN 0189 C1 384 SIŒB: EQU 385 386 387 CLST: 018A 388 DEFB 28H PORT B MODE 00000000В 2ВН 0188 00 389 DEFB DEFB DATA DIRECTION 018C 28 390 EE 1C C2 DEFB 11101110B 391 01BD 392 1CH CT1 MODE DEFB 018E 11000010B 16H 393 DEFB 018F 394 DEFB CT1 TC MSB 0170 16 0171 395 DEFB 00 17H LSB 0172 376 DEFB 17 0193 60 397 DEFB CIOCNT ; MASTER CONFIG. REG. 0194 01 378 DEFB 11110000B 0195 FO 399 DEFB CT1 TRIGGER DEFR 0196 OA 400 10 00000110B DEFB 0197 401 402 CEND: EQU 403 #Ε 404 DATA AREA 405 ;; 406 2000 407 ORG 2000 408 DEFS 64 STACK AREA 409 STAK: EQU $ ISIO FLAG BYTE 2040 410 SICFLC: DEFS BUFFER BYTE COUNT 411 BYTES: DEFS 2041 RESPONSE TIMER 412 RSPTMR: DEFS 2042 2043 413 BUFPTR: DEFS BUFFER POINTER 2045 414 BUFFER: DEFS ; BUFFER READ BUFF PTR 415 RBPTR: DEFS 2085 416 RBUF: EGU 417 418 END ``` 617-1564-0007 617-1 ## Binary Synchronous Communication Using the Z80 SIO ### **Application Note** A popular communication protocol used to exchange information between data processing devices has been in use for some time. This protocol, developed by IBM, is called binary synchronous protocol, or bisync. The Z80 S10 provides a flexible and powerful tool for the implementation of the bisync protocol. However, there are some design considerations that require special attention. This paper will discuss these design considerations and offer an approach to using bisync with the Z80 S10. Specific examples are presented and readers who are unfamiliar with the bisync protocol should refer to the ANSI standard (1) or the IBM publication (2) listed at the end of this paper. Bisync is a character-oriented protocol with Information transmitted in blocks between two (or more) data communication devices. The medium through which this information is conveyed is called the data link. The particular data link discussed in this paper is a point-to-point link using the ASCII transmission code. Other codes, such as EBCDIC, are not covered, but the format for bisync is basically the same. The data link consists of a master station (usually a computer) and a slave station (usually a terminal) with the associated communication gear in betweenmodems, phone lines, etc. The master station controls message flow by polling and selecting the slave station. Polling involves send-Ing a general request message to the slave station(s) to determine whether or not any of the slaves have data to send (traffic). If a slave station does have traffic, it responds to the poll and the master can then select that particular slave for information exchange. Slaves can only respond to a master device and cannot initiate communication on the data link. Information is exchanged by means of a weildefined block structure. Message blocks consist of a header, body, and trailer (Figure 1). The header is made of two or more SYN characters (hence the name bisync), a start of header (SOH) character, and addressing and control information for a particular slave station. Figure 1. Basic Message Block Format for Bisync Protocol The body begins with a start of text (STX) character and encompasses the entire text information. The body generally contains ASCII text data, although 8-bit binary data can be transmitted using transparent text The trailer contains the end of text (ETX) character and the block check character (BCC). The BCC is used for detecting errors through "cyclic redundancy checking" (CRC) or "iongitudal redundancy checking" (LRC). Error detection is essential when transferring information between data processing equipment. Since ASCII specifies only seven bits for its code, the eighth bit is used for vertical redundancy checking (VRC), more commonly known as character parity. In synchronous communications, character parity is generally odd, whereas in asynchronous communications it is even. Figure 2 shows typical ASCII characters with parity. The SIO can be programmed for 7-bit characters with odd parity enabled to minimize software overhead. This application note refers to products as Z80 "A", "B" etc. to specify the speed grade. We are no longer using those characters for the speeds. For more details, please refer to the ordering information section. Figure 2. Odd VRC. Number of 1s should be odd. Because VRC applies only to the Individual character, the entire message block has an LRC that makes up the BCC. The LRC is a simple bit position checksum where the number of is for each position (0 through 6) is even for a block of data. Since the BCC is a character, LRC is subject to the same character parity rules as the rest of the data block. The LRC includes all characters, except SYN, starting with the first character after SOH or STX and up to and including ETX in the trailer (Figure 3). Since the SIO cannot calculate the LRC, the task is left up to the user. LRC can be generated on a microprocessor with little effort by taking the message block and XORing the data with an initial value of zero to provide even LRC. | | s | S | S | \$ . | E. | В | |---|-----|---|---|------|----|---| | | , Y | Υ | 0 | T | Т | С | | | N | N | Н | x | x | С | | ŧ | | | _ | | | | Included in BBC Figure 3. Characters included in BBC Another type of BBC is generated by a cyclic redundancy check (CRC), which results in a more powerful method of block checking. CRC-12 is used for 6-bit transmission code and CRC-16 is used for 8-bit transmission code. CRC is used in lieu of character parity and LRC, as with transparent text mode operation. The remainder of this paper lilustrates how to use the SIO in three special cases of the bisync protocol: transparent text mode, abort/interrupt procedures, and error recovery procedures. Transparent text mode is useful in bisync when information exchanged between master and slave is not ASCII data. For example, a binary data file (object program) might be sent from master to slave. ASCII transmission code is only seven bits long making it difficult to send 8-bit binary data. One alternative is to convert the binary data to ASCII hex format at the master, transmit it to the slave and reconvert it back into binary at the slave. However, two disadvan- tages result from this. First, the master and slave require a means of conversion, by either software or hardware, adding cost to the data link. Since the slave (terminal) is burdened most by this, such an approach is usually not feasible. The other disadvantage is that the exchange of information is slower since two (or more) ASCII characters are sent for every eight bits of binary data. The bisync protocol has provisions for sending 8-bit binary data by using transparent text mode transmission. In this mode, character parity is disabled, allowing the full eight bits to be used for data. However, to allow control within the constraints of the protocol, there are certain limitations on the binary data pattern. The primary difference is that during transparent mode some communication control characters are preceded by a DLE character, actually making the control characters a two-character sequence. To distinguish a data byte from a control DLE, the protocol specifies insertion of another DLE. The receiver them throws away the first DLE, keeping the second as data. Table 1 shows the communication control characters that are valid during transparent mode. Another character change occurs when the SYN character is used for line fill. Normally, the SYN character is ignored, but during transparent mode the SYN is preceded by a DLE, and both are consequently ignored by the receiver. In the event that the CPU does not have a character ready to send, the SIO automatically inserts SYN characters into the data stream. With the SIO programmed for 16-bit sync characters, two syncs are sent from the SiO (write registers WR6 and WR7) when its transmit buffer is empty. In transparent mode, the user must change WR6 and WR7 to DLE, SYN in order for the SIO to provide the proper line fill characters. In accordance with the ANSI standard, line fill characters are not included in the SIO CRC calculation during transmit. During reception in transparent mode, the software must disable CRC accumulation when the DLE SYN character sequence is detected. While in transparent mode, the user must be concerned with the error detection codes. If parity is enabled in the SIO normally, it must be disabled during transparent mode. This change in SIO operation affects both transmit and receive and should therefore be considered if using full duplex. Table 1. Control Codes Used In Transparent Mode | Start of transparent text | |-------------------------------| | End of transparent text block | | End of transparent text | | Idle sync | | Enquiry | | DLE data | | Start of transparent header | | | 617-1 master sion, by cost to minai) is pach is sadvantage is slower ; are sent The ending int text aracter i eight to allow e proton the fference communited by a ontrol To of DLE. mother the first ale I icters maily, Ing by a d by the does not 10 autothe for sen† WR7) n transand WR7 abivoaccordi charcalcution in sable 'acter ie. ist be les. If it de. oth xt block Since the SIO allows CRC enable/disable on the fly, the software can easily control CRC accumulation in both receive and transmit. During transmit, the CRC must be enabled/ disabled before the character is transferred into the serial shift register. During receive, the CRC accumulation is delayed eight bits. After the character is transferred from the serial shift register into the buffer. the user has to read that character. decide whether or not to continue CRC accumulation, and disable/enable CRC before the next character is transferred to the buffer. This is not generally a problem, since character transfers occur about every 833 microseconds at 9600 baud. Table 2 shows the characters included and omitted in the CRC during transparent mode. Table 2. Characters included/Omitted in CRC During Transparent Mode | Omitted from CRC | Included In CRC | |---------------------|----------------------| | DLE SYN | DLE of DLE DLE | | DLE SOH | ETX of DLE ETX | | DLE STX# | ETB of DLE ETB | | | STX of DLE STX** | | 7 | | | *If not preceded by | **if preceded by DLE | | transparent header | SOH within same | block within same block When CRC accumulation is to be resumed, the software should enable CRC before the desired character is transferred to the receive buffer. For example, suppose a DLE pair is received during transparent text mode. The SIO generates an interrupt when the first DLE is transferred to the receive buffer. The driver program reads the DLE and immediately disables CRC. When the next interrupt occurs, the driver reads the second DLE and immediately enables CRC to include the second DLE into the CRC accumulation. The second category of interest includes abort and interrupt procedures. There are two types of aborts: block abort and sending station abort. There are three types of interrupts: termination interrupt, reverse interrupt and temporary interrupt. The block abort is used by the sending station when, in the process of transmitting a data block, the sending station detects an error condition in the data and decides to terminate the block so that the receiving station will discard it. In nontransparent mode, block abort is accomplished by ending the block with an ENQ character, instead of ETX or ETB. The sending station then waits for a reply from the receiver, which should be a NAK. The transparent mode procedure is identical except that a DLE ENQ character sequence is used. Since a block abort puts the data link back in nontransparent mode, NAK is the valid response the receiver should send in both transparent and nontransparent modes. The sending station abort is similar to the block abort, except that the sending station does not necessarily do a block abort but simply ends the current message block, waits for a response or timeout, and then sends an EOT to regain control of the data link. The sending station abort is useful when transmission to a particular receiver is necessary due to a higher priority message, buffer overflow condition, error detection, etc. Once the sending station abort sequence is made, the master can perform any data link control function. From the receiver side, a termination interrupt causes the sending station to stop transmission. Such a procedure is useful when the receiver cannot accept any more data or incurs an error condition, such as paper jam, card jam, hardware error, etc. To accomplish a termination interrupt, the receiving station sends an EOT instead of the normal response. The EOT resets all stations on the link and allows the master to issue any control sequence. The reverse interrupt (RINT) is used when the receiving station needs to transmit during reception of several message blocks. The RINT occurs when a receiver detects a valid CRC or LRC and, instead of returning an ACK, sends a DLE "<" character sequence to signal an affirmative acknowledgement and to stop transmission of data. Some exceptions and a more detailed description of RINT can be found in the ANSI standard. The temporary Interrupt procedure, WACK (Wait Before Sending Positive Acknowledge), is used by the receiving station to indicate positive acknowledgement and an inability to receive more data. Such a response may be necessary when the receiving station cannot accept data continuously, such as during a printing operation. The WACK consists of a DLE ";" character sequence and is sent in place of an ACK or ACKn. The sending station then sends ENQs (Enquiry) until the receiving station sends an ACK or ACKn. Recovery procedures provide a means of preventing data link instability. The recovery mechanism consists mainly of timers, grouped into four basic areas, and a NAK counter. The NAK counter is used to prevent repeated NAKs from inhibiting further communications. The sending unit counts how many NAKs it receives for a particular data block so that after a predetermined number of retries, it can recover and pursue another course of action. The particular count value and course of action taken when the count expires are left up to the user. Four timers (timer A or response timer, timer B or receiver timer, timer C or gross timer, and timer D or no activity timer) prevent the data link from getting "hung" or going idle for extended periods of time. Generally, the shortest interval is used with timer A, and the longest interval is used with timer D. For maximum system efficiency, however, the receiver timer (timer B) should timeout before the response timer (timer A). The particular implementation of these timers varies from system to system, and some fiexibility of exact timer values is left up to the user. Since it is assumed that interrupts will be used with the SIO, an interrupt driven receiver timer count is kept in memory and is reinitialized each time a character is received (receive interrupt). The same applies for the response timer, except that when a timeout occurs, the transmit driver has several options to follow. If the SIO is set to transmit CRC on transmit underrun, then the driver could simply set its flags and not fill the buffer. This allows a normal exit, since the SIO will then send its CRC bytes. If the SIO is set to not transmit CRC on transmit underrun, then it sends sync characters (SYN SYN or DLE SYN, whichever was last written to WR6 and WR7) until the transmit buffer is filled or transmit data is set to marking. In any event, enough time must be allowed after CRC is sent so that the receiver can properly decode CRC. Because of the character delay in the SIO during CRC accumulation, about 20 clock cycles are necessary after the last CRC byte is sent to ensure adequate decoding time. (See the SIO Technical Manual for further details.) The SIO could be programmed to send pad characters either by disabling parity and sending 8-bit FFs (hex) or by filling WR6 and WR7 with FF hex. If enabled, the SIO automatically sends whatever is in its sync registers upon transmit underrun. Muitiple message blocks do not have to be separated by pad characters as long as CRC is valid for the previous message block. However, to insure adequate time for the receiver to process CRC, it is recommended that at least two pad characters follow the last character of a block. Using the SIO for the bisync protocol is fairly straightforward. Care should be exercised when using the SIO in transparent text mode, but the implementation is greatly simplified by the SIO's flexibility, as compared to other serial communications iCs. The CRC capabilities of the SIO provide a powerful means of maintaining maximum data integrity with minimum software overhead. Coupled with the DMA and the interrupt capabilities of the ZBO processor, the user will find the SIO an excellent choice in serving data communication needs. - (1) American National Standards Institute. ANSI X3.28 - 1976. - (2) "General Information Binary Synchronous Communications." Pub. number GA27-3004-2. roviding # Timing in an Interrupt-Based System with the $Z80^{\circledR}$ CTC ## **⊘**ZilŒ ## **Application Note** INTRODUCTION in many computer systems, an accurate time base is needed so that critically timed events do not go awry. Use of a counter or timer to monitor time-dependent activities is essential in such systems. In an interrupt-driven system, the Z80 CTC can provide regular program time intervals. Single-event counts or single-event time delays can also be implemented under program control. This application note describes both continuous time-interval operations and single-interval count operations using the Z80 CTC in a Z80 system. HARDWARE CONFIGURATION In the example used here, the hardware consists of a Z80 CPU with 4K bytes of RAM, 4K bytes of ROM, a Z80A S10, and a Z80A CTC. There are two external inputs to the CTC: one is derived from the ac power line to provide 60Hz pulses; the other is connected to a transmit clock line on the SIO. One of the counter/timer outputs is connected to the SIO transmit and receive clock input, as shown in Figure 1. Figure 1. ZBOA System Block Diagram This application note refers to products as Z80 "A", "B" etc. to specify the speed grade. We are no longer using those characters for the speeds. For more details, please refer to the ordering information section. The Z80 CTC is designed for easy interface to the Z80 CPU. An 8-bit bidirectional data bus is used to transfer information between the CTC and CPU. The control lines, $\overline{RD}$ , $\overline{IORQ}$ , $\overline{MI}$ , and $\overline{CE}$ , determine what data is being transferred and when. $\overline{Mi}$ and $\overline{IORQ}$ are used during the interrupt acknowledge cycle to allow the CTC to present its 8-bit interrupt vector to the CPU. $\overline{IORQ}$ is also used in conjunction with $\overline{CE}$ to enable transfers between the CTC and the CPU. $\overline{RD}$ is used to control the direction of data flow between the CTC and CPU. The channel select lines (CSQ) and CS1) are connected to the lowest two bits of the address bus and are used to access one of the four counter/timer channels. Table is shows the relationships between the CS pins and the counter/timer channels. Table 1. Channel Select Values | cs <sub>1</sub> | cs <sub>0</sub> | C/T Channel | | | | |-----------------|-----------------|-------------|--|--|--| | 0 | 0 | Channel 0 | | | | | 0 | 1 1 | Channel I ` | | | | | 1 | 0 | Channel 2 | | | | | | 1 | Channel 3 | | | | The CTC system clock input requirements are similar to those of the Z80 CPU. For both, the system clock input Low level should be no greater then 0.45 V, the High level should be no less than $V_{\rm CC}$ -0.6 V, and the clock rise and fall times should be less than 30 ns. A clock-driver device that meets these requirements, such as the HH-3006-A , works well with the CTC. Several devices can be connected to the driver, but the user should be careful not to overload the driver. The capacitance of the clock input to the CTC (20 pF) should be noted as this may affect the system clock rise and fall times. interrupt control logic within the CTC is used to initiate interrupts and to control the interrupt acknowledge cycle generated by the CPU. An interrupt is generated by the CTC when one of the counter/timer down counters reaches terminal count (0) and iEi is High. IEI and IEO allow the CTC to operate within the Z80 interrupt daisy chain and to connect to the next higher-priority and next lower-priority devices in the chain, respectively. If there is no higher-priority device, IEI is tied to +5 V. The CTC Internally prioritizes each counter/ timer with respect to interrupt generation. This maximizes performance by resolving contention between channels should two or more interrupt conditions occur simultaneously. Table 2 shows the relative priority levels of each counter/timer within the CTC. Table 2. CTC Channel Interrupt Priority | Priority | Channei | |----------|---------| | Highest | 0 | | Lowest | 2 3 | CTC MODES There are two basic modes under which the CTC can operate: Timer mode and Counter mode. Each mode has certain programmable character— istics that enable the CTC to be used in a wide variety of applications. #### TIMER MODE A typical use of the CTC in Timer mode is to provide regular, fixed-interval interrupts to the CPU used as a time-base reference to allocate the processor resources efficiently. For example, a multitasking system might have the processor execute a task for a given length of time and then interrupt execution of the program at one-second intervals to scan the task queue for higher-priority tasks. This system time interval can be provided by the CTC in Timer mode, in Timer mode, the CTC downcounter is decremented by the output of the prescaler, which is toggled by the system clock input. The prescaler has a programmable value of 16 or 256, depending on the condition of bit 5 in the channel control word (CCW). Thus, with a 4 MHz system clock fed into the CTC, a timer resolution of 4Ms (prescaler count of 16) or 64Ms (count of 256) is possible. In the example shown, the Interrupt Interval is set to 8.33 ms, which is provided by the CTC with a 3.6864 MHz input clock, 256 prescaler value, and a time constant value of 120. The CTC interrupt service routine uses a software count of 120 to maintain a one-second system time interval. Each time the service routine is executed, the software count is decremented by 1. When the count reaches 0, a flag is set and the program pursues an appropriate course of action. Figure 2 shows the initialization and interrupt service routine coding for a CTC channel using the Timer mode. Another use of CTC Timer mode operation is to implement a nonretriggerable one-shot using external circultry. The digital approach to the one-shot provides a programmable time delay under CPU control and provides greater noise immunity than the more common analog delay circuits provide. Figure 3 shows a circuit that uses part of a 74LSO2 package in addition to one CTC channel. The trigger waveform should be positive-going and should meet the CTC setup time for the CLK/TRIG input. Also, the trigger High level time should be less than the CTC delay time in order to prevent the two 74LS02s from latching in the triggered state. An additional gate can be added to initialize the 74LS02 filp-flop to a defined state when the system is reset or else the software can pulse the timer output to set the filp-flop, as is done in this case. A third use of the Timer mode is to provide a bit rate clock for a serial transceiver device, such as the Z80S10. The S10 can accept a ix, 16x, 32x, or 64x bit rate clock input from an external source, and with a 16x, 32x, or 64x multiplier, the S10 can accept a pulse waveform input for the bit rate clocks, as long as the pulses meet the rise, fall, and hold time requirements of the S10. The CTC meets these requirements and can be connected directly to the S10 to provide the necessary bit rate clocks. Figure 4 shows the code needed to generate a bit rate clock for the S10. A clock driver by Hybrid House, 1615 Remuda La., San Jose, CA 95112. uid be capa-20 pF) system TC is itro! ed by e CTC iters igh. Ithin nect next ter/ on. coniore ily. i of to ng to me er og a de- With a 1x bit rate clock programmed into the SiO, a square-wave input must be supplied. This can be done by adding a filp-flop between the CTC and the SiO. The time constant value should be set to half the baud rate value, since the CTC output is divided in half by the filp-flop. Figure 2. Software for CTC Timer Mode Operation Figure 3. Monostable Multivibrator Using the Z80 CTC ``` TEST. CTCO ``` ``` CTC TEST PROGRAM 3 THIS PROGRAM USES THE CTC IN CONTINUOUS TIMER MODE. THE CTC COUNTS SYSTEM CLOCK PULSES AND INTERRUPTS EVERY 120 PULSES, THEN DECREMENTS A COUNT, THEN SWITCHES THE LED STATE WHEN THE COUNT REACHES ZERO. PROGRAM EQUATES 10 11 CTCO: EQU CTC O PORT 12 EQU CTCO+1 CTC 1 PORT 13 CTC2: CTCO+2 FQU FOTO 2 PORT CTC3: EQU CTCO+3 ICTC 3 PORT 15 LITE: EQU OEOH ILIGHT PORT 16 RAM: EQU 5000H RAM START ADDR 17 RAMSIZ: EQU 1000H 18 TIME: EQU 120 COUNT VALUE 19 20 21 CTC EQUATES 22 23 CCW: EQU 24 INTEN: EQU вон 25 CTRMODE: EQU. 4014 26 P256: ^{\prime}20H FQU 27 RISEDG: EQU 10H 28 PSTRT: EQU 8 29 TCLOAD: EQU 30 RESET: EGU 31 #E 33 35 . . *** MAIN PROGRAM 34 0000 35 ORG 0000 C31800 36 JP REGIN 37 0010 38 ORG $, AND, OFFFOH, OR, 10H 39 INTVEC: 0010 4000 40 DEFW ICTCO 0012 3D00 41 DEFW ICTC1 0014 3D00 42 DEFW ICTC2 3D00 0016 43 DEFW ICTC3 44 BEGIN: 0018 314020 SP, STAK ; INIT SP 001B ED5E 47 ΙM VECTOR INTERRUPT MODE 001D 3F00 48 LD A, INTVEC/256 JUPPER VECTOR BYTE 001F ED47 49 LD 0021 CD2700 50 CALL INIT INIT DEVICES 51 IALLOW INTERRUPTS ΕI 52 0025 18FE 53 JR ; LODP FOREVER 54 INIT: 55 0027 3EA7 56 57 L.D A, INTEN+P256+TCLOAD+RESET+CCW 0029 D3OC DUT (CTCO), A SET CTC MODE 0028 3E78 58 LD A, TIME 0020 DOC 59 OUT (CTCO), A SET TIME CONSTANT 002F 3E10 60 LD A, INTVEC. AND. 11111000B 0031 D30C 61 DUT (CTCO), A SET VECTOR VALUE 0033 AF 62 XOR 324120 0034 63 LD CLEAR DISPLAY BYTE ; INIT TIMER VALUE (DISP), A 0037 3E78 64 A. TIME 0039 324020 65 LD (COUNT), A 0030 C9 66 67 RET #E 68 INTERRUPT SERVICE ROUTINE 70 ``` 751- ``` TEST: CTCO OBJ CODE M STMT SOURCE STATEMENT LOC ICTC1: 72 ICTC2: 73 74 75 ICTC3: ; DUMMY ROUTINES ΕI 003D FB RETI ED4D 003E 76 77 78 ICTCO: SAVE REGISTERS CALL SAVE CD5A00 0040 CHANGE TIMER COUNT A. (COUNT) LD 3A4020 0043 DEC 80 3D 0046 (COUNT), A 81 LD 324020 0047 EXIT IF NOT DONE NZ RET 82 004A CO ELSE, RESET TIMER VALUE A, TIME L.D QQ4B 3E78 83 LD (COUNT), A 004D 324020 84 BLINK LITES LD A. (DISP) 85 0050 3A4120 CPL 86 0053 2F (DISP), A 87 LD 324120 0054 (LITE), A 88 OUT 0057 DBEO 89 RET C9 0059 90 SAVE REGISTER ROUTINE 91 92 93 SAVE: 94 ΕX (SP), HL 005A E3 95 PUSH DΕ 005B D5 96 PUSH BC C5 F5 005C AF PUSH 97 005D GD CALL CD9800 98 005E AF POP 99 0061 F1 BC POP 0042 C1 100 POP 0063 D1 101 POP 102 0064 E1 ΕI 103 0065 FB RETI 104 ED4D 0056 105 106 GO: (HL) JP E9 0068 108 #E 109 DATA AREA 110 , , 111 ORG 2000 112 STACK AREA DEFS 64 113 5000 114 115 STAK: EQU $ ; TIMER COUNT VALUE COUNT: DEFS 1 2040 LITE DISPLAY BYTE 116 DISP: DEFS 2041 117 END 118 START ``` Figure 4. Software for CTC Bit Rate Generator 4/1/81 RUPT MODE BYTE UPTS STANT ALUE: / BYTE ALUE Jous -DCK BES, 1ES DDR ZERO | L | .oc | OBJ | CODE | М | STMT | SOURCE | TEST, CTC | | | | | | |-----|----------|------------------------------|------|---|----------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------|---------------------------------------------|------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------|-------------| | | | | | | 1 | i ; | CTC TES | ST PROGR | AM | | | | | , K | | · · . | ÷ | | 2<br>3<br>4<br>5<br>6<br>7<br>8 | ;<br>;<br>; | TIMER N<br>CLOCK T<br>THE SYS<br>DIVIDED | 10DE, TH<br>TO THE S<br>STEM CLO<br>) BY 16 | E CTC SUI<br>IO FROM<br>CK IS 3.4<br>BY THE PI | CTC IN CO<br>PPLIES A<br>THE SYSTE<br>6864 MHZ,<br>RESCALER,<br>UE OF 3 1 | BIT RATE<br>M CLOCK<br>WHICH<br>AND DI | E<br>IS | | | | • | | | 9<br>10<br>11<br>12<br>13 | i | TO THE | SIO. OT | DIFFERE | UD CLOCK<br>RATES CA<br>NT TIME C | | TAINED | | | | | | | 14<br>15 | i | PROGRAM | 1 EQUATE: | S | | 10.1 | | | | | | | | 16<br>17<br>18<br>19<br>20<br>21 | CTCO:<br>CTC1:<br>CTC2:<br>CTC3:<br>TIME: | EGU<br>EGU<br>EGU<br>EGU | 12<br>CTCO+1<br>CTCO+2<br>CTCO+3<br>3 | | ; CTC 0<br>; CTC 1<br>; CTC 2<br>; CTC 3 | PORT . | VALUE | | | • | | | | 23 | i | CTC EQL | IATES | | | | | | | | | | • | 24<br>25<br>26<br>27<br>28<br>29<br>30<br>31<br>32<br>33<br>34<br>35 | *E | EGU INTEN: CTRMODE P256: RISEDG: PSTRT: TCLOAD: RESET: | EQU<br>EQU | 80H<br>EQU<br>20H<br>10H<br>8<br>4<br>2 | <b>40</b> H | | | | 000 | 00 | | | | 37<br>38 | BEGIN: | ORG | 0 | | | | | | 000 | 02<br>04 | 3E07<br>D30E<br>3E03<br>D30E | | | 39<br>40<br>41<br>42 | , | LD<br>OUT<br>LD<br>OUT | A, TCLOA<br>(CTC2),<br>A, TIME<br>(CTC2), | | ;SET CT | C MODE | <b>FANT</b> | | | | _ | | | 43<br>44<br>45<br>46 | ;<br>*E | | | DES HERE | | | | | 000 | 90 | 18FE | | | 45<br>47<br>48 | | JR | \$ | | ;LOOP F | OREVER | | | | | | | | 49 | | END | | | | 1 1 | | #### COUNTER MODE A typical computer system often uses a time-of-day clock. In the United States, the 60 Hz power line provides an accurate time base for synchronous motor clocks. A computer system can take advantage of the 60 Hz accuracy by incorporating a circuit that feeds 60 Hz square waves into a CTC channel. With a time constant value of 60, the CTC generates an interrupt once every second, which can be used to update a time-of-day clock. The CTC is set to Counter mode and with a time constant value of 60, as shown in Figure 5. The interrupt service routine does nothing more than update the time-of-day clock. A more sophisticated operating system kernel would use the CTC to check the task queue status. In synchronous data communications, it is often necessary to ensure that a flag or sync character separates two adjacent message packets. Since some serial controller devices have no way to determine the status of sync characters sent, the user must use time delays to separate messages with the appropriate number of sync characters. Typically, software or timer delays are used to provide the time necessary to allow the characters to shift out of the serial device. The disadvantage of using this method is that variable baud rates shift characters at variable times so a worst-case time must be allowed if the baud rate is not known. If the bit rate clock is suppiled by the modem, as is normally the case, this problem becomes even more acute. A solution to this problem is to use a counter to count the number of bits shifted out of the serial device. With the CTC tied to the transmit clock line of the serial device, the CTC can be programmed to delay a certain number of bits before the CPU sends another message. This solves all of the problems mentioned and simplifies the messagehandling software. Figure 6 shows the program needed to achieve the counting function. Note that the interrupt service routine disables the CTC, because the CTC is used only once with each message. Otherwise, the CTC would generate an interrupt each time the counter reached terminal count. Figure 1 shows the hardware implementation of the character delay counter using the $\mbox{CTC}_{\bullet}$ a) Main Program interrupt Service Routine Figure 5. Software for CTC Counter Mode #### OBJ CODE M STMT SOURCE STATEMENT LOC | 1 | • | CTC TEST | PROGRA | M | | | | |--------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------|------------------------------------|-----------------------------------|-----------------------------------------|----------------| | 2<br>3<br>4<br>5 | ;<br>; | THIS PROG<br>CHANGES T | RAM CO | ÚNTS EXT<br>STATE E | ERNAL PU | JLSES A | ND | | 6 | <b>;</b> | PROGRAM E | QUATES | i | | | | | 8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 | CTCO:<br>CTC1:<br>CTC2:<br>CTC3:<br>LITE:<br>RAM<br>RAMBIZ<br>COUNT | EOO C.<br>EOO C.<br>EOO C.<br>EOO C. | 2<br>TCO+1<br>TCO+2<br>TCO+3<br>EOH<br>OOOH | | CTC 2<br>CTC 3<br>LIGHT<br>RAM ST | PORT<br>PORT<br>PORT<br>PORT<br>ART ADI | OR<br>CONSTANT | | 18<br>19 | ; | CTC EQUATE | S | | | | | | 20<br>21<br>22<br>23<br>24<br>25<br>26<br>27 | CCW: | EGU 1 INTEN: EG CTRMODE: P256: EG RISEDG: EG PSTRT: EG TCLOAD: EG RESET: EG | 10<br>10<br>10 | BOH<br>EQU<br>20H<br>10H<br>B<br>4 | 4011 | | | NT JOUS ATE CK. H IS DIVIDED **JBTAINED** T VALUE with the acters. are used low the device. is that ers at lust be if the em, as becomes ogram Note /1/81 751-1809-0005 607 4/1/81 ``` OBJ CODE M STMT SOURCE STATEMENT LOC #E 29 30 11 *** MAIN PROGRAM *** 31 0000 32 ORG 0000 C31800 · 33 BEGIN JP 34 0010 35 ORG $. AND. OFFFOH. OR. 10H 36 INTVEC,: 0010 3800 37 DEFW ICTCO 0012 3800 38 DEFW ICTC1 0014 DEEW ICTC2 3800 39 0016 3800 DEFW 40 ICTC3 41 42 BEGIN: 0018 314020 43 LD SP, STAK INIT SP 001B VECTOR INTERRUPT MODE EDSE 44 IM 3E00 A. INTVEC/256 45 LD JUPPER VECTOR BYTE 001F ED47 LD 46 47 Ò021 CD2700 CALL ; INIT DEVICES INIT 0024 FB 48 ΕI ; ALLOW INTERRUPTS 49 0025 18FE 50 JR :LOOP FOREVER 51 INIT: 52 0027 3EC7 53 LD A. INTEN+CTRMODE+TCLOAD+RESET+CCW 0029 D3OD 54 DUT (CTC1), A SET CTC MODE 002B 3E3C 55 A. COUNT LD 002D D30D 56 OUT (CTC1), A SET TIME CONSTANT 002F 3E10 57 LD A. INTVEC. AND. 11111000B 0031 D30C 58 OUT (CTCO), A SET VECTOR VALUE 0033 AF 59 XOR 0034 324020 60 (DISP), A LD CLEAR DISPLAY BYTE 0037 61 RET 62 #E 63 INTERRUPT SERVICE ROUTINE 65 ICTCO: 66 67 ICTC2: ICTC3: 68 0038 69 EI. DUMMY ROUTINES 0039 ED4D 70 RETI 72 ICTC1: 003B CD4800 73 CALL SAVE SAVE REGISTERS 003E 3A4020 74 75 A, (DISP) LD BLINK LITES 0041 2F CPL 76 77 0042 324020 (DISP).A LD 0045 D3E0 DUT (LITE), A 0047 C9 78 79 RET 1 80 SAVE REGISTER ROUTINE 81 82 SAVE: 0048 E3 83 ΕX (SP), HL 0049 004A D5 84 PUSH DE C5 85 PUSH BC F5 004B 86 PUSH AF 004C CD5600 87 CALL GD 004F Fi 88 POP AF 0050 C1 89 POP BC 0051 D1 90 POP DΕ 91 92 0052 E1 PUB HL 0053 FB ΕI 0054 ED4D 93 RETI 95 GO: 0056 E9 96 JP (HL) 97 *E 98 ``` TEST, CTC1 TEST. CTC1 LOC OBJ CODE M STMT SOURCE STATEMENT DATA AREA 100 101 102 103 2000 ORG RAM 2000 DEFS STACK AREA STAK: EQU 2040 104 DISP: DEFS LITE DISPLAY BYTE 105 106 END UPT MODE °TS ANT 3YTE INITIALIZE CPU INITIALIZE CTC SETUP SOFTWARE FLAG ENABLE INTERRUPTS READ FLAG BYTE BIT O SET Y RESET BIT O a) Main Program b) Interrupt Service Routine Figure 6. Software for CTC Single-Cycle Use ## LOC OBJ CODE M STMT SOURCE STATEMENT ``` CTC TEST PROGRAM THIS PROGRAM INITIALIZES CTC INTERRUPT VECTOR, 3 THEN STARTS CTC 3, THEN WAITS FOR CTC 3 TO TERMINATE. AFTER TERMINATING, THE CTC INTERRUPT THE CPU AND ENTERS A SERVICE ROUTINE THAT SETS A PROGRAM FLAG TO INDICATE ZERO COUNT, AND RESETS CTC 3. 10 EQUATES 11 12 . RAM EQU 2000H RAM START ADDRESS 13 RAMBIZ: EQU 1000H RAM SIZE CTCO: EQU 12 ICTC O PORT 15 CTC1: EQU CTCO+1 CTC 1 PORT CTC2: 16 EQU. CTCO+2 CTC 2 PORT стсэ: EQU CTC0+3 CTC 3 PORT 18 COUNT: EĠU 20 COUNT 20 PULSES 19 ; ' 20 CTC PARAMETERS 21 22 CCW: FGU CTRL BYTE 23 INTEN: INTERR. ENABLE EGU 80H 24 CTRMODE: EQU 25 P256: FQU 20H PRESCALE BY 256 26 RISEDO: EQU 10H START ON RISING EDGE 27 PSTRT: EQU 8 PULSE STARTS TIMING 28 TCLOAD: EQU ITIME CONST. FOLLOWS 29 RESET: EQU ; SOFTWARE RESET 30 #E 31 0000 32 ORG 0 0000 C31800 33 BEGIN GO MAIN PROGRAM 34 0010 35 ORG $. AND. OFFFOH, OR. 10H INTVEC: 36 37 CTCVEC: 0010 4100 38 DEFW ICTCO 0012 4100 39 DEFW ICTC1 0014 4100 40 DEFW ICTC2 0016 4400 41 DEFW ICTC3 42 43 MAIN PROGRAM 44 45 BEGIN: 0018 318120 46 SP. STAK LD INIT SP 001B 3E00 47 LD A. INTVEC/256 INIT VECTOR REG. 001D ED47 48 LD I.A. 001F ED5E 49 IM. I VECTORED INTERRUPT MG 0021 3E10 50 A, CTCVEC. AND. 11111000B LD 0023 рзос (CTCO), A 51 SETUP CTC VECTOR 0025 3E01 52 LD A, 1 SET FLÁG BYTE 0027 320020 53 LD (FLAG), A 002A 54 ΕI 55 LOOP: 0028 3A0020 57 LD À, (FLAG) READ FLAG BYTE 002E CB47 58 BIT O, A 0030 28F9 59 JR Z, LOOP SBRANCH IF NOT BET 0032 CB87 60 RES O. A. CLEAR FLAG BYTE 0034 320020 61 LD (FLAG), A- 0037 3ED5 62 LD A. INTEN+CTRMODE+RISEDG+TCLOAD+1 0039 D30F 63 OUT (CTC3), A LOAD CTC 3 003B 3E14 64 LD A, COUNT 0030 D30F 65 OUT A.(EDTD) 003F 18EA 66 JR LOOP 67 #E 68 69 INTERRUPT SERVICE ROUTINES FOR CTC 70 ICTCO: ICTC1: ``` 751- | UPT VECTOR, | | |-------------|------| | C 3 TO | - 4 | | C INTERRUP | _ | | TIVIERRUP | Τ, | | THAT SETS | | | IT, AND | - 46 | DDRESS .SES E FER MODE 256 NG EDGE TIMING OLLOWS T NT1 JPT MC | | | | | | TEST, CTC3 | | | |---|------|----------|--------|--------|------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LOC | OBJ CODE | M STMT | SOURCE | STATEMENT | ·. | | | | | | 73 | ICTC2: | | A contract of | | | | 0041 | FB | 74 | | EI. | | DUMMY INTERRUPT ROUT | | | 0042 | ED4D | 75 | | RETI | | | | | | | 76 | | | | | | | | | • 77 | ICTC3: | | | | | | 0044 | 08 | 78 | , | EX | AF, AF' | | | | 0045 | 3E03 | 79 | -4 | LD | A, 00000011B | ≠RESET CTC 3 | | | 0047 | D30F | 80 | | OUT | (CTC3), A | | | | 0049 | 3A0020 | 81 | | LD | A, (FLAG) | SET PROGRAM FLAG | | | 004C | CBC7 | 82 | | SET | O. A | | | | 004E | 320020 | 83 | | LD | (FLAG), A | the second of th | | | 0051 | OB | 84 | | EX | AF, AF' | | | | 0052 | FB | 85 | | EI | | | | | 0053 | ED4D | 86 | | RETI | | | | | | | 87 | *E | | | | | | | | 88 | | • | | | | | | | 89 | ;; | DATA ARE | ΕA | | | | | | 90 | | 1 | | | | | 2000 | | 91 | | ORG | RAM | • | | | 2000 | | 92 | FLAG: | DEFS | 1 | PROGRAM FLAG BYTE | | | 2001 | | 93 | | DEFS | 128 | , | | | | | 94 | STAK: | EQU | <b>\$</b> | • | | | | | 95 | | • | | | | | | | 96 | | END | | | | _ | | | | | | | | CONCLUSION The versatility of the Z80 CTC makes it useful in a myriad of applications. System efficiency and throughput can be improved through prudent use of the CTC with the Z80 CPU. Coupled with the powerful, vectored interrupt capabilities of the Z80 CPU, the CTC can be used to supply counter/timer functions to the CPU. This reduces software overhead on the CPU and significantly increases system throughput.