## COP8620C/COP8622C/COP8640C/COP8642C/ COP86L20C/COP86L22C/COP86L40C/COP86L42C Single-Chip microCMOS Microcontrollers ## **General Description** The COP8620C/COP8640C are members of the COPSTM microcontroller family. They are fully static parts, fabricated using double-metal silicon gate microCMOS technology. These low cost microcontrollers are complete microcomputers containing all system timing, interrupt logic, ROM, RAM, EEPROM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8-bit memory mapped architecture, MICROWIRE/PLUSTM serial I/O, a 16-bit timer/counter with capture register and a multi-sourced interrupt. Each I/O pin has software selectable options to adapt the device to the specific application. The part operates over a voltage range of 4.5V to 6.0V. High throughput is achieved with an efficient, regular instruction set operating at a 1 microsecond per instruction rate. #### **Features** - Low Cost 8-bit microcontroller - Fully static CMOS - $\blacksquare$ 1 $\mu$ s instruction time - $\blacksquare$ Low current drain (2.2 mA at 3 $\mu s$ instruction rate) Low current static HALT mode (Typically < 1 $\mu A$ ) - Single supply operation: 4.5 to 6.0V - 2048 Bytes ROM/64 Bytes RAM/64 Bytes EEPROM on COP8640C - 1024 bytes ROM/64 bytes RAM/64 bytes EEPROM on COP8620C - 16-bit read/write timer operates in a variety of modes - Timer with 16-bit auto reload register - 16-bit external event counter - Timer with 16-bit capture register (selectable edge) - Multi-source interrupt - Reset master clear - External interrupt with selectable edge - Timer interrupt or capture interrupt - Software interrupt - 8-bit stack pointer (stack in RAM) - Powerful instruction set, most instructions single byte - BCD arithmetic instructions - MICROWIRE PLUS™ serial I/O - 28 pin package (optional 20 pin package) - 24 input/output pins (28-pin package) - Software selectable I/O options (TRI-STATE®, pushpull, weak pull-up) - Schmitt trigger inputs on Port G - Temperature range: -40°C to +85°C, -55°C to +125°C - Hybrid emulator devices - Fully supported by MetaLink's Development Systems ## **Block Diagram** ### COP86L20C/COP86L22C/COP86L40C/COP86L42C ## **Absolute Maximum Ratings** If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. Supply Voltage (V<sub>CC</sub>) Voltage at any Pin -0.3V to $V_{CC} + 0.3V$ 50 mA Total Current into V<sub>CC</sub> Pin (Source) Total Current out of GND Pin (Sink) Storage Temperature Range -65°C to +140°C Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electri- cal specifications are not ensured when operating the device at absolute maximum ratings. ## DC Electrical Characteristics $-40^{\circ}C \le T_A \le +85^{\circ}C$ unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |---------------------------------------|------------------------------------------------------------------|--------------------------------------------------|----------|----------------------|----------| | Operating Voltage | | 2.5 | | 6.0 | V | | Power Supply Ripple (Note 1) | Peak to Peak | | | 0.1 V <sub>CC</sub> | V | | Operating Voltage during EEPROM Write | | 4.5 | | 6.0 | V | | Supply Current (Note 2) | | | | | | | CKI = 10 MHz Supply Current during | $V_{CC} = 6V$ , tc = 1 $\mu$ s | | { | 9 | mA | | Write Operation (Note 2) | 13.5 | | | | | | CKI = 10 MHz | $V_{CC} = 6.0V, tc = 1 \mu s$ | | { | 15 | mA | | HALT Current (Note 3) | $V_{CC} = 6V, CKI = 0 MHz$ | | <1 | 10 | μΑ | | Input Levels | | | | | | | RESET, CKI | | 0.01/ | | | ., | | Logic High<br>Logic Low | | 0.9 V <sub>CC</sub> | \ | 0.1 V <sub>CC</sub> | V | | All Other Inputs | | | | 0.1 400 | | | Logic High | | 0.7 V <sub>CC</sub> | ì | | l v | | Logic Low | | | | 0.2 V <sub>CC</sub> | V | | Hi-Z Input Leakage | $V_{CC} = 6.0V$ | -2 | ) | +2 | μΑ | | Input Pullup Current | $V_{CC} = 6.0V, V_{IN} = 0V$ | -40 | | -250 | μΑ | | G Port Input Hysteresis (Note 5) | | | | 0.35 V <sub>CC</sub> | V | | Output Current Levels | | ļ | ļ | | | | D Outputs<br>Source | $V_{CC} = 4.5V, V_{OH} = 3.8V$ | -0.4 | ĺ | | mA | | Source | $V_{CC} = 4.5V, V_{OH} = 3.8V$<br>$V_{CC} = 2.5V, V_{OH} = 1.8V$ | -0.4 | ļ | | l mA | | Sink | V <sub>CC</sub> = 4.5V, V <sub>OL</sub> = 1.0V | 10 | ĺ | • | mA | | | V <sub>CC</sub> = 2.5V, V <sub>CL</sub> = 0.4V | 2 | | | mA | | All Others | 151111 0.01 | | | 440 | | | Source (Weak Pull-Up) | $V_{CC} = 4.5V, V_{OH} = 3.2V$ | -10<br>-2.5 | } | -110<br>-33 | μA | | Source (Push-Pull Mode) | $V_{CC} = 2.5V, V_{OH} = 1.8V$<br>$V_{CC} = 4.5V, V_{OH} = 3.8V$ | -0.4 | | -33 | μA<br>mA | | Course (Fasial an inicae) | V <sub>CC</sub> = 2.5V, V <sub>OH</sub> = 1.8V | -0.2 | 1 | 1 | mA | | Sink (Push-Pull Mode) | $V_{CC} = 4.5V, V_{OL} = 0.4V$ | 1.6 | | | mA | | _ | $V_{CC} = 2.5V, V_{OL} = 0.4V$ | 0.7 | | | mA | | TRI-STATE Leakage | | -2.0 | | + 2.0 | μΑ | | Allowable Sink/Source | | 1 | <b>\</b> | | | | Current Per Pin D Outputs (Sink) | | ł | | 15 | mA | | All Others | | ) | Ì | 3 | mA | | Maximum Input Current (Note 4) | | <del> </del> | | | | | Without Latchup (Room Temp) (Note 5) | Room Temp | } | ļ . | ± 100 | mA | | RAM Retention Voltage, Vr | 500 ns Rise and Fall Time (Min) | 2.0 | | | V | | Input Capacitance (Note 5) | | | | 7 | pF | | EEPROM Characteristics | | | | | | | EEPROM Write Cycle Time | | 1 | | 10 | ms | | EEPROM Number of Write Cycles | 1 | 1 | ' | 10,000 | Cycle | | EEPROM Data Retention | <u></u> | 10 | | | Years | Note 1: Rate of voltage change must be less than 0.5V/ms. Note 2: Supply current is measured after running 2000 cycles with a square wave CKI input, CKO open, inputs at rails and outputs open. Note 3: The HALT mode will stop CKI from oscillating in the RC and the Crystal configurations. Test conditions: All inputs tied to V<sub>CC</sub>, L and G ports are at TRI-STATE and tied to ground, all outputs low and tied to ground. Note 4: Pins G6 and RESET are designed with a high voltage input network for factory testing. These pins allow input voltages greater than V<sub>CC</sub> and the pins will have sink current to V<sub>CC</sub> when biased at voltages greater than V<sub>CC</sub> (the pins do not have source current when biased at a voltage below V<sub>CC</sub>). The effective resistance to V<sub>CC</sub> is 750Ω (typical). These two pins will not latch up. The voltage at G6 and RESET pins must be limited to less than 14V. ## COP86L20C/COP86L22C/COP86L40C/COP86L42C (Continued) AC Electrical Characteristics $-40^{\circ}\text{C} \le T_{A} \le +85^{\circ}\text{C}$ unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|----------------------|-----|----------------|----------------------| | Instruction Cycle Time (tc) Ext, Crystal/Resonator (Div-by 10) R/C Oscillator Mode (Div-by 10) | $V_{CC} \ge 4.5V$ $2.5V \le V_{CC} \le 6.0V$ $V_{CC} \ge 4.5V$ $2.5V \le V_{CC} \le 6.0V$ | 1<br>2.5<br>3<br>7.5 | | DC<br>DC<br>DC | μs<br>μs<br>μs<br>μs | | CKI Clock Duty Cycle (Note 5)<br>Rise Time (Note 5)<br>Fall Time (Note 5) | fr = 10 MHz Ext Clock<br>fr = 10 MHz Ext Clock | 40 | | 60<br>12<br>8 | %<br>ns<br>ns | | Inputs tsetup tHOLD | | 200<br>60 | × " | | ns<br>ns | | Output Propagation Delay tpD1, tpD0 SO, SK All Others | $C_L = 100 pF, R_L = 2.2 k\Omega$ | | | 0.7<br>1 | μs<br>μs | | MICROWIRE™ Setup Time (t <sub>UWS)</sub> MICROWIRE Hold Time (t <sub>UWH)</sub> MICROWIRE Output Propagation Delay Time (t <sub>UPD</sub> ) | ×° | 20<br>56 | | 220 | ns<br>ns<br>ns | | Input Pulse Width Interrupt Input High Time Interrupt Input Low Time Timer Input High Time Timer Input Low Time | | to to to | | | v.' | | Reset Pulse Width | | 1.0 | | | μs· | Note 5: Parameter sampled (not 100% tested). ## **Timing Diagram** ### COP8620C/COP8622C/COP8640C/COP8642C ## **Absolute Maximum Ratings** If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. Supply Voltage (V<sub>CC</sub>) 7V Voltage at any Pin -0.3V to V<sub>CC</sub> +0.3V Total Current into V<sub>CC</sub> Pin (Source) 50 mA Total Current out of GND Pin (Sink) Storage Temperature Range 60 mA -65°C to +140°C Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings. ## DC Electrical Characteristics $-40^{\circ}C \le T_A \le +85^{\circ}C$ unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|----------|----------------------------|----------------------------------| | Operating Voltage<br>Power Supply Ripple (Note 1) | Peak to Peak | 4.5 | | 6.0<br>0.1 V <sub>CC</sub> | V V | | Supply Current (Note 2) CKI = 10 MHz Supply Current during Write Operation (Note 2) | V <sub>CC</sub> = 6V, tc = 1 μs | | | 9 | mA | | CKI = 10 MHz<br>HALT Current (Note 3) | $V_{CC} = 6.0V$ , tc = 1 $\mu$ s<br>$V_{CC} = 6V$ , CKI = 0 MHz | | <1 | 15<br>10 | mA<br>μA | | Input Levels RESET, CKI Logic High Logic Low All Other Inputs | | 0.9 V <sub>CC</sub> | | 0.1 V <sub>CC</sub> | V<br>V | | Logic High<br>Logic Low | | 0.7 V <sub>CC</sub> | <u> </u> | 0.2 V <sub>CC</sub> | , V | | Hi-Z Input Leakage<br>Input Pullup Current | $V_{CC} = 6.0V$<br>$V_{CC} = 6.0V$ , $V_{IN} = 0V$ | -2<br>-40 | | +2<br>-250 | μA<br>μA | | G Port Input Hysteresis (Note 5) | 0 | | | 0.35 V <sub>CC</sub> | V | | Output Current Levels D Outputs Source Sink All Others Source (Weak Pull-Up) Source (Push-Pull Mode) Sink (Push-Pull Mode) TRI-STATE Leakage | V <sub>CC</sub> = 4.5V, V <sub>OH</sub> = 3.8V<br>V <sub>CC</sub> = 4.5V, V <sub>OL</sub> = 1.0V<br>V <sub>CC</sub> = 4.5V, V <sub>OH</sub> = 3.2V<br>V <sub>CC</sub> = 4.5V, V <sub>OH</sub> = 3.8V<br>V <sub>CC</sub> = 4.5V, V <sub>OL</sub> = 0.4V | -0.4<br>10<br>-10<br>-0.4<br>1.6<br>-2.0 | | -110<br>+2.0 | mA<br>mA<br>µA<br>mA<br>mA<br>µA | | Allowable Sink/Source<br>Current Per Pin<br>D Outputs (Sink)<br>All Others | | | | 15<br>3 | mA<br>mA | | Maximum Input Current (Note 4) Without Latchup (Room Temp) (Note 5) | Room Temp | | | ±100 | mA | | RAM Retention Voltage, Vr | 500 ns Rise and Fall Time (Min) | 2.0 | | | V | | Input Capacitance (Note 5) | | | | 7 | pF | | EEPROM Characteristics EEPROM Write Cycle Time EEPROM Number of Write Cycles EEPROM Data Retention | | 10 | | 10<br>10,000 | ms<br>Cycle<br>Years | Note 1: Rate of voltage change must be less than 0.5V/ms. Note 2: Supply current is measured after running 2000 cycles with a square wave CKI input, CKO open, inputs at rails and outputs open. Note 3: The HALT mode will stop CKI from oscillating in the RC and the Crystal configurations. Test conditions: All inputs tied to V<sub>CC</sub>, L and G ports are at TRI-STATE and tied to ground, all outputs low and tied to ground. Note 4: Pins G6 and $\overline{\text{RESET}}$ are designed with a high voltage input network for factory testing. These pins allow input voltages greater than $V_{CC}$ and the pins will have sink current to $V_{CC}$ when biased at voltages greater than $V_{CC}$ (the pins do not have source current when biased at a voltage below $V_{CC}$ ). The effective resistance to $V_{CC}$ is 750 $\Omega$ (typical). These two pins will not latch up. The voltage at G6 and $\overline{\text{RESET}}$ pins must be limited to less than 14V. ## COP8620C/COP8622C/COP8640C/COP8642C (Continued) ## AC Electrical Characteristics $-40^{\circ}\text{C} \le T_{A} \le +85^{\circ}\text{C}$ unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |----------------------------------------------------------------------|----------------------------------------------------|----------------|-------|---------|----------| | Instruction Cycle Time (tc)<br>Ext, Crystal/Resonator<br>(Div-by 10) | | 1 | - 111 | DC | μs | | R/C Oscillator Mode (Div-by 10) | (1) | 3 | | DC | μs | | CKI Clock Duty Cycle (Note 5) | 6- 40 MH - Fut Olanti | 40 | | 60 | % | | Rise Time (Note 5) Fall Time (Note 5) | fr = 10 MHz Ext Clock<br>fr = 10 MHz Ext Clock | | | 12<br>8 | ns<br>ns | | Inputs | | | | | | | SETUP<br>HOLD | | 200<br>60 | | | ns<br>ns | | Output Propagation Delay | $C_L = 100 \text{ pF, } R_L = 2.2 \text{ k}\Omega$ | | | | | | tpp1, tpD0<br>SO, SK | | | | 0.7 | μS | | All Others | | | | 1 | μs | | MICROWIRE™ Setup Time (t <sub>UWS)</sub> | | 20 | | | ns | | MICROWIRE Hold Time (t <sub>UWH)</sub> MICROWIRE Output | | 56 | | | ns | | Propagation Delay Time (t <sub>UPD</sub> ) | | | | 220 | ns | | Input Pulse Width | | | | | | | Interrupt Input High Time<br>Interrupt Input Low Time | | t <sub>C</sub> | | | | | Timer Input High Time | | to<br>to | | | | | Timer Input Low Time | | tc | | | | | Reset Pulse Width | | 1.0 | | | μs | Note 5: Parameter sampled (not 100% tested). ## COP6620C/COP6622C/COP6640C/COP6642C ## **Absolute Maximum Ratings** If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. Supply Voltage (V<sub>CC</sub>) 6V Voltage at any Pin Total Current into V<sub>CC</sub> Pin (Source) -0.3V to $V_{CC} + 0.3V$ Total Current out of GND Pin (Sink) Storage Temperature Range 48 mA -65°C to +140°C Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the de- vice at absolute maximum ratings. ## DC Electrical Characteristics $-55^{\circ}$ C $\leq T_{A} \leq +125^{\circ}$ C unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------|-----|----------------------------|----------------------| | Operating Voltage Power Supply Ripple (Note 1) | Peak to Peak | 4.5 | | 5.5<br>0.1 V <sub>CC</sub> | V<br>V | | Supply Current (Note 2) CKI = 10 MHz Supply Current during Write Operation (Note 2) | V <sub>CC</sub> = 5.5V, tc = 1 μs | | | 15 | mA | | CKI = 10 MHz HALT Current (Note 3) | $V_{CC} = 5.5V$ , tc = 1 $\mu$ s<br>$V_{CC} = 5.5V$ , CKI = 0 MHz | | <10 | 21<br>40 | mA<br>μA | | Input Levels RESET, CKI Logic High Logic Low All Other Inputs | | 0.9 V <sub>CC</sub> | | 0.1 V <sub>CC</sub> | <b>V V</b> | | Logic High<br>Logic Low | | 0.7 V <sub>CC</sub> | | 0.2 V <sub>CC</sub> | v | | Hi-Z Input Leakage<br>Input Pullup Current | $V_{CC} = 5.5V$ $V_{CC} = 4.5V$ | -5<br>-35 | | +5<br>-300 | μA<br>μA | | G Port Input Hysteresis (Note 5) | | | | 0.35 V <sub>CC</sub> | <b>&gt;</b> | | Output Current Levels D Outputs Source Sink All Others | $V_{CC} = 4.5V, V_{OH} = 3.8V$ $V_{CC} = 4.5V, V_{OL} = 1.0V$ | -0.35<br>9 | | | mA<br>mA | | Source (Weak Pull-Up) Source (Push-Pull Mode) Sink (Push-Pull Mode) TRI-STATE Leakage | $V_{CC} = 4.5V, V_{OH} = 3.2V$ $V_{CC} = 4.5V, V_{OH} = 3.8V$ $V_{CC} = 4.5V, V_{OL} = 0.4V$ | -9<br>-0.35<br>1.4<br>-5.0 | | - 120<br>+ 5.0 | μΑ<br>mA<br>mA<br>μΑ | | Allowable Sink/Source<br>Current Per Pin<br>D Outputs (Sink)<br>All Others | | | | 12<br>2.5 | mA<br>mA | | Maximum Input Current (Note 4) Without Latchup (Room Temp) (Note 5) | Room Temp | | | ± 100 | mA | | RAM Retention Voltage, Vr | 500 ns Rise and Fall Time (Min) | 2.5 | | | V | | Input Capacitance (Note 5) | | | | 7 | pF | | EEPROM Characteristics EEPROM Write Cycle Time EEPROM Number of Write Cycles EEPROM Data Retention | | 10 | | 10<br>10,000 | ms<br>Cycle<br>Years | Note 1: Rate of voltage change must be less than 0.5V/ms. Note 2: Supply current is measured after running 2000 cycles with a square wave CKI input, CKO open, inputs at rails and outputs open. Note 3: The HALT mode will stop CKI from oscillating in the RC and the Crystal configurations. Test conditions: All inputs tied to V<sub>CC</sub>, L and G ports are at TRI-STATE and tied to ground, all outputs low and tied to ground. Note 4: Pins G6 and $\overline{\text{RESET}}$ are designed with a high voltage input network for factory testing. These pins allow input voltages greater than $V_{CC}$ and the pins will have sink current to $V_{CC}$ when biased at voltages greater than $V_{CC}$ (the pins do not have source current when biased at a voltage below $V_{CC}$ ). The effective resistance to $V_{CC}$ is 750 $\Omega$ (typical). These two pins will not latch up. The voltage at G6 and $\overline{\text{RESET}}$ pins must be limited to less than 14V. ## COP6620C/COP6622C/COP6640C/COP6642C (Continued) ## AC Electrical Characteristics $-55^{\circ}\text{C} \le T_{\text{A}} \le +125^{\circ}\text{C}$ unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|------------|-----|---------------|----------------| | Instruction Cycle Time (tc)<br>Ext, Crystal/Resonator<br>(Div-by 10) | | 1 | - | DC | μs | | CKI Clock Duty Cycle (Note 5)<br>Rise Time (Note 5)<br>Fall Time (Note 5) | fr = 9 MHz Ext Clock<br>fr = 9 MHz Ext Clock | 40 | | 60<br>12<br>8 | %<br>ns<br>ns | | Inputs tsetup thold | | 220<br>66 | | | ns<br>ns | | Output Propagation Delay tpp1, tpp0 SO, SK All Others | $C_L = 100 \text{ pF, R}_L = 2.2 \text{ k}\Omega$ | o/ | | 0.8<br>1.1 | μs<br>μs | | MICROWIRE™ Setup Time (t <sub>UWS)</sub> MICROWIRE Hold Time (t <sub>UWH)</sub> MICROWIRE Output Propagation Delay Time (t <sub>UPD</sub> ) | | 20<br>56 | | 220 | ns<br>ns<br>ns | | Input Pulse Width<br>Interrupt Input High Time<br>Interrupt Input Low Time<br>Timer Input High Time<br>Timer Input Low Time | | 0 to to to | | | | | Reset Pulse Width | | 1.0 | _ | | μs | Note 5: Parameter sampled (not 100% tested). ## **Connection Diagrams** **DUAL-IN-LINE PACKAGE** Order Number COP6622C-XXX/N, COP66L22C-XXX/N, COP6642C-XXX/N, COP66L42C-XXX/N, COP8622C-XXX/N, COP86L42C-XXX/N, COP8642C-XXX/N, COP86L42C-XXX/N See NS Package Number D20A or N20A (D Package for Prototypes Only) #### SURFACE MOUNT Order Number COP6622C-XXX/WM, COP66L22C-XXX/WM, COP6642C-XXX/WM, COP66L42C-XXX/WM, COP8622C-XXX/WM, COP86L22C-XXX/WM, COP8642C-XXX/WM, COP86L42C-XXX/WM See NS Package Number M20B Order Number COP6620C-XXX/N, COP66L20C-XXX/N, COP6640C-XXX/N, COP66L40C-XXX/N, COP8620C-XXX/N, COP86L20C-XXX/N, COP8640C-XXX/N, COP86L40C-XXX/N, See NS Package Number D28C or N28B (D Package for Prototypes Only) TL/DD/10366-5 Order Number COP6620C-XXX/WM, COP66L20C-XXX/WM, COP6640C-XXX/WM, COP66L40C-XXX/WM, COP8620C-XXX/WM, COP86L20C-XXX/WM, COP8640C-XXX/WM, COP86L40C-XXX/WM See NS Package Number M28B #### COP8620C/COP8640C TL/DD/10366-8 FIGURE 3. Connection Diagrams ## **Pin Descriptions** V<sub>CC</sub> and GND are the power supply pins. CKI is the clock input. This can come from an external source, a R/C generated oscillator or a crystal (in conjunction with CKO). See Oscillator description. RESET is the master reset input. See Reset description. PORT I is a four bit Hi-Z input port. PORT L is an 8-bit I/O port. There are two registers associated with each L I/O port: a data register and a configuration register. Therefore, each L I/O bit can be individually configured under software control as shown below: | Port L<br>Config. | Port L<br>Data | Part L<br>Setup | |-------------------|----------------|-------------------------| | 0 | 0 | Hi-Z Input (TRI-STATE) | | 0 | 1 | Input With Weak Pull-Up | | 1 | 0 | Push-Pull "0" Output | | 1 | 1 | Push-Pull "1" Output | Three data memory address locations are allocated for these ports, one for data register, one for configuration register and one for the input pins. PORT G is an 8-bit port with 6 I/O pins (G0-G5) and 2 input pins (G6, G7). All eight G-pins have Schmitt Triggers on the inputs. The G7 pin functions as an input pin under normal operation and as the continue pin to exit the HALT mode. There are two registers with each I/O port: a data register and a configuration register. Therefore, each I/O bit can be individually configured under software control as shown below. | 1011. | ow. | | | | | | | |-------------------|----------------|-------------------------|--|--|--|--|--| | Port G<br>Config. | Port G<br>Data | Port G<br>Setup | | | | | | | 0 | 0 | Hi-Z Input (TRI-STATE) | | | | | | | 0 | 1 | Input With Weak Pull-Up | | | | | | | 1 | 0 | Push-Pull "0" Output | | | | | | | 1 | 1 1 | Push-Pull "1" Output | | | | | | Three data memory address locations are allocated for these ports, one for data register, one for configuration register and one for the input pins. Since G6 and G7 are input only pins, any attempt by the user to set them up as outputs by writing a one to the configuration register will be disregarded. Reading the G6 and G7 configuration bits will return zeros. Note that the chip will be placed in the HALT mode by setting the G7 data bit. Six bits of Port G have alternate features: G0 INTR (an external interrupt) G3 TIO (timer/counter input/output) G4 SO (MICROWIRE serial data output) G5 SK (MICROWIRE clock I/O) G6 SI (MICROWIRE serial data input) G7 CKO crystal oscillator output (selected by mask option) or HALT restart input (general purpose input) Pins G1 and G2 currently do not have any alternate functions PORT D is a four bit output port that is set high when RESET goes low. ### **Functional Description** Figure 1 shows the block diagram of the internal architecture. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. #### **ALU AND CPU REGISTERS** The ALU can do an 8-bit addition, subtraction, logical or shift operation in one cycle time. There are five CPU registers: A is the 8-bit Accumulator register PU is the upper 7 bits of the program counter (PC) PL is the lower 8 bits of the program counter (PC) B is the 8-bit address register, can be auto incremented or decremented. X is the 8-bit alternate address register, can be incremented or decremented. SP is the 8-bit stack pointer, points to subroutine stack (in RAM). B, X and SP registers are mapped into the on chip RAM. The B and X registers are used to address the on chip RAM. The SP register is used to address the stack in RAM during subroutine calls and returns. #### PROGRAM MEMORY Program memory for the COP8620C/COP8622C consists of 1024 bytes of ROM and the COP8640C/COP8642C consists of 2048 bytes of ROM. These bytes may hold program instructions or constant data. The program memory is addressed by the 15-bit program counter (PC). ROM can be indirectly read by the LAID instruction for table lookup. #### DATA MEMORY The data memory address space includes on chip RAM, EEPROM, I/O and registers. Data memory is addressed directly by the instruction or indirectly through B, X and SP registers. The COP8620C/COP8640C has 64 bytes of RAM. Sixteen bytes of RAM are mapped as "registers", these can be loaded immediately and decremented and tested. Three specific registers: X, B, and SP are mapped into this space, the other registers are available for general usage. Any bit of data memory can be directly set, reset or tested. I/O and registers (except A and PC) are memory mapped; therefore, I/O bits and register bits can be directly and individually set, reset and tested. RAM contents are undefined upon power-up. The COP8620C/COP8640C provides 64 bytes of EEPROM for nonvolatile data memory. The data EEPROM can be read and written in exactly the same way as the RAM. All instructions that perform read and write operations on the RAM work similarly upon the data EEPROM. The data EEPROM contains all 00s when shipped by the factory. A data EEPROM programming cycle is initiated by an instruction such as X, LD, SBIT and RBIT. The EE memory support circuitry sets the BsyERAM flag in the EECR register immediately upon beginning a data EEPROM write cycle. It will be automatically reset by the hardware at the end of the data EEPROM write cycle. The application program should test the BsyERAM flag before attempting a write operation to the data EEPROM. A second EEPROM write operation while a write operation is in progress will be ignored and the Werr flag in the EECR register will be set to indicate the error status. Once the write operation starts, nothing will stop the write operation, not by resetting the device, and not even turning off the V<sub>CC</sub> will guarantee the write operation to stop. Warning: The data memory pointer should not point to EEPROM unless the EEPROM is addressed. This will prevent inadvertent write to EEPROM. #### **EECR AND EE SUPPORT CIRCUITRY** The EEPROM module contains EE support circuits to generate all necessary high voltage programming pulses. An EEPROM cell in the erase state is read out as a 0 and the written state as a 1. The EECR register provides control, status and test mode functions for the EE module. The EECR register bit assignments are shown below. Werr Write Error. Writing to EEPROM while a previous write cycle is still busy, that is BsyERAM is 1, causes Werr to be set to 1 indicating error status. Werr is a Read/Write bit and is cleared by writing a 0 into it. BsyERAM This bit is a read only bit and is set to 1 when EEPROM is being written. It is automatically reset by the hardware upon completion of the write operation. This bit is not cleared by reset. If the bit is set upon power up or reset, the application program should test the BsyERAM flag and wait for the flag to go low before attempting a write operation to the data EEPROM. Bits 4 to 7 of the EECR register are used for encoding various EEPROM module test modes, most of which are for factory manufacturing tests. Except BsyERAM (bit 3) the EECR is cleared by reset. EECR is mapped into address location E0. Bit 2 can be used as flag. Bits 1 and 4 are always read as "0" and cannot be used as flags. #### RESET The RESET input when pulled low initializes the microcontroller. Initialization will occur whenever the RESET input is pulled low. Upon initialization, the ports L and G are placed in the TRI-STATE mode and the Port D is set high. The PC, PSW and CNTRL registers are cleared. The data and configuration registers for Ports L & G are cleared. Except bit 3, the EECR register is cleared. The external RC network shown in Figure 4 should be used to ensure that the RESET pin is held low until the power supply to the chip stabilizes. TL/DD/10366-9 RC ≥ 5X Power Supply Rise Time FIGURE 4. Recommended Reset Circuit | Wr | Test Mode Codes | | | | | Unused | Unused | | |-----|-----------------|-----|-----|---------|-----|--------|--------|-----| | Rd | Test Mode Codes | | | BsyERAM | | | Werr | | | Bit | 7** | 6** | 5** | 4** | 3 | 2* | 1** | 0 | | 1 | R/W | R/W | R/W | R/O | R/O | R/W | R/O | R/W | <sup>\*</sup>Can be used as flag bit <sup>\*\*</sup>Cannot be used as flag bit FIGURE 5. Crystal and R-C Connection Diagrams TL/DD/10366-10 #### OSCILLATOR CIRCUITS Figure 5 shows the three clock oscillator configurations. #### A. CRYSTAL OSCILLATOR The device can be driven by a crystal clock. The crystal network is connected between the pins CKI and CKO. Table I shows the component values required for various Table I shows the component values required for various standard crystal values. #### **B. EXTERNAL OSCILLATOR** CKI can be driven by an external clock signal. CKO is available as a general purpose input and/or HALT restart control. #### C. R/C OSCILLATOR CKI is configured as a single pin RC controlled Schmitt trigger oscillator. CKO is available as a general purpose input and/or HALT restart control. Table II shows the variation in the oscillator frequencies (due to the part) as functions of the R/C component values (R/C tolerances not included). TABLE I. Crystal Oscillator Configuration, T<sub>A</sub> = 25°C, V<sub>CC</sub> = 5.0V | R1<br>(kΩ) | R2<br>(MΩ) | C1<br>(pF) | C2<br>(pF) | CKI Freq<br>(MHz) | |------------|------------|------------|------------|-------------------| | 0 | 1 | 30 | 30-36 | 10 | | 0 | 1 | 30 | 30-36 | 4 | | 5.5 | 1 | 100 | 100 | 0.455 | TABLE II. RC Oscillator Configuration, $T_A = 25^{\circ}C$ , $V_{CC} = 5.0V$ | | R<br>(kΩ) | C<br>(pF) | CKI Freq.<br>(MHz) | Instr. Cycle<br>(μs) | |---|-----------|-----------|--------------------|----------------------| | 1 | 3.3 | 82 | 2.2 to 2.7 | 3.7 to 4.6 | | ١ | 5.6 | 100 | 1.1 to 1.3 | 7.4 to 9.0 | | l | 6.8 | 100 | 0.9 to 1.1 | 8.8 to 10.8 | Note: 3k ≤ R ≤ 200k 50 pF ≤ C ≤ 200 pF The device has three mask options for configuring the clock input. The CKI and CKO pins are automatically configured upon selecting a particular option. - Crystal/Resonator (CKI/10) CKO for crystal configuration - External (CKI/10) CKO available as G7 input - R/C (CKI/10) CKO available as G7 input G7 can be used either as a general purpose input or as a control input to continue from the HALT mode. #### **CURRENT DRAIN** The total current drain of the chip depends on: - 1) Oscillator operating mode-I1 - 2) Internal switching current-12 - 3) Internal leakage current—I3 - 4) Output source current-I4 - DC current caused by external input not at V<sub>CC</sub> or GND— - 6) EEPROM current during EE read operation. This current is active during 20% of the instruction cycle time—I6 - 7) EEPROM current during write operation—I7 Thus the total current drain, It is given as $$1t = 11 + 12 + 13 + 14 + 15 + 16 + 17$$ To reduce the total current drain, each of the above components must be minimum. Operating with a crystal network will draw more current than an external square-wave. The R/C mode will draw the most. Switching current, governed by the equation below, can be reduced by lowering voltage and frequency. Leakage current can be reduced by lowering voltage and temperature. The other two items can be reduced by carefully designing the end-user's system. $$I2 = C \times V \times f$$ #### Where C = equivalent capacitance of the chip. V = operating voltage f = CKI frequency #### HALT MODE The device supports a power saving mode of operation: HALT. The controller is placed in the HALT mode by setting the G7 data bit, alternatively the user can stop the clock input. In the HALT mode all internal processor activities including the clock oscillator are stopped. The fully static architecture freezes the state of the controller and retains all information until continuing. In the HALT mode, power requirements are minimal as it draws only leakage currents and output current. The applied voltage (V<sub>CC</sub>) may be decreased down to Vr (minimum RAM retention voltage) without altering the state of the machine. There are two ways to exit the HALT mode: via the RESET or by the CKO pin. A low on the RESET line reinitializes the microcontroller and starts executing from the address 0000H. A low to high transition on the CKO pin causes the microcontroller to continue with no reinitialization from the address following the HALT instruction. This also resets the G7 data bit. #### **INTERRUPTS** There are three interrupt sources, as shown below. A maskable interrupt on external G0 input (positive or negative edge sensitive under software control) A maskable interrupt on timer underflow or timer capture A non-maskable software/error interrupt on opcode zero #### INTERRUPT CONTROL The GIE (global interrupt enable) bit enables the interrupt function. This is used in conjunction with ENI and ENTI to select one or both of the interrupt sources. This bit is reset when interrupt is acknowledged. ENI and ENTI bits select external and timer interrupt respectively. Thus the user can select either or both sources to interrupt the microcontroller when GIE is enabled. IEDG selects the external interrupt edge (0 = rising edge, 1 = falling edge). The user can get an interrupt on both rising and falling edges by toggling the state of IEDG bit after each interrupt. IPND and TPND bits signal which interrupt is pending. After interrupt is acknowledged, the user can check these two bits to determine which interrupt is pending. This permits the interrupts to be prioritized under software. The pending flags have to be cleared by the user. Setting the GIE bit high inside the interrupt subroutine allows nested interrupts. The software interrupt does not reset the GIE bit. This means that the controller can be interrupted by other interrupt sources while servicing the software interrupt. #### INTERRUPT PROCESSING The interrupt, once acknowledged, pushes the program counter (PC) onto the stack and the stack pointer (SP) is decremented twice. The Global Interrupt Enable (GIE) bit is reset to disable further interrupts. The microcontroller then vectors to the address 00FFH and resumes execution from that address. This process takes 7 cycles to complete. At the end of the interrupt subroutine, any of the following three instructions return the processor back to the main program: RET, RETSK or RETI. Either one of the three instructions will pop the stack into the program counter (PC). The stack pointer is then incremented twice. The RETI instruction additionally sets the GIE bit to re-enable further interrupts. Any of the three instructions can be used to return from a hardware interrupt subroutine. The RETSK instruction should be used when returning from a software interrupt subroutine to avoid entering an infinite loop. FIGURE 6. Interrupt Block Diagram TL/DD/10366-11 #### **DETECTION OF ILLEGAL CONDITIONS** The device incorporates a hardware mechanism that allows it to detect illegal conditions which may occur from coding errors, noise and 'brown out' voltage drop situations. Specifically it detects cases of executing out of undefined ROM area and unbalanced stack situations. Reading an undefined ROM location returns 00 (hexadecimal) as its contents. The opcode for a software interrupt is also '00'. Thus a program accessing undefined ROM will cause a software interrupt. Reading an undefined RAM location returns an FF (hexadecimal). The subroutine stack grows down for each subroutine call. By initializing the stack pointer to the top of RAM (02F), the first unbalanced return instruction will cause the stack pointer to address undefined RAM. As a result the program will attempt to execute from FFFF (hexadecimal), which is an undefined ROM location and will trigger a software interrupt. #### MICROWIRE/PLUSTM MICROWIRE/PLUS is a serial synchronous bidirectional communications interface. The MICROWIRE/PLUS capability enables the device to interface with any of National Semiconductor's MICROWIRE peripherals (i.e. A/D converters, display drivers, EEPROMS, etc.) and with other microcontrollers which support the MICROWIRE/PLUS interface. It consists of an 8-bit serial shift register (SIO) with serial data input (SI), serial data output (SO) and serial shift clock (SK). Figure 7 shows the block diagram of the MICROWIRE/PLUS interface. The shift clock can be selected from either an internal source or an external source. Operating the MICROWIRE/PLUS interface with the internal clock source is called the Master mode of operation. Similarly, operating the MICROWIRE/PLUS interface with an external shift clock is called the Slave mode of operation. The CNTRL register is used to configure and control the MICROWIRE/PLUS mode. To use the MICROWIRE/PLUS, the MSEL bit in the CNTRL register is set to one. The SK clock rate is selected by the two bits, SL0 and SL1, in the CNTRL register. Table III details the different clock rates that may be selected. TABLE III | SL1 | SL0 | SK Cycle Time | |-----|-----|-----------------| | 0 | 0 | 2t <sub>C</sub> | | 0 | 1 | 4t <sub>C</sub> | | 1 | × | 8t <sub>C</sub> | where, t<sub>C</sub> is the instruction cycle clock. #### MICROWIRE/PLUS OPERATION Setting the BUSY bit in the PSW register causes the MI-CROWIRE/PLUS arrangement to start shifting the data. It gets reset when eight data bits have been shifted. The user may reset the BUSY bit by software to allow less than 8 bits to shift. The device may enter the MICROWIRE/PLUS mode either as a Master or as a Slave. Figure 8 shows how two microcontrollers and several peripherals may be interconnected using the MICROWIRE/PLUS arrangement. #### Master MICROWIRE/PLUS Operation In the MICROWIRE/PLUS Master mode of operation the shift clock (SK) is generated internally. The MICROWIRE/PLUS Master always initiates all data exchanges. (See Figure 8). The MSEL bit in the CNTRL register must be set to enable the SO and SK functions onto the G Port. The SO and SK pins must also be selected as outputs by setting appropriate bits in the Port G configuration register. Table IV summarizes the bit settings required for Master mode of operation. #### SLAVE MICROWIRE/PLUS OPERATION In the MICROWIRE/PLUS Slave mode of operation the SK clock is generated by an external source. Setting the MSEL bit in the CNTRL register enables the SO and SK functions onto the G Port. The SK pin must be selected as an input and the SO pin is selected as an output pin by appropriately setting up the Port G configuration register. Table IV summarizes the settings required to enter the Slave mode of operation. The user must set the BUSY flag immediately upon entering the Slave mode. This will ensure that all data bits sent by the Master will be shifted properly. After eight clock pulses the BUSY flag will be cleared and the sequence may be repeated. (See Figure 8.) #### **TABLE IV** | G4<br>Config.<br>Bit | G5<br>Config.<br>Bit | G4<br>Fun. | G5<br>Fun. | G6<br>Fun. | Operation | |----------------------|----------------------|------------|------------|------------|------------------| | 1 | 1 | so | Int. SK | SI | MICROWIRE Master | | 0 | 1 | TRI-STATE | Int. SK | SI | MICROWIRE Master | | 1 | 0 | so | Ext. SK | SI | MICROWIRE Slave | | 0 | 0 | TRI-STATE | Ext. SK | SI | MICROWIRE Slave | #### TIMER/COUNTER The device has a powerful 16-bit timer with an associated 16-bit register enabling them to perform extensive timer functions. The timer T1 and its register R1 are each organized as two 8-bit read/write registers. Control bits in the register CNTRL allow the timer to be started and stopped under software control. The timer-register pair can be operated in one of three possible modes. Table V details various timer operating modes and their requisite control settings. TL/DD/10366-12 #### **MODE 1. TIMER WITH AUTO-LOAD REGISTER** In this mode of operation, the timer T1 counts down at the instruction cycle rate. Upon underflow the value in the register R1 gets automatically reloaded into the timer which continues to count down. The timer underflow can be programmed to interrupt the microcontroller. A bit in the control register CNTRL enables the TIO (G3) pin to toggle upon timer underflows. This allow the generation of square-wave outputs or pulse width modulated outputs under software control. (See Figure 9) #### **MODE 2. EXTERNAL COUNTER** In this mode, the timer T1 becomes a 16-bit external event counter. The counter counts down upon an edge on the TIO pin. Control bits in the register CNTRL program the counter to decrement either on a positive edge or on a negative edge. Upon underflow the contents of the register R1 are automatically copied into the counter. The underflow can also be programmed to generate an interrupt. (See Figure 9) #### **MODE 3. TIMER WITH CAPTURE REGISTER** Timer T1 can be used to precisely measure external frequencies or events in this mode of operation. The timer T1 counts down at the instruction cycle rate. Upon the occurrence of a specified edge on the T10 pin the contents of the timer T1 are copied into the register R1. Bits in the control register CNTRL allow the trigger edge to be specified either as a positive edge or as a negative edge. In this mode the user can elect to be interrupted on the specified trigger edge. (See Figure 10.) FIGURE 8. MICROWIRE/PLUS Application TL/DD/10366-13 **TABLE V. Timer Operating Modes** | CNTRL<br>Bits<br>765 | Operation Mode | T Interrupt | Timer<br>Counts<br>On | |----------------------|---------------------------------------|-----------------|-----------------------| | 000 | External Counter W/Auto-Load Reg. | Timer Underflow | TIO Pos. Edge | | 001 | External Counter W/Auto-Load Reg. | Timer Underflow | TIO Neg. Edge | | 010 | Not Allowed | Not Allowed | Not Allowed | | 011 | Not Allowed | Not Allowed | Not Allowed | | 100 | Timer W/Auto-Load Reg. | Timer Underflow | tc | | 101 | Timer W/Auto-Load Reg./Toggle TIO Out | Timer Underflow | tc | | 110 | Timer W/Capture Register | TIO Pos. Edge | tc | | 111 | Timer W/Capture Register | TIO Neg. Edge | tc | FIGURE 9. Timer/Counter Auto **Reload Mode Block Diagram** ## FIGURE 10. Timer Capture Mode Block Dlagram #### TIMER PWM APPLICATION Figure 11 shows how a minimal component D/A converter can be built out of the Timer-Register pair in the Auto-Reload mode. The timer is placed in the "Timer with auto reload" mode and the TIO pin is selected as the timer output. At the outset the TIO pin is set high, the timer T1 holds the on time and the register R1 holds the signal off time. Setting TRUN bit starts the timer which counts down at the instruction cycle rate. The underflow toggles the TIO output and copies the off time into the timer, which continues to run. By alternately loading in the on time and the off time at each successive interrupt a PWM frequency can be easily generated. FIGURE 11. Timer Application ### **Control Registers** #### **CNTRL REGISTER (ADDRESS X'00EE)** The Timer and MICROWIRE/PLUS control register contains the following bits: **SL1 &** SL0 Select the MICROWIRE/PLUS clock divide-by **IEDG** External interrupt edge polarity select (0 = rising edge, 1 = falling edge) **MSEL** Enable MICROWIRE/PLUS functions SO and SK TRUN Start/Stop the Timer/Counter (1 = run, 0 = TC3 Timer input edge polarity select (0 = rising edge, 1 = falling edge) TC2 Selects the capture mode TC1 Selects the timer mode TC1 TC2 TC3 TRUN MSEL IEDG | SL1 SL0 BIT 7 BIT 0 #### **PSW REGISTER (ADDRESS X'00EF)** The PSW register contains the following select bits: GIE Global interrupt enable ENI External interrupt enable BUSY MICROWIRE/PLUS busy shifting IPND External interrupt pending ENTI Timer interrupt enable TPND Timer interrupt pending С Carry Flag HC Half carry Flag | HC | C | TPND | ENTI | IPND | BUSY | ENI | GIE | |-------|---|------|------|------|------|-----|-------| | Bit 7 | | | | | | | Bit 0 | ## **Memory Map** All RAM, ports and registers (except A and PC) are mapped into data memory address space. | Address | Contents | |----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | COP8620 | C/COP8640C | | 00 to 2F | On Chip RAM Bytes | | 30 to 7F | Unused RAM Address Space (Reads as all Ones) | | 80 to BF | On Chip EEPROM (64 bytes) | | C0 to CF | Expansion Space for I/O and Registers | | D0 to DF<br>D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7<br>D8-DB<br>DC<br>DD-DF | On Chip I/O and Registers Port L Data Register Port L Configuration Register Port L Input Pins (Read Only) Reserved for Port L Port G Data Register Port G Configuration Register Port G Input Pins (Read Only) Port I Input Pins (Read Only) Reserved for Port C Port D Data Register Reserved for Port D | | E0 to EF<br>E0<br>E1-E8<br>E9<br>EA<br>EB<br>EC<br>ED<br>EE | On Chip Functions and Registers EECR Reserved MICROWIRE/PLUS Shift Register Timer Lower Byte Timer Upper Byte Timer Autoload Register Lower Byte Timer Autoload Register Upper Byte CNTRL Control Register PSW Register | | F0 to FF<br>FC<br>FD<br>FE | On Chip RAM Mapped as Registers<br>X Register<br>SP Hegister<br>B Register | Reading unused memory locations below 7FH will return all ones. Reading other unused memory locations will return undefined data. ## **Addressing Modes** #### REGISTER INDIRECT This is the "normal" mode of addressing. The operand is the memory addressed by the B register or X register. #### DIRECT The instruction contains an 8-bit address field that directly points to the data memory for the operand. #### **IMMEDIATE** The instruction contains an 8-bit immediate field as the operand. ## REGISTER INDIRECT (AUTO INCREMENT AND DECREMENT) This is a register indirect mode that automatically increments or decrements the B or X register after executing the instruction. #### RELATIVE This mode is used for the JP instruction, the instruction field is added to the program counter to get the new program location. JP has a range of from -31 to +32 to allow a one byte relative jump (JP + 1 is implemented by a NOP instruction). There are no 'pages' when using JP, all 15 bits of PC are used. #### **Instruction Set** #### **REGISTER AND SYMBOL DEFINITIONS** #### Registers | A | 8-bit Accumulator register | |----|------------------------------| | В | 8-bit Address register | | X | 8-bit Address register | | SP | 8-bit Stack pointer register | | PC | 15-bit Program counter regis | | PU | upper 7 bits of PC | PL lower 8 bits of PC C 1-bit of PSW register for carry HC Half Carry GIE 1-bit of PSW register for global interrupt enable #### **Symbols** | [R] | Memory indirectly addressed by B register | |-----|-------------------------------------------| | [X] | Memory indirectly addressed by X register | | Mem | Direct address memory or [B] | | 141 | Discot address mamon, as [D] as Immediate | Meml Direct address memory or [B] or Immediate data Imm 8-bit Immediate data Reg Register memory: addresses F0 to FF (Includes B, X and SP) Bit Bit number (0 to 7) ← Loaded with ← Exchanged with ## Instruction Set (Continued) ### Instruction Set | ADD | add | A ← A + Meml | |--------|------------------------------|---------------------------------------------------------------| | ADC | add with carry | A ← A + Meml + C, C ← Carry | | | | HC ← Half Carry | | SUBC ( | subtract with carry | A ← A + Meml + C, C ← Carry | | | | HC ← Half Carry | | AND I | Logical AND | A ← A and Memi | | OR | Logical OR | A ← A or Memi | | | <b>-</b> | | | XOR | Logical Exclusive-OR | A ← A xor Meml | | IFEQ | IF equal | Compare A and Meml, Do next if A = Meml | | IFGT | IF greater than | Compare A and Meml, Do next if A > Meml | | IFBNE | IF B not equal | Do next if lower 4 bits of B ≠ Imm | | DRSZ | Decrement Reg. ,skip if zero | Reg ← Reg − 1, skip if Reg goes to 0 | | SBIT | Set bit | 1 to bit, | | | | Mem (bit = 0 to 7 immediate) | | RBIT ( | Reset bit | 0 to bit. | | 11011 | 1 to 3 ot Dit | Mem | | IEDIT | M L IA | | | IFBIT | If bit | If bit, | | | | Mem is true, do next instr. | | X | Exchange A with memory | A ←→ Mem | | LDA I | Load A with memory | A ← Memi | | LD mem | Load Direct memory Immed. | Mem ← Imm | | | Load Register memory Immed. | | | LD Reg | Load negister memory immed. | Reg ← Imm | | x | Exchange A with memory [B] | $A \longleftrightarrow [B] (B \longleftarrow B \pm 1)$ | | x | Exchange A with memory [X] | $A \longleftrightarrow [X] (X \longleftarrow X \pm 1)$ | | LDA Í | Load A with memory [B] | $A \leftarrow [B] (B \leftarrow B \pm 1)$ | | LDA l | Load A with memory [X] | $A \leftarrow [X] (X \leftarrow X \pm 1)$ | | LDM | Load Memory Immediate | [B] ← Imm (B ← B±1) | | | <del></del> | | | CLRA | Clear A | A ← 0 | | INCA | Increment A | A ← A + 1 | | DECA | Decrement A | A ← A − 1 | | LAID | Load A indirect from ROM | $A \leftarrow ROM(PU,A)$ | | DCORA | DECIMAL CORRECT A | A ← BCD correction (follows ADC, SUBC) | | RRCA | ROTATE A RIGHT THRU C | $C \rightarrow A7 \rightarrow \rightarrow A0 \rightarrow C$ | | SWAPA | Swap nibbles of A | A7 A4 ←→ A3 A0 | | sc | Set C | C ← 1, HC ← 1 | | | | | | RC I | Reset C | $C \leftarrow 0, HC \leftarrow 0$ | | IFC | If C | If C is true, do next instruction | | IFNC | If not C | If C is not true, do next instruction | | JMPL | Jump absolute long | PC ← ii (ii = 15 bits, 0 to 32k) | | JMP | Jump absolute | PC110 ← i (i = 12 bits) | | JP | Jump relative short | $PC \leftarrow PC + r(ris - 31 to + 32, not 1)$ | | JSRL | Jump subroutine long | | | | | | | JSR | Jump subroutine | [SP] ← PL,[SP-1] ← PU,SP-2,PC110 ← i | | JID | Jump indirect | PL ← ROM(PU,A) | | RET | Return from subroutine | $SP+2,PL \leftarrow [SP],PU \leftarrow [SP-1]$ | | RETSK | Return and Skip | SP+2,PL ← [SP],PU ← [SP-1],Skip next instruction | | RETI | Return from Interrupt | SP+2,PL ← [SP],PU ← [SP-1],GIE ← 1 | | INTR | Generate an interrupt | $[SP] \leftarrow PL[SP-1] \leftarrow PUSP-2PC \leftarrow OFF$ | | NOP | No operation | PC ← PC + 1 | | 1100 | 140 0401411011 | , 10 ← FO 1 1 | | $\mathbf{c}$ | |------------------------------| | $\tilde{\sim}$ | | | | ٧. | | 40C/COP86L | | စ | | ā | | $\overline{}$ | | <u>.</u> | | $\mathbf{c}$ | | $\pi$ | | $\mathbf{\circ}$ | | Š | | () | | $\simeq$ | | $\mathbf{\circ}$ | | 4 | | | | OP86L. | | $\approx$ | | ₩ | | α, | | | | $\mathbf{\mathcal{Y}}$ | | $\mathbf{c}$ | | < | | ည္ထ | | ب | | N | | C | | P86L22 | | 77 | | ã | | œ | | 0 | | $\overline{}$ | | J | | 3/COP86L22C/C | | $\sim$ | | - | | $\mathbf{c}$ | | ō | | $\overline{\sim}$ | | | | | | စ | | æ | | ñ | | = | | $\mathbf{o}$ | | 7 | | $\mathbf{\mathcal{C}}$ | | - | | $\mathbf{c}$ | | $\sim$ | | | | 7 | | ي | | œ | | 0 | | = | | U | | () | | $\leq$ | | | | U | | 0 | | = | | | | $\mathbf{z}$ | | œ | | Δ. | | OP8640C/COP8642C/COP86L20C/C | | بر | | $\mathbf{c}$ | | | | - | | 7 | | ડૅ | | 2C/2 | | 22C/ | | 522C/ | | 3622C/ | | 98622C/ | | P8622C/ | | <b>JP8622C/</b> | | :OP8622C/ | | COP8622C/ | | /COP8622C/ | | 3/COP8622C/ | | C/COP8622C/ | | 0C/COP8622C/ | | 20C/COP8622C/ | | 520C/COP8622C/ | | 3620C/COP8622C/ | | 98620C/COP8622C/ | | P8620C/COP8622C/ | | P8620C/C | | ;OP8620C/COP8622C/ | | COP8620C/COP8622C/ | | | | | | | g table) | is an unused opcode (see following table) | nused opcode | • is an ur | ićn | Md is a directly addressed memory locatic n | addressed | s a directly | | is the immediate data | Is | where, | |-----------------|----------|-----|------------------|------------------|----------|-------------------------------------------|----------------|----------------|---------------|---------------------------------------------|----------------|--------------|----------|-----------------------|--------|-------------------| | JP + 32 JP + | | # 1 | JMP<br>0F00-0FFF | JSR<br>0F00-0FFF | IFBNE OF | LDB,0 | RBIT<br>7,[B] | SBIT<br>7,[B] | RETI | * | * | * | DRSZ 0FF | LD 0FF, #1 | JP -16 | JP -0 | | JP + 31 JP + 15 | <b>-</b> | Ħ | JMP<br>0E00-0EFF | JSR<br>0E00-0EFF | IFBNE 0E | LDB, 1 | RBIT<br>6, [B] | SBIT<br>6, [B] | RET | LD<br>[B], #i | LD A,<br>[B] | ≅ è | DRSZ 0FE | LD OFE, #i | JP -17 | ٦ <sub>P</sub> -1 | | JP + 30 JP +14 | <b>-</b> | Ή | JMP<br>0D00-0DFF | JSR<br>OD00-ODFF | IFBNE OD | LDB, 2 | RBIT<br>5,[B] | SBIT<br>5,[B] | RETSK | LD A, | JSRL | DIR | DRSZ 0FD | LD 0FD,#i | JP -18 | JP -2 | | JP + 29 JP +13 | | -11 | JMP<br>0C00-0CFF | JSR<br>0C00-0CFF | IFBNE 0C | LDB,3 | RBIT<br>4,[B] | SBIT<br>4,[B] | * | X A,Md | JMPL | LD Md,<br>#i | DRSZ 0FC | LD 0FC,#i | JP-19 | JР-3 | | JP + 28 JP + 12 | | п | JMP<br>0B00-0BFF | JSR<br>0B00-0BFF | IFBNE 08 | LDB,4 | RBIT<br>3,[B] | SBIT<br>3,[B] | DECA | LD<br>[B-],#i | LD A,<br>[B-] | | DRSZ 0FB | LD 0FB,#i | JP -20 | ٦<br>4 | | JP + 27 JP + 11 | | ., | JMP<br>0A00-0AFF | JSR<br>0A00-0AFF | IFBNE 0A | LDB,5 | RBIT<br>2,[B] | SBIT<br>2,[B] | INCA | LD<br>[B+],#i | LD A,<br>[B+] | [X+] | DRSZ 0FA | LD 0FA,#i | JP -21 | چ<br>9- | | JP + 26 JP + | JP + 26 | | JMP<br>0900-09FF | JSR<br>0900-09FF | IFBNE 9 | LDB,6 | RBIT<br>1,[B] | SBIT<br>1,[B] | IFNC | * | * | * | DRSZ 0F9 | LD 0F9,#i | JP -22 | JP -6 | | JP + 25 JP + | JP + 25 | | JMP<br>0800-08FF | JSR<br>0800-08FF | IFBNE 8 | LDB,7 | RBIT<br>0,[B] | SBIT<br>0,[B] | IFC | LD A,<br>#i | * | NOP | DRSZ 0F8 | LD 0F8,#i | JP -23 | JP-7 | | JP + 24 JP + | JP + 24 | | JMP<br>0700-07FF | JSR<br>0700-07FF | IFBNE 7 | LDB,8 | * | IFBIT<br>7,[B] | OR<br>A,[B] | OR A,<br>#i | * | * | DRSZ 0F7 | LD 0F7,#i | JP -24 | Ъ-8 | | JP + 23 JP | JP + 23 | | JMP<br>0600-06FF | JSR<br>0600-06FF | IFBNE 6 | LDB,9 | DCORA | IFBIT<br>6,[B] | XOR<br>A,[B] | XOR A,<br>#i | (B) | Σ× | DRSZ 0F6 | LD 0F6,#i | JP -25 | JP -9 | | JP + 22 JP | JP + 22 | | JMP<br>0500-05FF | JSR<br>0500-05FF | IFBNE 5 | LD B, 0A | SWAPA | 1FB1T<br>5,[B] | AND<br>A,[B] | AND A,<br>#i | JID | * | DRSZ 0F5 | LD 0F5,#i | JP -26 | JP -10 | | JP + 21 JP + | JP + 21 | | JMP<br>0400-04FF | JSR<br>0400-04FF | IFBNE 4 | LD B, 0B | CLRA | 1FBIT<br>4,[B] | ADD<br>A,[B] | ADD A,<br>#i | LAID | * | DRSZ 0F4 | LD 0F4,#i | JP -27 | JP-11 | | JP + 20 JP + 4 | JP + 20 | | JMP<br>0300-03FF | JSR<br>0300-03FF | IFBNE 3 | LD B, OC | * | 1FB1T<br>3,[B] | IFGT<br>A,[B] | IFGT A,<br>#i | X A,<br>[B – ] | X ×<br>A, | DRSZ 0F3 | LD 0F3,#i | JP-28 | JP -12 | | JP + 19 JP + 3 | JP + 19 | | JMP<br>0200-02FF | JSR<br>0200-02FF | IFBNE 2 | LD B, OD | * | 1FBIT<br>2,[B] | IFEQ<br>A,[B] | IFEQ A,<br>#i | X A,<br>[B+] | X + , | DRSZ 0F2 | LD 0F2,#i | JP -29 | JP -13 | | JP + 18 JP + | JP + 18 | | JMP<br>0100-01FF | JSR<br>0100-01FF | IFBNE 1 | LD B, OE | * | 1,[B] | SUBC<br>A,[B] | SUBC A,<br>#i | sc | * | DRSZ 0F1 | LD 0F1,#i | JP -30 | JP -14 | | JP + 17 INTR | JP + 17 | | JMP<br>0000-00FF | JSR<br>0000-00FF | IFBNE 0 | LD B, OF | * | 1FBIT<br>0,[B] | ADC A,<br>[B] | ADC A,<br>#i | RC | RRCA | DRSZ 0F0 | LD 0F0,#i | JP-31 | JP -15 | | 1 0 | 1 | | 2 | 3 | 4 | G | 6 | 7 | 8 | 9 | > | В | င | ם | Е | П | | | | | | | | | 7-4 | Bits 7-4 | | | | | | | | | ### **Instruction Execution Time** Most instructions are single byte (with immediate addressing mode instruction taking two bytes). Most single instructions take one cycle time to execute. See the BYTES and CYCLES per INSTRUCTION table for details. # BYTES and CYCLES per INSTRUCTION The following table shows the number of bytes and cycles for each instruction in the format of byte/cycle. #### **Arithmetic and Logic Instructions** | C. | [B] | Direct | immed. | |-------|-----|--------|--------| | ADD | 1/1 | 3/4 | 2/2 | | ADC | 1/1 | 3/4 | 2/2 | | SUBC | 1/1 | 3/4 | 2/2 | | AND | 1/1 | 3/4 | 2/2 | | OR | 1/1 | 3/4 | . 2/2 | | XOR | 1/1 | 3/4 | 2/2 | | IFEQ | 1/1 | 3/4 | 2/2 | | IFGT | 1/1 | 3/4 | 2/2 | | IFBNE | 1/1 | 1 A 1 | 1 6 | | DRSZ | 10 | - 1/3 | 1 | | SBIT | 1/1 | 3/4 | | | RBIT | 1/1 | 3/4 | | | IFBIT | 1/1 | 3/4 | * * | #### **Memory Transfer Instructions** | | | ster<br>rect<br>[X] | 7 5 | Immed. | Auto Inc | r Indirect<br>or & Decr<br>[X+, X-] | | |------------|-----|---------------------|-----|--------|----------|-------------------------------------|-------------| | X A,* | 1/1 | 1/3 | 2/3 | ÷ | 1/2 | 1/3 | | | LD A,* | 1/1 | 1/3 | 2/3 | 2/2 | 1/2 | 1/3 | 3. | | LD B,Imm | 5 | | 1.5 | 1/1. | 1 3 | -0 | (If B < 16) | | LD B,Imm | | | | 2/3 | | | (If B > 15) | | LD Mem,Imm | 2/ | /2 | 3/3 | | 2/2 | | | | LD Reg,Imm | . 1 | | - | 2/3 | - W 0 | * | . 1 | <sup>= &</sup>gt; Memory location addressed by B or X or directly. | N. P. S. | Instructions U | sing A & C | Transfer of Contr | ol Instructions | |----------|----------------|------------|-------------------|-----------------| | 4 | CLRA- | 1/1 | JMPL | 3/4 | | - 1 1 | INCA | 1/1 | JMP | 2/3 | | | DECA | 1/1 | JP | 1/3 | | | LAID . | 1/3 | JSRL | 3/5 | | | DCORA | 1/1 | JSR | 2/5 | | 1 | RRCA | 1/1 | JID | 1/3 | | | SWAPA | 1/1 | RET | 1/5 | | | SC | 1/1 | RETSK | 1/5 | | × 1 | RC | 1/1 | RETI | 1/5 | | | IFC . | 1/1 | INTR | 1/7 | | - | IFNC | 5 1/1 · · | NOP | 1/1 | # BYTES and CYCLES per INSTRUCTION (Continued) The following table shows the instructions assigned to unused opcodes. This table is for information only. The operations performed are subject to change without notice. Do not use these opcodes. | Unused<br>Opcode | Instruction | Unused<br>Opcode | Instruction | |------------------|-------------|------------------|-------------| | 60 | NOP | A9 | NOP | | 61 | NOP | AF | LD A, [B] | | 62 | NOP | B1 | C → HC | | 63 | NOP | B4 | NOP | | 67 | NOP | B5 | NOP | | 8C | RET | B7 | X A, [X] | | 99 | NOP | B9 | NOP | | 9F | LD [B], #i | BF | LD A, [X] | | A7 | X A, [B] | | | | A8 | NOP | | | ## **Option List** The mask programmable options are listed out below. The options are programmed at the same time as the ROM pattern to provide the user with hardware flexibility to use a variety of oscillator configuration. #### **OPTION 1: CKI INPUT** = 1 Crystal/Resonator (CKI/10) CKO for crystal con- figuration = 2 External (CKI/10) CKO available as G7 input = 3 R/C (CKI/10) CKO available as G7 input #### **OPTION 2: BONDING** = 1 28 pin DIP = 2 N/A = 3 20 pin DIP = 4 20 SO = 5 28 SO The following option information is to be sent to National along with the EPROM. #### **Option Data** Option 1 Value is: \_\_ CKI Input Option 2 Value is: \_\_ COP Bonding ## **Development Support** #### **IN-CIRCUIT EMULATOR** The MetaLink iceMASTER™-COP8 Model 400 In-Circuit Emulator for the COP8 family of microcontrollers features high-performance operation, ease of use, and an extremely flexible user-interface for maximum productivity. Interchangeable probe cards, which connect to the standard common base, support the various configurations and packages of the COP8 family. The iceMASTER provides real time, full speed emulation up to 10 MHz, 32k bytes of emulation memory and 4k frames of trace buffer memory. The user may define as many as 32k trace and break triggers which can be enabled, disabled, set or cleared. They can be simple triggers based on code or address ranges or complex triggers based on code address, direct address, opcode value, opcode class or immediate operand. Complex breakpoints can be ANDed or ORed together. Trace information consists of address bus values, opcodes and user selectable probe clips status (external event lines). The trace buffer can be viewed as raw hex or as disassembled instructions. The probe clip bit values can be displayed in binary, hex or digital waveform formats. During single-step operation the dynamically annotated code feature displays the contents of all accessed (read and write) memory locations and registers, as well as flow-of-control direction change markers next to each instruction executed. The iceMASTER's performance analyzer offers a resolution of better than 6 $\mu s.$ The user can easily monitor the time spent executing specific portions of code and find "hot spots" or "dead code". Up to 15 independent memory areas based on code address or label ranges can be defined. Analysis results can be viewed in bargraph format or as actual frequency count. Emulator memory operations for program memory include single line assembler, disassembler, view, change and write to file. Data memory operations include fill, move, compare, dump to file, examine and modify. The contents of any memory space can be directly viewed and modified from the corresponding window. The iceMASTER comes with an easy to use windowed interface. Each window can be sized, highlighted, color-controlled, added, or removed completely. Commands can be accessed via pull-down-menus and/or redefinable hot keys. A context sensitive hypertext/hyperlinked on-line help system explains clearly the options the user has from within any window. The iceMASTER connects easily to a PC via the standard COMM port and its 115.2k baud serial link keeps typical program download time to under 3 seconds. The following tables list the emulator and probe cards ordering information. #### **Emulator Ordering Information** | Part Number | Description | Current<br>Version | | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--| | IM-COP8/400/1‡ | 0/1‡ MetaLink base unit in-circuit emulator for all COP8 devices, symbolic debugger software and RS-232 serial interface cable, with 110V @ 60 Hz Power Supply. | | | | IM-COP8/400/2‡ | MetaLink base unit in-circuit emulator for all COP8 devices, symbolic debugger software and RS-232 serial interface cable, with 220V @ 50 Hz Power Supply. | Model File Rev<br>3.050. | | <sup>‡</sup> These parts include National's COP8 Assembler/Linker/Librarian Package (COP8-DEV-IBMA) ### **Development Support (Continued)** #### **Probe Card Ordering Informaton** | Part Number | Pkg. | Voltage<br>Range | Emulates | |-----------------|--------|------------------|-----------------| | MHW-8640C20D5PC | 20 DIP | 4.5-5.5V | COP8642C, 8622C | | MHW-8640C20DWPC | 20 DIP | 2.5-6.0V | COP8642C, 8622C | | MHW-8640C28D5PC | 28 DIP | 4.5-5.5V | COP8640C, 8620C | | MHW-8640C28DWPC | 28 DIP | 2.5-6.0V | COP8640C, 8620C | #### MACRO CROSS ASSEMBLER National Semiconductor offers a COP8 macro cross assembler. It runs on industry standard compatible PCs and supports all of the full-symbolic debugging features of the MetaLink iceMASTER emulators. #### **Assembler Ordering Information** | Part Number | Description | Manual | |---------------|--------------------------------------------------------------------------------|---------------| | COP8-DEV-IBMA | COP8 Assembler/<br>Linker/Librarian for<br>IBM®, PC/XT®, AT®<br>or compatible. | 424410632-001 | #### SINGLE CHIP EMULATOR DEVICE The COP8 family is fully supported by single chip hybrid emulators. For more detailed information refer to the emulation device specific data sheets and the emulator selection table below. #### PROGRAMMING SUPPORT Programming of the single chip emulator devices is supported by different sources. The table below shows the programmers certified for programming the hybrid emulator versions. #### **DIAL-A-HELPER** Dial-A-Helper is a service provided by the Microcontroller Applications Group. The Dial-A-Helper is an Electronic Bulletin Board information system. #### INFORMATION SYSTEM The Dial-A-Helper system provides access to an automated information storage and retrieval system that may be accessed over standard dial-up telephone lines 24 hours a day. The system capabilities include a MESSAGE SECTION (electronic mail) for communications to and from the Microcontroller Applications Group and a FILE SECTION which consists of several file areas where valuable application software and utilities could be found. The minimum requirement for accessing the Dial-A-Helper is a Hayes compatible modem. #### **EPROM Programmer Information** | Manufacturer and Product | U.S. Phone<br>Number | Europe Phone<br>Number | Asia Phone<br>Number | | |----------------------------------------------------|----------------------|----------------------------------------------------------|------------------------------|--| | MetaLink-Debug<br>Module | (602) 926-0797 | Germany: +49-<br>8141-1030 | Hong Kong: +852-<br>737-1800 | | | Xeltek-Superpro | (408) 745-7974 | Germany: +49<br>2041 684758 | Singapore: +65 276<br>6433 | | | BP Microsystems-<br>EP-1140 | (800) 224-2102 | Germany +49 89<br>857 66 67 | Hong Kong: +852<br>388 0629 | | | Data I/O - Unisite;<br>- System 29,<br>- System 39 | (800) 322-8246 | Europe: +31-20-<br>622866<br>Germany: +49-89-<br>85-8020 | Japan: +33-432-<br>6991 | | | Abcom- COP8<br>Programmer | 0 | Europe: +89 808707 | | | | System General<br>Turpro-1-FX;<br>-APRO | (408) 263-6667 | Switzerland: +31-<br>921-7844 | Taiwan: +2-9173005 | | #### Single Chip Emulator Selection Table | Device Number | Clock Option | Package | Description | Emulates | |----------------|-------------------------------------------|---------|------------------------|-----------------| | COP8640CMHD-X | X=1: Crystal<br>X=2: External<br>X=3: R/C | 28 DIP | Hybrid, UV<br>Erasable | COP8640C, 8620C | | COP8640CMHEA-X | X=1: Crystal<br>X=2: External<br>X=3: R/C | 28 SO | Hybrid, UV<br>Erasable | COP8640C, 8620C | | COP8642CMHD-X | X=1: Crystal<br>X=2: External<br>X=3: R/C | 20 DIP | Hybrid, UV<br>Erasable | COP8642C, 8622C | ## **Development Support (Continued)** If the user has a PC with a communications package then files from the FILE SECTION can be down-loaded to disk for later use. #### ORDER P/N: MOLE-DIAL-A-HLP Information System Package contains: Dial-A-Helper Users Manual Public Domain Communications Software #### **FACTORY APPLICATIONS SUPPORT** Dial-A-Helper also provides immediate factory applications support. If a user has questions, he can leave messages on our electronic bulletin board, which we will respond to. Voice: (800) 272-9959 Modem: Canada/U.S.: (800) NSC-MICRO Baud: Setup: 14.4k Length: Length: 8-Bit Parity: None Stop Bit: 1 Operation: 24 Hrs. 7 Days