# LH0082 Z80 CTC Counter Timer Circuit # Description The Z80 product line is a complete set of microcomputer components, development systems and support software. The Z80 microcomputer component set includes all of the circuits necessary to build high-performance microcomputer systems with virtually no other logic and a minimum number of low cost standard memory elements. The LH0082 Z80 CTC (Z80 CTC for short below) is a programmable, four channel device that provides counting and timing functions for the Z80 CPU. The Z80 CPU configures the Z80 CTC's four independent channels to operate under various modes and conditions as required. The LH0082A Z80A and LH0082B Z80B CTC are the high speed version which can operate at the 4MHz and 6MHz system clock, respectively. ### Features - 1. Four independent programmable 8-bit counter/16-bit timer channels - 2. N-channel silicon gate process - 3. Each channel may be selected to operate in either a counter mode or timer mode ## Pin Connections #### LH0082U/LH0082AU/LH0082BU LH0082M/LH0082AM NC 34 22 NC 39 NC 21 NC GND 7 $\bigcirc$ NC 35 38 NC NC 8 INT 36 20 D<sub>7</sub> RD 9 37 V<sub>CC</sub> 19 D<sub>6</sub> IE1 37 36 NC 18 Ds ZC/TO₀ 10 M1 38 35 CLK/TRG<sub>0</sub> NC II 17 D<sub>4</sub> CLK 39 34 NC ZC/TO<sub>1</sub> 12 ČE 40 16 D<sub>2</sub> 33 CLK/TRG<sub>1</sub> ZC/TO<sub>2</sub> 13 $15 D_2$ RESET 41 32 CLK/TRG<sub>2</sub> $14 D_1$ IORQ 14 CSO 42 31 CLK/TRG<sub>3</sub> 13 NC NC 15 NC 43 12 NC 30 NC NC 44 IEO 16 29 CS1 NC 17 1 2 3 4 5 6 7 8 9 10 11 CLK/TRG: CLK/TRG: CLK/TRG: CLK/TRG: CLK/TRG: Ncc DOG DOG NCG CLK/TRG3 Top View \*The GND pins must be connected to the GND level. - Programmable interrupts on counter or timer states - When the down-counter reaches the zero count the CTC reloads its time constant automatically and continues it's channel operation - 6. Readable down counter - Selectable 16 or 256 clock prescaler for each timer channels - Selectable positive or negative trigger may initiate timer or counter operation - Three channels have ZC/TO outputs capable of driving Darlington transistors - Vectored daisy chain priority interrupt logic included - 11. Single +5V power supply and single phase clock - 12. All inputs and outputs fully TTL compatible - 13. 28-pin DIP (DIP28-P-600) 44-pin QFP (QFP44-P-1010A) 44-pin QFJ (QFJ44-P-S650) # Ordering Information | Product | Z80 CTC | Z80A CTC | Z80B CTC | Z80E CTC | Package | Operating | |-----------------|---------|----------|----------|----------|------------|---------------| | Clock frequency | 2.5MHz | 4MHz | 6MHz | 8MHz | rackage | temperature | | | LH0082 | LH0082A | LH0082B | LH0082E | 28-pin DIP | 0°C to + 70°C | | Model No. | LH0082M | LH0082AM | | | 44-pin QFP | 0°C to +60°C | | | LH0082U | LH0082AU | LH0082BU | | 44-pin QFJ | 0°C to +70°C | # Block Diagram # 5 # Pin Description | Pin | Meaning | I/O | Function | |------------------------------------------------|---------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Do-D7 | Data bus | Bidirectional<br>3-state | System data bus. | | CS <sub>0</sub> , CS <sub>1</sub> | Channel select | I | Selects one of the four independent channels. | | CE | Chip enable | 1 | Active "Low". A Low enables the CPU to transmit and receive control words and data. | | CLOCK | System clock | I | Standard Z80 system clock used for internal synchronization signals. | | M1 | Machine cycle one | I | Active "Low". Indicates that the $\overline{CPU}$ is acknowledging an interrupt, when both $\overline{M1}$ and $\overline{IORQ}$ are active. | | IORQ | I/O request | I | Active "Low". Read operation when RD is active, and write operation when it is not active. Indicates the CPU is acknowledging an interrupt, when both $\overline{\text{IORQ}}$ and $\overline{\text{M1}}$ are active. | | RD | Read cycle status | I | Active "Low". Read operation when active. | | IEI | Interrupt enable in | I | Active "High". Forms a priority interrupt daisy-chain. | | IEO | Interrupt enable out | 0 | Active "High". Forms a priority-interrupt daisy-chain. | | ĪNT | Interrupt request | Open drain, O | Active "Low". Active when requesting an interrupt. | | RESET | Reset | I | Active "Low". Resets the interrupt bits. | | CLK/TRG <sub>0</sub> -<br>CLK/TRG <sub>3</sub> | External clock/timer<br>trigger input | 1 | Counter/timer input for four independent channels. | | ZC/TO <sub>0</sub> -<br>ZC/TO <sub>2</sub> | External clock/timer<br>trigger out | 0 | Active "High". 0/1/2 output for four independent channels. No output terminal at channel 3. | # Absolute Maximum Ratings | Parameter | Symbol | Ratings | Unit | Note | |-----------------------|------------------|----------------|---------------|------| | Input voltage | V <sub>IN</sub> | -0.3 to $+7.0$ | V | | | Output voltage | V <sub>OUT</sub> | -0.3 to +7.0 | V | | | Operating temperature | Topr | 0 to +70 | $^{\circ}$ C | 1 | | Storage temperature | Tstg | -65 to +150 | ${\mathbb C}$ | | Note 1: Topr=0 to +60°C for 44-pin QFP. # DC Characteristics $(V_{CC} = 5V \pm 5\%, Ta = 0 \text{ to } + 70\%^{\text{Note 1}})$ | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------|------------------|---------------------------------------|--------------------|------|----------------|---------| | Clock input low voltage | V <sub>ILC</sub> | | -0.3 | | 0.45 | V | | Clock input high voltage | VIIIC | | $V_{\rm cc} = 0.6$ | | $V_{cc} + 0.3$ | V | | Input low voltage | V <sub>IL</sub> | | -0.3 | | 0.8 | V | | Input high voltage | V <sub>IH</sub> | | 2.0 | | $V_{CC}$ | V | | Output low voltage | V <sub>OL</sub> | $I_{OL} = 2mA$ | | | 0.4 | v | | Output high voltage | V <sub>OH</sub> | $I_{OH} = -250 \mu A$ | 2.4 | | | V | | Supply current | I <sub>CC</sub> | $t_c = 400 ns$ | | | 120 | mΑ | | Input leakage current | $I_{L1}$ | $0 \le V_{IN} \le V_{CC}$ | | | 10 | $\mu$ A | | 3-state output leakage current | I <sub>LOH</sub> | $2.4V \leq V_{OUT} \leq V_{CC}$ | | | 10 | $\mu$ A | | 3-state output leakage current | ILOL | $V_{OUT} = 0.4 V$ | | | 10 | μΑ | | Darlington drive current | I <sub>OHD</sub> | $V_{OH} = 1.5V, R_{EXT} = 390 \Omega$ | -1.5 | | | mΑ | Note 1: Ta=0 to +60°C for 44-pin QFP. # Capacitance (f=1MHz, Ta=25%) | Parameter | Symbol | Conditions | MIN. | TYP. | MAX. | Unit | |--------------------|--------------------|--------------------------|------|------|------|------| | Clock capacitance | C <sub>CLOCK</sub> | 11 | | | 20 | pF | | Input capacitance | C <sub>IN</sub> | Unmeasured pins returned | | | 5 | pF | | Output capacitance | C <sub>OUT</sub> | to ground | | | 10 | pF | # **AC Characteristics** $(V_{CC}=5V\pm5\%, Ta=0 \text{ to}+70^{\circ}\text{C})$ | | _ | | LH0 | 082 | LH00 | )82A | LHO | 082B | LH00 | 082E | F1=:4 | Note | |-----|---------------------------------|--------------|------|-------------|------|------------|---------|------------|------|------------|-------|----------| | No. | Parameter | Symbol | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | Unit | Note | | 1 | Clock cycle time | TcC | 400 | (Note 1) | 250 | (Note 1) | 165 | (Note 1) | 125 | (Note 1) | ns | | | 2 | Clock width (high) | TwCh | 170 | 2000 | 105 | 2000 | 65 | 2000 | 55 | 2000 | ns | | | 3 | Clock width (low) | TwCl | 170 | 2000 | 105 | 2000 | 65 | 2000 | 55 | 2000 | ns | | | 4 | Clock fall time | TfC | | 30 | | 30 | | 20 | | 10 | ns | | | 5 | Clock rise time | TrC | | 30 | | 30 | | 20 | | 10 | ns | | | 6 | All hold times | Th | 0 | | 0 | | 0 | | 0 | | ns | | | 7 | CS to clock † setup time | TsCS (C) | 250 | | 160 | | 100 | | 80 | | ns | | | 8 | CE to clock † setup time | TsCE (C) | 200 | | 150 | | 100 | | 75 | | ns | | | 9 | IORQ to clock t setup time | TsIO (C) | 250 | | 115 | | 70 | | 60 | | ns | | | 10 | RD ↓ to clock ↑ setup time | TsRD (C) | 240 | | 115 | | 70 | | 60 | | ns | | | 11 | Clock to data out delay | TdC (DO) | | 240 | | 200 | | 130 | | 100 | ns | 2 | | 12 | Clock ↓ to data out float delay | TdC (DOz) | | 230 | | 110 | | 90 | | 75 | ns | | | 13 | Data in to clock † setup time | TsDI (C) | 60 | | 50 | | 40 | | 30 | | ns | | | 14 | MI to clock † setup time | TsMl (C) | 210 | | 90 | | 70 | | 55 | | ns | | | 1.5 | MI ↓ to IEO ↓ delay (interrupt | TAM (IEO) | | 300 | | 190 | | 130 | | 90 | ns | 3 | | 15 | immediately preceding MI) | TdMl (IEO) | | 300 | | 190 | | 130 | | | 113 | | | 1.0 | IORQ ↓ to data out delay | THO (DOI) | | 340 | | 160 | | 110 | | 80 | ns | 2 | | 16 | (INTA cycle) | TdIO (DOI) | | 340 | | 160 | | 110 | | | 113 | | | 17 | IEI ↓ to IEO ↓ delay | TdIEI (IEOf) | | 190 | | 130 | | 100 | | 80 | ns | 3 | | 18 | IEI† to IEO† delay | TdIEI (IEOr) | | 220 | | 160 | | 110 | | 80 | ns | 3 | | 18 | (after ED decode) | Talel (IEOF) | | 220 | | 100 | | 110 | | - 00 | 11.3 | | | 19 | Clock † to INT ↓ delay | TdC (INT) | | TeC+200 | | TcC+140 | | TeC+120 | | TeC+100 | ns | 4 | | | CLK/TRG ↑ to INT ↓ delay | | | TeC+230 | | TcC+160 | | TeC+130 | | TeC+110 | ns | 5 | | 00 | tsCTR (C) satisfied | TdCLK (INT) | | 100 1 230 | | 100 | | 1(0 ) 130 | | 1001110 | | | | 20 | CLK/TRG ↑ to INT ↓ delay | Tuch (INT) | | 2TcC+530 | | 2TcC+370 | | 2TeC+280 | | 2TcC+190 | ns | 5 | | | tsCTR (C) not satisfied | | | 2 FCC 1 330 | | 2100 1 310 | | 2110 1 200 | | 2110 1 150 | 11,5 | | | 21 | CLK/TRG cycle time | TsCTR | 2TeC | | 2TcC | | 2TcC | | 2TcC | | ns | 5 | | 22 | CLK/TRG rise time | TrCTR | | 50 | | 50 | | 40 | | 35 | ns | | | 23 | CLK/TRG fall time | TfCTR | | 50 | | 50 | | 40 | | 35 | ns | | | 24 | CLK/TRG width (low) | TwCTRI | 200 | | 200 | | 120 | Ļ | 100 | | ns | | | 25 | CLK/TRG width (high) | TwCTRh | 200 | <u> </u> | 200 | | 120 | | 100 | ļ | ns | ļ | | 26 | CLK/TRG † to clock † setup | TsCTR (Cs) | 300 | | 210 | | 150 | | 110 | | ns | 5 | | 26 | time for immediate count | ISCIR (CS) | 300 | | 210 | | 130 | | 110 | | | | | | CLK/TRG † to clock † setup | | | | | | | | | | | | | 27 | time for enabling of prescaler | TsCTR (Ct) | 210 | | 210 | | 150 | | 110 | | ns | 4 | | | on following clock † | | | | | | | | | | | ļ | | 28 | Clock † to ZC/TO † delay | TdC (ZC/TOr) | | 260 | | 190 | <u></u> | 140 | | 110 | ns | <u> </u> | | 29 | Clock ↓ to ZC/TO ↓ delay | TdC (ZC/TOf) | | 190 | | 190 | | 140 | | 110 | ns | | <sup>↑</sup> Rising edge, ↓ falling edge Ta=0 to $+60^{\circ}C$ for 44-pin QFP $<sup>|</sup>A| \; \underline{2.5 \; TcC} > (n-2) \; TdIEI \; (IEOf) \; + \; TdMI \; (IEO) \; + \; TsIEI \; (IO) \; + \; TTL \; buffer \; delay, \; if \; any.$ <sup>[</sup>B] RESET must be active for a minimum of 3 clock cycles. Note 1: TcC=TwCh+TwCl+TrC+TfC. Note 2: Increase delay by 10 ns for each 50 pF increase in loading, 200 pF maximum for data lines, and 100 pF for control lines. Note 3: Increase delay by 2 ns for each 10 pF increase in loading, 100 pF maximum. Note 4: Timer mode. Note 5: Counter mode. # AC Timing Chart # Programming # (1) Operation mode select To select a channel operating mode, write a channel control word having bit 0 changed to 1 in the channel control register. | $D_7$ | $D_6$ | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ | $D_0$ | |--------------------------|-------|-----------------|----------------------------------|--------|--------------------------|-------|-------| | Inter-<br>rupt<br>enable | Mode | scaler<br>value | CLK/<br>TRO<br>edge<br>selection | mode : | Time<br>constant<br>mode | Reset | 1 | D3 and D5 are used in timer mode only. - Bit 7 = 0: Disables a channel interrupt. - Bit 7 = 1: Enables a channel interrupt each time the down-counter counts down to zero. No interrupt is produced even with bit 7 as 1, after the counter has counted down to zero with bit 7 as 0. - Bit 6 = 0: Selects the timer mode, having the prescaler output as the down-counter clock. The timer's period comes in t<sub>C</sub>. P. TC. Where t<sub>C</sub> represents system clock period, P has 16 or 256 (divisional scale by the prescaler), and TC means an 8-bit programmable time constant (max. 256). - Bit 6 = 1: Selects the counter mode, having the external clock (CLK input) signal as the downcounter clock. The prescaler is not used. - Bit 5 = 0: Used for the timer mode only. The prescaler divides the system clock into 16 sections. - Bit 5 = 1: Used for the timer mode only. The prescaler divides the system clock into 256 sections. - Bit 4 = 0: Starts the timer operation at the trigger input falling edge in the timer mode. In the counter mode, the down-counter comes on at the clock input rising edge. - Bit 4 = 1: Starts the timer operation at the trigger input rising edge in the timer mode. In the counter mode, the down-counter comes on at the clock input rising edge. - Bit 3 = 0: Effective in the timer mode only. With bit 1=1, the timer starts at the rising edge of the machine cycle T<sub>2</sub> which is next to the write cycle of a time constant. With bit 1=0, the timer starts at the rising edge of the machine cycle T<sub>1</sub> which is next to the write cycle of this control information. - Bit 3 = 1: Effective in the timer mode only. The timer starts by an external trigger input that is given after the rising of the machine cycle T<sub>2</sub> next to the write cycle of a time constant. The operation starts at the second clock rising if the trigger input meets the set-up time, and at the third clock rising if it does not. If an external trigger input is given before writing a time constant the condition of bit 3 = 0 is caused - Bit 2 = 0: Indicates that there is no time constant written after the channel control word. This bit cannot be 0 for the channel control word to be immediately given when the channel is reset. - Bit 2 = 1: Indicates that there is a time constant written after the channel control word. When a time constant is written during a downcounter operation, the new constant is set into the time constant register. But the counter keeps on counting. Once the counter counts zero, the new constant is available to use. - Bit 1 = 0: The channel acts as a down-counter. - ◆Bit 1 = 1: Stops the operation as a down-counter. With bit 2 = 1, the operation restarts after a time contant is written. With bit 2 = 0, the channel does not act until a new control word is given. # (2) Time constant programming An 8-bit time constant is written into the time constant register, following the channel control word with bit 2 = 1. "00" (hexadecimal) indicates the time constant 256. | $D_7$ | $D_e$ | $D_5$ | D4 | $D_3$ | $D_2$ | Ð١ | Do _ | |-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|------| | TC7 | TC <sub>6</sub> | TC <sub>5</sub> | TC <sub>4</sub> | TC <sub>3</sub> | TC <sub>2</sub> | TC <sub>1</sub> | TCo | # (3) Interrupt vector programming If the Z-80 CTC has one or more interrupts enabled, it can supply interrupt vectors to the Z-80 CPU. To do so, the Z-80 CTC must be pre-programmed with the most-significant five bits of the interrupt vector. Programming consists of writing a vector word to the I/O port corresponding to the Z-80 CTC Channel 0. Note that $D_0$ of the vector word is always zero, to distinguish the vector from a channel control word. $D_1$ and $D_2$ are not used in programming the vector word. These bits are supplied by the interrupt logic to identify the channel requesting interrupt service with a unique interrupt vector. Channel 0 has the highest priority. | D/ D0 | D5 | D4 | D3 | $D_2$ | Di . | D0 | |-------|----|----------------|----------------|-------|------|----| | V7 V6 | Vs | V <sub>4</sub> | V <sub>3</sub> | $V_2$ | Vı | Vo | | $D_2$ | D <sub>1</sub> | Channel | |-------|----------------|---------| | 0 | 0 | 0 | | 0 | 1 | 1 | | 1 | 0 | 2 | | 1 | 1 | 3 | # Timing # (1) Write cycle timing Fig. 1 shows write cycle timing for loading control, time constant or vector words. The CTC does not have a write signal input, so it generates one internally when the read (RD) input is High during T<sub>1</sub>. During T<sub>2</sub> IORQ and CE inputs are Low. M1 must be High to distinguish a write cycle from an interrupt acknowledge. A 2-bit binary code at inputs CS<sub>1</sub> and CS<sub>0</sub> selects the channel to be addressed, and the word being written is placed on the Z-80 data bus. The data word is latched into the appropriate register with the rising edge of clock cycle T<sub>3</sub>. # (2) Read cycle timing Fig. 2 shows read cycle timing. This cycle reads the contents of a down-counter without disturbing the count. During clock cycle T<sub>2</sub>, the Z-80 CPU initiates a read cycle by driving the following inputs Low: RD, IORQ, and CE. A 2-bit binary code at inputs CS<sub>1</sub> and CS<sub>0</sub> selects the channel to be read. MI must be High to distinguish this cycle from an interrupt acknowledge. No additional wait states are allowed. # (3) Interrupt acknowledge timing Fig. 3 shows interrupt acknowledge timing. After an interrupt request, the Z-80 CPU sends an interrupt acknowledge (M1 and $\overline{IORQ}$ ). All channels are inhibited from changing their interrupt request status when $\overline{M1}$ is active—about two clock cycles earlier than $\overline{IORQ}$ , $\overline{RD}$ is High to distinguish this cycle from an instruction fetch. The CTC interrupt logic determines the highest priority channel requesting an interrupt. If the CTC interrupt enable input. (IEI) is High, the highest proiority interrupting channel within the CTC places its interrupt vector on the data bus when IORQ goes Low. Two wait states (Twa) are automatically inserted at this time to allow the daisy chain to stabilize. Additional wait states may be added. # (4) Return from interrupt cycle If a Z-80 peripheral has no interrupt pending and is not under service, then its IEO = IEI. If it has an interrupt under service (i.e.,it has already interrupted and received an interrupt acknowledge) then its IEO is always Low, inhibiting lower priority devices from interrupting. If it has an interrupt pending which has not yet been acknowledged, IEO is Low unless an "ED" is decoded as the first byte of a 2-byte opcode. In this case, IEO goes High until the next opcode byte is decoded, whereupon it goes Low again. If the second byte of the opcode was a "4D," then the opcode was an RETI instruction. After an "ED" opcode is decoded, only the peripheral device which has interrupted and is currently under service has its IEI High and its IEO Low. This device is the highest-priority device in the daisy chain that has received an interrupt acknowledge. All other peripherals have IEI = IEO. If the next opcode byte decoded is "4D", this peripheral device resets its "interrupt under service" condition. ### (5) Daisy-chain interrupt service Fig. 5 shows a typical nested interrupt order with the CTC. Channel 2 first requests an interrupt to be serviced. If the higher-priority Channel 1 requests an interrupt while Channel 2 is in service, the Channel 2 service is interrupted and Channel 1 is serviced instead. Now the Channel 1 service routine has been completely executed, an RETI instruction can be given to indicate that Channel 1 has been serviced. At this moment, Channel 2 will be in service again. ### (6) Counter operation/timer operation In the counter mode, the CLK/TRG pulse input decrements the down-counter. The trigger is asynchronous, but the count is synchronized with CLK. For the decrement to occur on the next rising edge of CLK, the trigger edge must precede CLK by a minimum lead time. In the timer mode, a CLK/TRG pulse input starts the timer on the second succeeding rising edge of CLK. The trigger pulse is asynchronous, and it must have a minimum width. A minimum lead time (210 ns) is required between the active edge of the CLK/TRG and the next rising edge of CLK to enable the prescaler on the following clock edge.