Http://www.100y.com.tw ### **CA80C85B** ## HIGH PERFORMANCE 8-BIT CMOS MICROPROCESSOR - Enhanced, high performance CA80C85B microprocessor features pin and functional compatibility with industry standard 8085 and 8085A - Very low power consumption achieved with proven CMOS implementation - · TTL compatible input/output voltages - Fast Available in 8 MHz, 6 MHz, 5 MHz and 3 MHz speed versions - Full support of extended instruction set, and standard 8080 and 8085/8085A instruction sets - Runs over 10,000 CP/M<sup>®</sup> programs - On-chip clock generator (using external crystal, LC or RC network) - · Direct addressing to 64K bytes - Four Interrupt inputs (one non-maskable) - One of the multi-sourced, Calmos<sup>™</sup> 8000 series products The CA80C85B is an 8-bit microprocessor having complete pin and functional compatibility with industry standard 8085s and 8085As. In addition, it supports the special 8085 extended instruction set. The CA80C85B includes an on-board system controller, clock generator, serial I/O port and direct addressing capability to 64K bytes of memory. The device also utilizes a multiplexed data bus, with 16-bit addresses split between an 8-bit address bus and an 8-bit data bus. The CA80C85B is manufactured in CMOS and supplied in a PDIP package configuration suitable for commercial and industrial applications. The CA80C85B provides the systems designer with single component CPU functionality, thereby reducing the parts count. Its low power consumption and TTL I/O compatibility make the CA80C85B particularly well suited to portable or standby type applications. Figure 2-1: PDIP Pin Configurations Figure 2-2: PLCC Pin Configurations Figure 2-3: CA80C85B Block Diagram Table 2-1: Pin Descriptions | Symbol PDIP | Pin | Туре | Name and Function | | | | | |-----------------------------------|------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | A <sub>8</sub> - A <sub>15</sub> | 21 - 28 | 0 | High Address Bus: the most significant 8 bits of the memory address. | | | | | | AD <sub>0</sub> - AD <sub>7</sub> | 12 - 19 | I/O | Low Address and Data Bus: the least significant 8 bits of the memory address multiplexed with an 8-bit data bus. | | | | | | ALE | 30 | 0.0 | Address Latch Enable Out: This signal occurs during the first clock state of a machine cycle. The falling edge of the ALE may be used to strobe the status information. | | | | | | CLK | 37 | 0 | <b>Clock:</b> This signal can be used as a system clock. The period of CLK is twice the period of the $t_1$ , $t_2$ input. | | | | | | HLDA | 38 | 0 | <b>Hold Acknowledge</b> : Indicates that the CPU has received the HOLD request and that the bus will be relinquished in the next clock cycle. | | | | | | HOLD | 39 | I | <b>Iold Request</b> : Is used to indicate that another master is requesting the use of the address and ata buses. When HOLD is acknowledged (HLDA), the Address, Data, $\overline{RD}$ , $\overline{WR}$ and $\overline{IO}/\overline{M}$ line re set to the high impedance state. Note that the CPU can regain control of the bus only after IOLD is removed. | | | | | | ĪNTĀ | 11 | 0 | Interrupt Acknowledge: This active low signal indicates that the interrupt request input (INTR) has been recognized and acknowledged. | | | | | | INTR | 10 | 0 | Interrupt Request: This is a general purpose interrupt. When INTR goes HIGH, it will inhibit the Program Counter, generate an interrupt acknowledge (INTA) signal, and sample the data bus for a RESTART or CALL instruction. | | | | | | IO/M | 34 | 0 | Machine Cycle Status: See S <sub>0</sub> and S <sub>1</sub> status bits for further details. | | | | | | RD | 32 | О | Read Control: Active low signal is used to indicate that selected memory or I/O device is to be read with the data bus available for the data transfer. RD is set to a high impedance state during HOLD, HALT and RESET modes. | | | | | | READY | 35 | I | Ready: This signal is set to HIGH during read or write cycles to indicate that the selected memory or I/O device is ready to send or receive data. | | | | | | RESET IN | 36 | I | Reset In: Active low signal sets the Program Counter to zero, and resets the interrupt enable INTE) and HLDA flipflop. Note that so long as RESETIN is held low, the CPU is held in a recondition. | | | | | | RO | 3 | 0 | Reset Out: Indicates that the CPU is being reset. This signal can be used as a system RESET. | | | | | | RST7.5<br>RST6.5<br>RST5.5 | 7, 8, 9 | I | <b>Restart Interrupts:</b> These inputs provide three maskable interrupts which invoke an automatic internal restart. RST7.5 is the highest relative priority, followed by RST6.5 and RST5.5. All three interrupts have a higher priority than INTR. | | | | | | $S_0 - S_1$ $IO/\overline{M}$ | 29, 33, 34 | 0 | Status Outputs: These signals provide an indication of the machine status during any given cycle. All become valid at the beginning of a machine cycle, and remain stable for the duration of that cycle. The status may be latched by the falling edge of the ALE signal. | | | | | | SID | 5 | I | Serial Input Data: Data on SID is loaded into accumulator bit 7 when a RIM instruction is executed. | | | | | | SOD | 4 | 0 | Serial Output Data: This signal is set or reset by the SIM instruction. | | | | | | TRAP | 6 C | I | <b>Trap Interrupt</b> : Is a non-maskable restart interrupt. It is the highest priority interrupt, and is unaffected by an interrupt enable (INTE). | | | | | | $V_{DD}$ | 40 | $O_{Z_{I_{F}}}$ | Power: +5V supply | | | | | | V <sub>SS</sub> | 20 | | Ground: Ground reference. | | | | | | WR | 31 | 0 | Write Control: This active low signal is used to indicate that selected memory or I/O device is to be written to, with the data bus available for the data transfer. WR is set to a high impedance state during HOLD, HALT, and RESET modes. | | | | | | X <sub>1</sub> , X <sub>2</sub> | 1,2 | N CC | $\mathbf{X}_1$ , $\mathbf{X}_2$ : These two inputs are connected to clock source which is used to drive the internal clock generator. The clock source may be a crystal, LC or RC network. An external clock cal also be connected directly to $\mathbf{X}_1$ , to produce an internal processor clock frequency of one half of the input frequency. | | | | | #### **FUNCTIONAL DESIGN** The CA80C85B utilizes a stack architecture to enable any part of the external memory to be employed as a Last In/First Out (LIFO) memory stack. A 16-bit stack pointer controls the addressing of this stack. The arrangement allows extensive subroutine nesting and multiple level interrupts to be handled without losing the system status. In addition, the device accepts serial input data and provides serial output data, functions which are controlled by the interrupt mask instructions. The CA80C85B provides 16-bit arithmetic operation with immediate operators and decimal capability. An 8-bit accumulator, four user accessible flag bits, an 8-bit parallel binary arithmetic unit and six 8-bit data registers, all shown in the block diagram of Figure 2-3, are also provided. CA80C85B timing signals are supplied by an internal clock generator (which can be used with either crystal or RC timing circuits), or by an external clock input signal. Status outputs convey memory I/O instruction and Read/Write timing indications. For typical, single function type configurations, the CA80C85B is supplied in a 40-pin package, the low pin count a result of multiplexing the Address and Data Bus lines. Pin functions are described in Table 2-1, with the 40-pin DIP pin configuration illustrated in Figure 2-1. The lower processor pin count of this device can be reflected throughout a system design by similar pin count reductions in peripheral chips. Further, this optimization can be achieved without incurring complex or critical timing problems. The CA80C85B has five levels of interrupts, including three maskable restart interrupts, one non-maskable TRAP interrupt and a bus vectored interrupt, INTR. Bus control is provided by the $\overline{\tiny{RD}}$ , $\overline{\tiny{WR}}$ , $S_0$ , $S_1$ , $IO/\overline{\tiny{M}}$ and $\overline{\tiny{INTA}}$ interrupt acknowledge signals. When a HOLD control input signal is received, both Address and Data Bus are set to a high-impedance state, and an HLDA output signal acknowledges that microprocessor operation is stopped, and that the buses are available for use by other devices. Note that HOLD and all other interrupt signals are synchronized with the processor's internal clock. This is illustrated in the processor state transition diagram of Figure 2-4. In addition to the Data Bus, a simple serial interface is provided by the Serial Input Data (SID) and Serial Output Data (SOD) lines. At the software level, the CA80C85B supports the full extended instruction set, offering 10 additional instructions for the production of more efficient code. The five existing condition code flags have also been enhanced with two additional flag bits, one of which indicates a 2s complement overflow. Notes: - BI indicates that the bus is idle during this machine cycle, though the processor itself is active - CK indicates the number of clock cycles in this machine cycle. #### Table 2-2: 3 MHz AC Characteristics $T_A = -40^{\circ} \text{ to } +85^{\circ}\text{C}, V_{DD} = +5\text{v} + 10\%, t_{CYC} = 320 \text{ ns}, C_L = 150 \text{ pF}$ | Symbol | Parameter | Lin | nits | Units | |-------------------|-----------------------------------------------------------------------------|-------|--------------------|-------| | Зуппоп | Palallietei | Min | Max | Units | | t <sub>1</sub> | CLK Low Time | 80 | NC | ns | | t <sub>2</sub> | CLK High Time | 120 | -1 | ns | | t <sub>AC</sub> | A <sub>8</sub> - A <sub>15</sub> Valid to Leading Edge of Control (Note 1) | 270 | 005. | ns | | t <sub>ACL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid to Leading Edge of Control | 240 | -51 | ns | | t <sub>AD</sub> | A0 - A15 Valid to Valid Data In | -31 | 575 | ns | | t <sub>AFR</sub> | Address Float After Leading Edge of RD, INTA | 41 W- | 0 | ns | | t <sub>AL</sub> | A <sub>8</sub> - A <sub>15</sub> Valid Before Trailing Edge of ALE (Note 1) | 115 | 1.75 | ns | | t <sub>ALL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid Before Trailing Edge of ALE | 90 | -1 10 | ns | | t <sub>ARY</sub> | READY Valid from Address Valid | | 220 | ns | | t <sub>CA</sub> | Address (A <sub>8</sub> - A <sub>15</sub> ) Valid After Control | 120 | -ss <del>i</del> 1 | ns | | t <sub>cc</sub> | Width of Control Low (RD, WR, INTA) | 400 | MAIL | ns | | t <sub>CL</sub> | Trailing Edge of Control to Leading Edge of ALE | 50 | | ns | | t <sub>cyc</sub> | CLK Cycle Period | 320 | 2000 | ns | | t <sub>DW</sub> | Data Valid to Trailing Edge of WR | 420 | | ns | | t <sub>f</sub> | CLK Fall Time | - | 30 | ns | | t <sub>HABE</sub> | HLDA to Bus Enable | - | 210 | ns | | t <sub>HABF</sub> | Bus Float After HLDA | - | 210 | ns | | t <sub>HACK</sub> | HLDA Valid to Trailing Edge of CLK | 110 | 47 V | ns | | t <sub>HDH</sub> | HOLD Hold Time | 0 | | ns | | t <sub>HDS</sub> | HOLD Setup Time to Trailing Edge of CLK | 170 | -7/ | ns | | t <sub>INH</sub> | INTR Hold Time | 0 | - 41 | ns | | t <sub>INS</sub> | INTR RST and TRAP Setup Time to Falling Edge of CLK | 160 | - 1 | ns | | t <sub>LA</sub> | Address Hold Time After ALE | 100 | | ns | | t <sub>LC</sub> | Trailing Edge of ALE to Leading Edge of Control | 130 | - | ns | | t <sub>LCK</sub> | ALE Low During CLK High | 100 | - | ns | | $t_{LDR}$ | ALE to Valid Data During Read | - XXI | 460 | ns | | t <sub>LDW</sub> | ALE to Valid Data During Write | 7 | 200 | ns | | t <sub>LL</sub> | ALE Width | 140 | - | ns | | t <sub>LRY</sub> | ALE to Ready Stable | UNI: | 110 | ns | | t <sub>r</sub> | CLK Rise Time | 7.7 | 30 | ns | | t <sub>RAE</sub> | Trailing Edge of RD to re-Enabling of Address | 150 | | ns | | t <sub>RD</sub> | RD (or INTA) to Valid Data | Mo | 300 | ns | | t <sub>RDH</sub> | Data Hold Time After RD, INTA | 0 | T = 1 | ns | | t <sub>RV</sub> | Control Trailing Edge to Leading Edge of Next Control | 400 | 1.5 | ns | | t <sub>RYH</sub> | READY Hold Time | 0 | | ns | | t <sub>RYS</sub> | READY Setup Time to Leading Edge of CLK | 110 | · | ns | | t <sub>WD</sub> | Data Valid After Trailing Edge of WR | 100 | T-10 | ns | | t <sub>WDL</sub> | Leading Edge of WR to Data Valid | V-C | 40 | ns | | t <sub>XKF</sub> | X₁ Rising to CLK Falling | 20 | 150 | ns | | t <sub>XKR</sub> | X <sub>1</sub> Rising to CLK Rising | 20 | 120 | ns | Note: 1. A<sub>8</sub> - A<sub>15</sub> Address Specs apply to IO/m̄, S0 and S1. Except A<sub>8</sub> - A<sub>15</sub> are undefined during T<sub>4</sub> - T<sub>6</sub> of cycle whereas IO/m̄, S<sub>0</sub> and S<sub>1</sub> are stable. #### Table 2-3: 5 MHz AC Characteristics $T_A = -40^{\circ} \text{ to } +85^{\circ}\text{C}, V_{DD} = +5\text{v} + 10\%, t_{CYC} = 200 \text{ ns}, C_L = 150 \text{ pF}$ | Symbol | Parameter | Lir | nits | Units | |-------------------|-----------------------------------------------------------------------------|--------|--------|--------| | Symbol | rainietei | Min | Max | Ullits | | t <sub>1</sub> | CLK Low Time | 40 | M. | ns | | t <sub>2</sub> | CLK High Time | 70 | -7 C | ns | | t <sub>AC</sub> | A <sub>8</sub> - A <sub>15</sub> Valid to Leading Edge of Control (Note 1) | 115 | 00x. | ns | | t <sub>ACL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid to Leading Edge of Control | 115 | -51 | ns | | t <sub>AD</sub> | A <sub>0</sub> - A <sub>15</sub> Valid to Valid Data In | -73 | 330 | ns | | t <sub>AFR</sub> | Address Float After Leading Edge of RD, INTA | M | 0 | ns | | t <sub>AL</sub> | A <sub>8</sub> - A <sub>15</sub> Valid Before Trailing Edge of ALE (Note 1) | 50 | 1.75 | ns | | t <sub>ALL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid Before Trailing Edge of ALE | 50 | -110 | ns | | t <sub>ARY</sub> | READY Valid from Address Valid | | 100 | ns | | t <sub>CA</sub> | Address (A <sub>8</sub> - A <sub>15</sub> ) Valid After Control | 60 | - 1 | ns | | t <sub>CC</sub> | Width of Control Low (RD, WR, INTA) | 230 | N.A.Z. | ns | | t <sub>CL</sub> | Trailing Edge of Control to Leading Edge of ALE | 25 | - TEN | ns | | t <sub>CYC</sub> | CLK Cycle Period | 200 | 2000 | ns | | $t_{DW}$ | Data Valid to Trailing Edge of WR | 230 | | ns | | t <sub>f</sub> | CLK Fall Time | - | 30 | ns | | t <sub>HABE</sub> | HLDA to Bus Enable | - | 150 | ns | | t <sub>HABF</sub> | Bus Float After HLDA | - | 150 | ns | | t <sub>HACK</sub> | HLDA Valid to Trailing Edge of CLK | 40 | 12/1 | ns | | t <sub>HDH</sub> | HOLD Hold Time | 0 | | ns | | t <sub>HDS</sub> | HOLD Setup Time to Trailing Edge of CLK | 120 | -7// | ns | | t <sub>INH</sub> | INTR Hold Time | 0 | - 41 | ns | | t <sub>INS</sub> | INTR RST and TRAP Setup Time to Falling Edge of CLK | 150 | - 1 | ns | | t <sub>LA</sub> | Address Hold Time After ALE | 50 | | ns | | t <sub>LC</sub> | Trailing Edge of ALE to Leading Edge of Control | 60 | - | ns | | t <sub>LCK</sub> | ALE Low During CLK High | 50 | - | ns | | $t_{LDR}$ | ALE to Valid Data During Read | | 250 | ns | | t <sub>LDW</sub> | ALE to Valid Data During Write | (17.4. | 140 | ns | | t <sub>LL</sub> | ALE Width | 80 | - | ns | | t <sub>LRY</sub> | ALE to Ready Stable | Mrs | 30 | ns | | t <sub>r</sub> | CLK Rise Time | -17 | 30 | ns | | t <sub>RAE</sub> | Trailing Edge of RD to re-Enabling of Address | 85 | | ns | | t <sub>RD</sub> | RD (or INTA) to Valid Data | 140 | 150 | ns | | t <sub>RDH</sub> | Data Hold Time After RD, INTA | 0 | TTN. | ns | | t <sub>RV</sub> | Control Trailing Edge to Leading Edge of Next Control | 220 | | ns | | t <sub>RYH</sub> | READY Hold Time | 0 | · FV | ns | | t <sub>RYS</sub> | READY Setup Time to Leading Edge of CLK | 100 | Ar. | ns | | t <sub>WD</sub> | Data Valid After Trailing Edge of WR | 60 | T-12 | ns | | t <sub>WDL</sub> | Leading Edge of WR to Data Valid | V-C | 20 | ns | | t <sub>XKF</sub> | X₁ Rising to CLK Falling | 20 | 110 | ns | | t <sub>XKR</sub> | X <sub>1</sub> Rising to CLK Rising | 20 | 100 | ns | Note: 1. $A_8 - A_{15}$ Address Specs apply to $IO/\overline{\text{m}}$ , S0 and S1. Except $A_8 - A_{15}$ are undefined during $T_4 - T_6$ of cycle whereas $IO/\overline{\text{m}}$ , $S_0 - S_0 - S_0$ and S<sub>1</sub> are stable. WWW.100Y.COM.TW #### Table 2-4: 6 MHz AC Characteristics $T_A = -40^{\circ} \text{ to } +85^{\circ}\text{C}, V_{DD} = +5\text{v} + 5\%, t_{CYC} = 167 \text{ ns}, C_L = 150 \text{ pF}$ | Symbol | Parameter | Lir | nits | Units | |-------------------|-----------------------------------------------------------------------------|------|--------------------|-------| | Cymbol | N 100 S Talameter | Min | Max | Ville | | t <sub>1</sub> | CLK Low Time | 34 | 07:0 | ns | | t <sub>2</sub> | CLK High Time | 59 | - <del>-</del> √ ( | ns | | t <sub>AC</sub> | A <sub>8</sub> - A <sub>15</sub> Valid to Leading Edge of Control (Note 1) | 96 | 003. | ns | | t <sub>ACL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid to Leading Edge of Control | 96 | - TV | ns | | t <sub>AD</sub> | A <sub>0</sub> - A <sub>15</sub> Valid to Valid Data In | | 292 | ns | | t <sub>AFR</sub> | Address Float After Leading Edge of RD, INTA | 115 | 0 | ns | | t <sub>AL</sub> | A <sub>8</sub> - A <sub>15</sub> Valid Before Trailing Edge of ALE (Note 1) | 42 | 1.70 | ns | | t <sub>ALL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid Before Trailing Edge of ALE | 42 | -1401 | ns | | t <sub>ARY</sub> | READY Valid from Address Valid | - 1 | 83 | ns | | t <sub>CA</sub> | Address (A <sub>8</sub> - A <sub>15</sub> ) Valid After Control | 50 | - N | ns | | t <sub>cc</sub> | Width of Control Low (RD, WR, INTA) | 192 | M | ns | | t <sub>CL</sub> | Trailing Edge of Control to Leading Edge of ALE | 20 | | ns | | t <sub>cyc</sub> | CLK Cycle Period | 167 | 2000 | ns | | t <sub>DW</sub> | Data Valid to Trailing Edge of WR | 192 | | ns | | t <sub>f</sub> | CLK Fall Time | - | 25 | ns | | t <sub>HABE</sub> | HLDA to Bus Enable | - | 125 | ns | | t <sub>HABF</sub> | Bus Float After HLDA | - | 125 | ns | | t <sub>HACK</sub> | HLDA Valid to Trailing Edge of CLK | 33 | 17/1 | ns | | t <sub>HDH</sub> | HOLD Hold Time | 0 | -21 | ns | | t <sub>HDS</sub> | HOLD Setup Time to Trailing Edge of CLK | 100 | 7// | ns | | t <sub>INH</sub> | INTR Hold Time | 0 | - 1 | ns | | t <sub>INS</sub> | INTR RST and TRAP Setup Time to Falling Edge of CLK | 125 | - | ns | | t <sub>LA</sub> | Address Hold Time After ALE | 42 | _ | ns | | t <sub>LC</sub> | Trailing Edge of ALE to Leading Edge of Control | 50 | - | ns | | t <sub>LCK</sub> | ALE Low During CLK High | 42 | - | ns | | $t_{LDR}$ | ALE to Valid Data During Read | | 225 | ns | | t <sub>LDW</sub> | ALE to Valid Data During Write | 1.7. | 100 | ns | | t <sub>LL</sub> | ALE Width | 67 | N - | ns | | t <sub>LRY</sub> | ALE to Ready Stable | Nr. | 25 | ns | | t <sub>r</sub> | CLK Rise Time | 257 | 25 | ns | | t <sub>RAE</sub> | Trailing Edge of RD to Re-enabling of Address | 65 | - X X- | ns | | t <sub>RD</sub> | RD (or INTA) to Valid Data | No. | 125 | ns | | t <sub>RDH</sub> | Data Hold Time After RD, INTA | 0 | T. T. | ns | | t <sub>RV</sub> | Control Trailing Edge to Leading Edge of Next Control | 183 | 1 · · · | ns | | t <sub>RYH</sub> | READY Hold Time | 0 | VEL | ns | | t <sub>RYS</sub> | READY Setup Time to Leading Edge of CLK | 84 | | ns | | t <sub>WD</sub> | Data Valid After Trailing Edge of WR | 50 | 1.1 | ns | | t <sub>WDL</sub> | Leading Edge of WR to Data Valid | V-C | 16 | ns | | t <sub>XKF</sub> | X₁ Rising to CLK Falling | 20 | 110 | ns | | t <sub>XKR</sub> | X <sub>1</sub> Rising to CLK Rising | 20 | 100 | ns | Note: 1. A<sub>8</sub> - A<sub>15</sub> Address Specs apply to IO/M̄, S0 and S1. Except A<sub>8</sub> - A<sub>15</sub> are undefined during T<sub>4</sub> - T<sub>6</sub> of cycle whereas IO/M̄, S<sub>0</sub> and S<sub>1</sub> are stable. #### Table 2-5: 8 MHz AC Characteristics $T_A = -40^{\circ} \text{ to } +85^{\circ}\text{C}, V_{DD} = +5\text{v} + 5\%, t_{CYC} = 125 \text{ ns}, C_L = 150 \text{ pF}$ | Symbol | Parameter | Lir | nits | Units | |-------------------|-----------------------------------------------------------------------------|--------------------------|--------------------|-------| | Symbol | rainietei | Min | Max | Units | | t <sub>1</sub> | CLK Low Time | 25 | M. | ns | | t <sub>2</sub> | CLK High Time | 44 | <u>-</u> 7 ( | ns | | t <sub>AC</sub> | A <sub>8</sub> - A <sub>15</sub> Valid to Leading Edge of Control (Note 1) | 72 | 00x. | ns | | t <sub>ACL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid to Leading Edge of Control | 72 | -51 | ns | | $t_{AD}$ | A <sub>0</sub> - A <sub>15</sub> Valid to Valid Data In | -1-11 | 220 | ns | | t <sub>AFR</sub> | Address Float After Leading Edge of RD, INTA | 111- | 0 | ns | | t <sub>AL</sub> | A <sub>8</sub> - A <sub>15</sub> Valid Before Trailing Edge of ALE (Note 1) | 31 | 1.75 | ns | | t <sub>ALL</sub> | A <sub>0</sub> - A <sub>7</sub> Valid Before Trailing Edge of ALE | 31 | -110 | ns | | t <sub>ARY</sub> | READY Valid from Address Valid | -1511 | 63 | ns | | t <sub>CA</sub> | Address (A <sub>8</sub> - A <sub>15</sub> ) Valid After Control | 37 | - X <del>I</del> 1 | ns | | t <sub>CC</sub> | Width of Control Low (RD, WR, INTA) | 144 | A 4.5 | ns | | t <sub>CL</sub> | Trailing Edge of Control to Leading Edge of ALE | 15 | arti. | ns | | t <sub>CYC</sub> | CLK Cycle Period | 125 | 2000 | ns | | t <sub>DW</sub> | Data Valid to Trailing Edge of WR | 144 | or V | ns | | t | CLK Fall Time | - | 25 | ns | | t <sub>HABE</sub> | HLDA to Bus Enable | - | 94 | ns | | t <sub>HABF</sub> | Bus Float After HLDA | - | 94 | ns | | t <sub>HACK</sub> | HLDA Valid to Trailing Edge of CLK | 25 | 47 | ns | | t <sub>HDH</sub> | HOLD Hold Time | 0 | | ns | | t <sub>HDS</sub> | HOLD Setup Time to Trailing Edge of CLK | 78 | 7// | ns | | t <sub>INH</sub> | INTR Hold Time | 0 | - 41 | ns | | t <sub>INS</sub> | INTR RST and TRAP Setup Time to Falling Edge of CLK | 94 | - 1 | ns | | t <sub>LA</sub> | Address Hold Time After ALE | 32 | | ns | | t <sub>LC</sub> | Trailing Edge of ALE to Leading Edge of Control | 38 | - | ns | | t <sub>LCK</sub> | ALE Low During CLK High | 32 | - | ns | | $t_{LDR}$ | ALE to Valid Data During Read | - | 168 | ns | | t <sub>LDW</sub> | ALE to Valid Data During Write | C. F. A. | 75 | ns | | t <sub>LL</sub> | ALE Width | 50 | V - | ns | | t <sub>LRY</sub> | ALE to Ready Stable | Mrs | 25 | ns | | t <sub>r</sub> | CLK Rise Time | 7.7 | 25 | ns | | t <sub>RAE</sub> | Trailing Edge of RD to Re-enabling of Address | 45 | -337 | ns | | t <sub>RD</sub> | RD (or INTA) to Valid Data | $\Lambda_{\overline{c}}$ | 94 | ns | | t <sub>RDH</sub> | Data Hold Time After RD, INTA | 0 | T-V | ns | | t <sub>RV</sub> | Control Trailing Edge to Leading Edge of Next Control | 138 | - L | ns | | t <sub>RYH</sub> | READY Hold Time | 0 | | ns | | t <sub>RYS</sub> | READY Setup Time to Leading Edge of CLK | 63 | Mr. | ns | | t <sub>WD</sub> | Data Valid After Trailing Edge of WR | 34 | TIM | ns | | t <sub>WDL</sub> | Leading Edge of WR to Data Valid | V.C | 16 | ns | | t <sub>XKF</sub> | X <sub>1</sub> Rising to CLK Falling | 20 | 69 | ns | | t <sub>XKR</sub> | X₁ Rising to CLK Rising | 20 | 63 | ns | Note: 1. $A_8 - A_{15}$ Address Specs apply to $IO/\overline{\text{m}}$ , S0 and S1. Except $A_8 - A_{15}$ are undefined during $T_4 - T_6$ of cycle whereas $IO/\overline{\text{m}}$ , $S_0 - S_0 - S_0$ WWW.100Y.COM.TW Figure 2-5: Timing Diagrams #### a) Clock Timing M. 100 X. COM-1 A ## .100Y.CQM.TW b) Read Operation Figure 4: Timing Diagrams con't #### c) Write Operation #### **OPERATION** WRITE # WW.100Y.COM.TW d) Hold Operation W.100Y.COM.T Figure 4: Timing Diagrams con't ## e) Interrupt Timing COM.TV M. 100 X. COM . 1 A WWW.100Y.COM. #### Table 2-6: DC Characteristics (Commercial and Industrial Temperature Range Devices) $T_A = -40^{\circ}$ to +85°C, $V_{DD} = +5v + 10\%$ , $t_{CYC} = 320$ ns (except as noted) W.100X.COM.LW | Symbol | Parameter | Test Condition | of Cu | mits | Units | |------------------|-------------------------|--------------------------------------------------------|--------|----------------------|-------| | Cybc. | 100 50 | 31 1951 SQUARES | Min | Max | | | TVI | Power Supply Current | $t_{CYC} = 320 \text{ ns}, T_A = -40 ^{\circ}\text{C}$ | OUT. | 24 | mA | | $I_{DD1}$ | Fower Suppry Current | $t_{CYC} = 320 \text{ ns}, T_A = +25 ^{\circ}\text{C}$ | - <7 ( | 17 | mA | | | Developed Comment | $t_{CYC} = 200 \text{ ns}, T_A = -40 ^{\circ}\text{C}$ | 100 1. | 29 | mA | | $I_{DD2}$ | Power Supply Current | $t_{CYC} = 200 \text{ ns}, T_A = +25 \text{ °C}$ | · | 21 | mA | | I <sub>IL</sub> | Input Leakage Current | $V_{IN} = V_{DD}$ and $V_{IN} = 0$ | -10 | 10 | μΑ | | $I_{OL}$ | Output Leakage Current | $0v \le V_{OUT} \le V_{DD}$ | -10 | 10 | μΑ | | $V_{HY}$ | Hysteresis, RESET | ON | 0.25 | -1 CO | V | | V <sub>IH</sub> | Input High Voltage | TIN N | 2.2 | V <sub>DD</sub> +0.3 | V | | V <sub>IHR</sub> | Input High Level, RESET | COM | 2.4 | V <sub>DD</sub> +0.3 | V | | $V_{IL}$ | Input Low Voltage | . OM:I | -0.3 | +0.8 | V | | V <sub>ILR</sub> | Input Low Level, RESET | V.CO. | -0.3 | +0.8 | V | | V <sub>OL</sub> | Output Low Voltage | $I_{OL} = 2 \text{ mA}$ | | 0.45 | (V) | | 7.00 | Output High Voltage | $I_{OH} = -400 \mu A$ | 2.4 | 11007 | V | | $V_{OH}$ | Output High Voltage | $I_{OH} = -40 \mu A$ | 4.2 | 1.20 | 7 V | | Y.COM. | IW WW.1 | OOX.COMILY | WIX | W.100 | v.C | | | | | | | | | | | | | | | Table 2-7: Absolute Maximum Ratings | Storage Temperature | −65°C to +160°C | |-------------------------------------------|------------------------| | Voltage On Any Pin with respect to Ground | -0.3 to VDD +0.3 Volts | | Output Currents | 100mA | | Power Dissipation | 1 Watt | | Lead Temperature (Soldering: 10 seconds) | 300°C | Note: Stresses beyond those listed above may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### **Clock Inputs** Clock inputs to the CA80C85B are supplied via the two inputs $X_1$ and $X_2$ . The $X_1$ input can be driven either from an external clock, or used with the $X_2$ input and a crystal to produce an oscillator function. The minimum input frequency required in both cases is 1 MHz. The actual internal microprocessor clock frequency is one half of the frequency applied or generated externally. For example, a 6 MHz crystal or external clock waveform is required for 3 MHz operation, and a 12 MHz clock source is required for 6 MHz operation. The $\rm X_1/\rm X_2$ circuitry is intended to be used with a crystal cut for parallel resonance at the required clock frequency. Such crystals require closely controlled load capacitance in order to resonate at the specified frequency. The CA80C85B has an equivalent parallel capacitance of between 10 and 20 pF. Since most crystals will require higher values of capacitance to resonate at precisely their specified frequency, additional capacitance must be added as shown in Figure 2-6(a). When the $X_1$ input is driven from an external clock, $X_2$ is left open. In this case, $X_1$ should be driven with a CMOS driver or a TTL device with a pull-up resistor, as shown in Figure 2-6(b). The clock low time must be greater than 80 ns for the 3 MHz device and 30 ns for the 6 MHz. Figure 2-6: External Clock Circuits #### Serial I/O The Set Interrupt Mask (SIM) and Read Interrupt Mask (RIM) instructions provide several functions related to serial port I/O and interrupt mask operations. The SIM instruction is used to output serial data, and to program the interrupt mask register. The output signal, SOD, is set or reset as specified by the SIM instruction, with the accumulator contents constructed as shown in Figure 2-7. Figure 2-7: SIM Instruction Data Byte The RIM instruction is used to read the serial input data (SID), as well as the interrupt mask. The accumulator contents after a RIM instruction has been executed are as shown in Figure 2-8. Figure 2-8: RIM Instruction Data Byte #### Interrupts The five interrupt levels provided by the CA80C85B are listed by descending order of priority in Table 2-8. TRAP and RSTx.5 are RESTART interrupts. When acknowledged, these four interrupts cause the processor to save the program counter (PC) on the stack, then branch to the restart address specified in the table. The TRAP interrupt is non-maskable. It is set with a rising edge (low to high) followed by a stable high level until sampled by the processor. To reactivate the TRAP interrupt, the input signal must first go low, then high. To preserve the status of the Interrupt Enable (IE) flag after a TRAP interrupt has occurred, the interrupt mask must be read and saved immediately after the interrupt has been acknowledged (refer to RIM instruction). The RST7.5 is a maskable interrupt, set on a rising edge only, and then latched. The RST6.5 and RST5.5 are maskable interrupts, set with a high level applied to their respective inputs. The status of the three RST interrupt masks can only be affected by the SIM instruction and RESETIN. The INTR interrupt is also set by a high level applied to the input pin. It is similar in operation to the 8080 INT interrupt in that the action of the processor is dependent on the instruction placed on the bus during the INTA. Note that the servicing of any of the five interrupts disables all future interrupts (except TRAPS) until an EI instruction is executed. Of course, an interrupt of higher priority may interrupt a previous interrupt in process if the interrupts have been re-enabled within the interrupt service routine. Table 2-8: Interrupt Restart Address | Interrupt | Restart Address (HEX) | |-----------|-------------------------------------------------------------------| | TRAP | 24H | | RST7.5 | 3CH | | RST6.5 | 34H | | RST5.5 | 2CH | | INTR | Dependent upon the instruction received on the bus during an INTA | #### **Status Outputs** The status of the CA80C85B can be determined from the combination of $S_0,\,S_1$ and $IO/\overline{\scriptscriptstyle M}$ output signals. These signals are latched on the falling edge of an ALE signal, and are valid while ALE is low. Table 2-9 lists the seven possible types of machine cycles as defined by $S_0,\,S_1$ and $IO/\overline{\scriptscriptstyle M}$ . Note in the Figure 2-5 timing diagrams that the $\overline{\scriptscriptstyle RD}$ and $\overline{\scriptscriptstyle WR}$ control lines become active after the status signals, when the transfer of data is to take place. Table 2-9: Machine Cycle Status Conditions | S <sub>0</sub> | S <sub>1</sub> | IO/M | Status | |----------------|----------------|------|-----------------------| | 1 | 0 | 0 | Memory Write | | 0 | 1 | 0 | Memory Read | | 1 | 0 | 1 | I/O Write | | 0 | 1 | 1 | I/O Read | | 1 | 1 | 0 | Opcode Fetch | | 1 | 1 | 1 | Interrupt Acknowledge | | Z | 0 | 0 | Halt | | Z | X | X | Hold | | Z | X | X | Reset | Z - High impedance state #### **Extended Instructions and Condition Codes** The CA80C85B Flag Register features two additional condition code flags, for a total of seven. These are illustrated in Figure 2-9. The ten opcodes which comprise the extended instruction set of the CA80C85B microprocessor are described in Table 2-10. | S | Z | UI | AC | 0 | Р | ٧ | С | FLAG | |---|---|----|----|---|---|---|---|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | BIT | V - 2's complement overflow for both 8 and 16-bit arithmetic operations UI - Underflow indicator (DCX instruction) or Overflow indicator (INX instruction) $UI = 01 \times 02 + 01 \times R + 02 \times R$ where: 01 = sign of operand 1 02 = sign of operand 2 R = sign of result For subtraction and comparisons, replace 02 with $\overline{02}$ Figure 2-9: Extended Condition Codes X - Don't care condition Table 2-10: CA80C85B Extended Instruction Set | Name | Opcodes | Flags | Cycles | States | Description | |------|---------------------------------------------------------------------------------|--------------|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ARHL | 00010000<br>Addressing:<br>Register | СУ | 2 | 7 | Arithmetic Shift of H and L to the Right: The contents of registers H and L are shifted right one bit is shifted into the carry bit. The result is saved in registers H and L. H7=H7; Hn-1=Hn; L7=H0; Ln-1=Ln; CY=L0 | | DSUB | 00001000<br>Addressing:<br>Register | Z, S, P, CY, | 3 | 10 | Double Subtraction: The contents of registers B and Care subtracted from the contents of registers H and L. The result is saved in registers H and L. (H) (L)=(H) (L) - (B) (C) | | JNUI | 11011101<br>low-order address<br>high-order address<br>Addressing:<br>Immediate | none | 2 or 3 | 7 or 10 | Jump on NOT UI Flag: Control is transferred to the instruction address specified in bytes 2 and 3 of the current instruction. The result is saved in registers H and L. (H) (L)=(H) (L) - (B) (C) | | | 11111101<br>low-order address<br>high-order address<br>Addressing:<br>Immediate | none | 2 or 3 | 7 or 10 | Jump on UI Flag: Control is transferred to the instruction address specified in bytes 2 and 3 of the current instruction. if the Unsigned Indicator Flag (UI) is set. Otherwise control continues sequentially. (H) (L)=(H) (L) - (B) (C) | | LDHI | 00101000 data Addressing: Immediate Register | none | 3 | 10 | Load D and E with L Plus Immediate Byte: The immediate byte is added to the contents of registers H and L, and the result is saved in registers D and E. (D) (E) = (H) (L) + (byte 2) | | LDSI | 00111000 data Addressing: Immediate Register | none | 3 | 10 | Load D and E with SP Plus Immediate Byte: The 2 bytes of register SP are added to the immediate byte, and the result is saved in registers D and E. (D) (E) = (SPH) (SPL) + (byte 2) | | LHLX | 11101101 data Addressing: Register Indirect | none | 3 | 1010 | Load H and L Indirect Through D and E: The contents of the memory location given by registers D and E are moved to register L. The contents of the next location are moved to register H L=((D) (E)); H=((D)(E) + 1) | | RDEL | 00011000 Addressing: Register | CY, V | 3 | 10 | Rotate D and E Left Through Carry: The contents of the registers D and E are rotated one bit left through the carry flag. The low-order bit is set equal to the CY flag and the CY flag is set to the value shifted out of the high-order bit Dn+1=Dn; D0; E7; CY=D7; En+1=En; E0=CY | | RSTV | 11001011 Addressing: Register Indirect | none | 1 or 3 | 6 or 12 | Restart on Overflow: If overflow flag V is set, then the actions below are performed. Otherwise, control continues sequentially. If (V): SP - 1=PCH; SP - 2=PCL; SP=SP - 2; PC=40HEX | | SHLX | 11011001<br>Addressing: | none | 3 | 10 | Store H and L Indirect Through D and E: The contents of register L are moved to the memory location given by registers D and E. The contents of register H are | 勝 特 力 材 料 886-3-5753170 胜特力电子(上海) 86-21-34970699 胜特力电子(深圳) 86-755-83298787 Http://www.100y.com.tw