## National Semiconductor ## COP8780C/COP8781C/COP8782C 8-Bit One-Time Programmable (OTP) Microcontroller ## General Description The COP8780C, COP8781C and COP8782C are members of the COPSTM 8-bit microcontroller family. They are fully static microcontrollers, fabricated using double-metal, double poly silicon gate microCMOS EPROM technology. These devices are available as UV erasable or One Time Programmable (OTP). These low cost microcontrollers are complete microcomputers containing all system timing, interrupt logic, EPROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8-bit memory mapped architecture, MI-CROWIRE/PLUSTM serial I/O, a 16-bit timer/counter with associated 16-bit autoreload/capture register, and a multisourced interrupt. Each I/O pin has software selectable options to adapt the device to the specific application. These devices operate over a voltage range of 4.5V to 6.0V. An efficient, regular instruction set operating at a 1 µs instruction cycle rate provides optimal throughput. The COP8780C, COP8781C and COP8782C can be configured to EMULATE the COP880C, COP840C and COP820C microcontrollers. ## Key Features - 16-bit multi-function timer supporting - PWM mode - External event counter mode - Input capture mode - Crystal, RC or External Oscillator, user configurable - 4 kbytes on-chip OTP EPROM with security feature - 128 or 64 bytes of on-chip RAM, user configurable #### I/O Features - Memory-mapped I/O - Software selectable I/O options (TRI-STATE®, Push-Pull, Weak Pull-Up Input, High Impedance input) - Schmitt trigger inputs on Port G - MICROWIRE/PLUS serial I/O - Packages: - 44 PLCC, OTP, Emulates COP880C, 36 I/O pins - 40 DIP, OTP, Emulates COP880C, 36 I/O pins - 28 DIP, OTP, Emulates COP820C/840C/881C, 24 I/O pins - 20 DIP, OTP, Emulates COP822C/842C, 16 I/O pins - 28 SO, 20 SO, OTP - 44 LDCC, UV Erasable - 40 CERDIP, 28 CERDIP, 20 CERDIP, UV Erasable #### CPU/Instruction Set Features - 1 µs instruction cycle time - Three multi-source interrupts servicing - External interrupt with selectable edge - Timer interrupt - Software interrupt - Versatile and easy to use instruction set - 8-bit Stack Pointer (SP)—stack in RAM - Two 8-bit Register Indirect Data Memory Pointers (B and X) ## Fully Static CMOS - Low current drain (typically $< 1 \mu A$ ) - Extra-low current static HALT mode - Single supply operation: 4.5V to 6.0V - Temperature range: -40°C to +85°C ## Development Support - Emulation device for the COP880C, COP840C, and COP820C - Real-time emulation and full program debug offered by MetaLink development system ## **Block Diagram** FIGURE 1. Block Diagram ## **Connection Diagrams** Order Number COP8780C-XXX/V or COP8780C-XXX/EL See NS Package Number EL40C or V44A Order Number COP8780C-XXX/N or COP8780C-XXX/J See NS Package Number J40AQ or N40A Order Number COP78782C/XXX/J, COP8782C-XXX/N or COP8782C-XXX/WM See NS Package Number J20AQ, M20B or N20B Top View Order Number COP8781C-XXX/J, COP8781C-XXX/N or COP8781C-XXX/WM See NS Package Number J28AQ, M28B or N28B FIGURE 3. Connection Diagrams ## COP8780C/COP8781C/COP8782C 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>) Programming Voltage Vpp (RESET pin) 13.4V and ME (pin G6) Voltage at any Pin -0.3V to $V_{CC} + 0.3V$ Total Current into V<sub>CC</sub> Pin (Source) Total Current out of GND Pin (Sink) 50 mA 60 mA Storage Temperature Range $-65^{\circ}$ C to $+150^{\circ}$ 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 COP87XXC; $-40^{\circ}\text{C} \le T_{A} \le +85^{\circ}\text{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<br>V | | Supply Current<br>CKI = 10 MHz (Note 2)<br>HALT Current (Note 3) | $V_{CC} = 6V, t_C = 1 \mu s$<br>$V_{CC} = 6V, CKI = 0 MHz$ | | | 21<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> | | 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 6) | | 0.05 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 Allowable Sink/Source | $V_{CC} = 4.5V, V_{OH} = 3.8V$ $V_{CC} = 4.5V, V_{OL} = 1.0V$ $V_{CC} = 4.5V, V_{OH} = 3.2V$ $V_{CC} = 4.5V, V_{OH} = 3.8V$ $V_{CC} = 4.5V, V_{OL} = 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>μA | | Current per Pin D Outputs (Sink) All Others | | | | 15<br>3 | mA<br>mA | | Maximum Input Current (Notes 4, 6) without Latchup (Room Temp) | Room Temp | | | ± 200 | mA | | RAM Retention Voltage, Vr<br>(Note 5) | | 2.0 | | | V | | Input Capacitance | (Note 6) | | | 7 | pF | | Load Capacitance on D2 | (Note 6) | | | 1000 | pF | 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. Halt test conditions: All Inputs tied to VCC. L, C, and G port I/O's configured as outputs and programmed low; D outputs programmed low; the window for UV erasable packages is completely covered with an opaque cover to prevent light from falling onto the die during HALT mode test. Parameter refers to HALT mode entered via setting bit 7 of the G Port data register. Note 4: Pins G6 and RESET are designed with a high voltage input network for factory testing. These pins allow input voltages greater than VCC 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Ω (typ). These two pins will not latch up. The voltage at the pins must be limited to less than 14V. Note 5: To maintain RAM integrity, the voltage must not be dropped or raised instantaneously. Note 6: Parameter characterized but not tested. ## COP8780C/COP8781C/COP8782C AC Electrical Characteristics $-40^{\circ}\text{C} < T_{A} < +85^{\circ}\text{C}$ unless otherwise specified | Parameter | Condition | Min | Тур | Max | Units | |----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------|-----|---------------|-------------------------------------------------------------| | Instruction Cycle Time (t <sub>C</sub> ) Crystal/Resonator or External Clock R/C Oscillator Mode | V <sub>CC</sub> ≥ 4.5V<br>V <sub>CC</sub> ≥ 4.5V | 1 3 | | DC<br>DC | μs<br>μs | | CKI Clock Duty Cycle (Note 7) Rise Time (Note 7) Fall Time (Note 7) | fr = Max<br>fr = 10 MHz Ext Clock<br>fr = 10 MHz Ext Clock | 45 | | 55<br>12<br>8 | %<br>ns<br>ns | | Inputs tsetup tHOLD | V <sub>CC</sub> ≥ 4.5V<br>V <sub>CC</sub> ≥ 4.5V | 200<br>60 | | | ns<br>ns | | Output Propagation Delay t <sub>PD1</sub> , t <sub>PD0</sub> SO, SK All Others | $C_L$ = 100 pF, $R_L$ = 2.2 k $\Omega$<br>$V_{CC} \ge 4.5 V$<br>$V_{CC} \ge 4.5 V$ | | | 0.7 | μs<br>μs | | MICROWIRE™ Setup Time (t <sub>UWS)</sub> MICROWIRE Hold Time (t <sub>UWH)</sub> MICROWIRE Output Propagation Delay (t <sub>UPD</sub> ) | | 20<br>56 | | 220 | 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 | | 1<br>1<br>1 | | | t <sub>c</sub> t <sub>c</sub> t <sub>c</sub> t <sub>c</sub> | | Reset Pulse Width | | 1.0 | | | μs | Note 7: Parameter guaranteed by design, but not tested. $t_c$ = Instruction Cycle Time. ## **Timing Diagram** TL/DD/10802-2 ## **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 an 8-bit Hi-Z input port. The 28-pin device does not have a full complement of PORT I pins. The unavailable pins are not terminated i.e., they are floating. A read operation for these unterminated pins will return unpredictable values. The user must ensure that the software takes this into account by either masking or restricting the accesses to bit operations. The unterminated PORT I pins will draw power only when addressed. PORT L is an 8-bit I/O port. PORT C is a 4-bit I/O port. Three memory locations are allocated for the L, G and C ports, one each for data register, configuration register and the input pins. Reading bits 4-7 of the C-Configuration register, data register, and input pins returns undefined data. There are two registers associated with the L and C ports: a data register and a configuration register. Therefore, each L and CI/O bit can be individually configured under software control as shown below: | Config. | Data | Ports L and C Setup | |---------|------|--------------------------------------| | 0 | 0 | Hi-Z Input (TRI-STATE Output) | | 0 | 1 | Input with Pull-Up (Weak One Output) | | 1 | 0 | Push-Pull Zero Output | | 1 | 1 | Push-Pull One Output | On the 20- and 28-pin parts, it is recommended that all bits of Port C be configured as outputs to minimize current. 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. There are two registers associated with the G port: a data register and a configuration register. Therefore, each G port bit can be individually configured under software control as shown below: | Config. | Data | Port G Setup | |---------|------|--------------------------------------| | 0 | 0 | Hi-Z Input (TRI-STATE Output) | | 0 | 1 | Input with Pull-Up (Weak One Output) | | 1 | 0 | Push-Pull Zero Output | | 1 | 1 | Push-Pull One Output | Since G6 and G7 are input only pins, any attempt by the user to configure them as outputs by writing a one to the configuration register will be disregarded. Reading the G6 and G7 configuration bits will return zeros. The device will be placed in the HALT mode by writing a one to the G7 bit in the G-port data register. Six pins of Port G have alternate features: G0 INTR (an external interrupt) G3 TIO (timer/counter input/output) G4 SO (MICROWIRE/PLUS serial data output) G5 SK (MICROWIRE/PLUS clock I/O) G6 SI (MICROWIRE/PLUS serial data input) G7 CKO crystal oscillator output (selected by programming the ECON register) or HALT Restart/general purpose input Pins G1 and G2 currently do not have any alternate func- PORT D is an 8-bit output port that is preset high when RESET goes low. Care must be exercised with the D2 pin operation. At reset, the external load on this pin must ensure that the output voltage stay above 0.7 V<sub>CC</sub> to prevent the chip from entering special modes. Also, keep the external loading on D2 to less than 1000 pF. ### **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, which points to the subroutine/ interrupt stack in RAM. The SP must be initialized with software (usually to RAM address 06F Hex with 128 bytes of on-chip RAM selected, or to RAM address 02F Hex with 64 bytes of on-chip RAM selected). The SP is used with the subroutine call and return instructions, and with the inter- 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 The device contains 4096 bytes of UV erasable or OTP EPROM memory. This memory is mapped in the program memory address space from 0000 to 0FFF Hex. The program memory may contain either instructions or data constants, and is addressed by the 15-bit program counter (PC). The program memory can be indirectly read by the LAID (Load Accumulator Indirect) instruction for table lookup of constant data. All locations in the EPROM program memory will contain OFF Hex (all 1's) after the device is erased. OTP parts are shipped with all locations already erased to OFF Hex. Unused EPROM locations should always be programmed to 00 Hex so that the software trap can be used to halt runaway program operation. The device can be configured to inhibit external reads of the program memory. This is done by programming the security bit in the ECON (EPROM configuration) register to zero. See the ECON REGISTER section for more details. #### **DATA MEMORY** The data memory address space includes on-chip RAM, I/O, and registers. Data memory is addressed directly by instructions, or indirectly by means of the B, X, or SP point- ers. The device can be configured to have either 64 or 128 bytes of RAM, depending on the value of the "RAM SIZE" bit in the ECON (EPROM CONFIGURATION) register. The sixteen bytes of RAM located at data memory address 0F0–0FF are designated as "registers". These sixteen registers can be decremented and tested with the DRSZ (Decrement Register and Skip if Zero) instruction. The three pointers X, B, and SP are memory mapped into this register address space at addresses 0FC, 0FE, and 0FD respectively. The remaining registers are available for general usage. Any bit of data memory can be directly set, reset or tested. All of the I/O registers and control registers (except A and PC) are memory mapped. Consequently, any of the I/O bits or control register bits can be directly and individually set, reset, or tested. Note: RAM contents are undefined upon power-up. #### **ECON (EPROM CONFIGURATION) REGISTER** The ECON register is used to configure the user selectable clock, security, and RAM size options. The register can be programmed and read only in EPROM programming mode. Therefore, the register should be programmed at the same time as the program memory locations 0000 through 0FFF Hex. UV erasable parts are shipped with 0FF Hex in this register while the OTP parts are shipped with 07F Hex in this register. Erasing the EPROM program memory also erases the ECON register. The device has a security feature which, when enabled, prevents reading of the EPROM program memory. The security bit in the ECON register determines whether security is enabled or disabled. If the security option is enabled, then any attempt to externally read the contents of the EPROM will result in the value E0 Hex being read from all program memory locations. If the security option is disabled, the contents of the internal EPROM may be read. The ECON register is readable regardless of the state of the security bit. The format of the ECON register is as follows: #### **TABLE I** | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------|-------|----------|-------|-------|-------|----------|-------| | Х | Х | SECURITY | CKI 2 | CKI 1 | Х | RAM SIZE | Х | Bit 7 = X Don't care. Bit 6 = X Don't care. Bit 5 = 1 Security disabled. EPROM read and write are allowed. = 0 Security enabled. EPROM read and write are not allowed. #### Bits 4,3 = 1,1 External CKI option selected. = 0,1 Not allowed. = 1,0 RC oscillator option selected. = 0,0 Crystal oscillator option selected. Bit 2 = X Don't care. Bit 1 = 1 Selects 128 byte RAM option. This emulates COP840 and COP880. = 0 Selects 64 byte RAM option. This emulates COP820. Bit 0 = X Don't care. #### 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, G and C 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 and C are cleared. The external RC network shown in Figure 4 should be used 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/11299-7 RC ≥ 5X Power Supply Rise Time #### **FIGURE 4. Recommended Reset Circuit** #### **OSCILLATOR CIRCUITS** Figure 5 shows the three clock oscillator configurations available for the device. The CKI 1 and CKI 2 bits in the ECON register are used to select the clock option. See the ECON REGISTER section for more details. FIGURE 5. Crystal, External and R-C Connection Diagrams #### A. Crystal Oscillator The device can be driven by a crystal clock. The crystal network is connected between the pins CKI and CKO. Table II shows the component values required for various standard crystal frequencies. #### **B. External Oscillator** CKI can be driven by an external clock signal provided it meets the specified duty cycle, rise and fall times, and input levels. In External oscillator mode, G7 is available as a general purpose input and/or HALT restart control. TABLE II. Crystal Oscillator Configuration, $T_A = 25^{\circ}C$ | | •• | 1505 111 01 75101 01 | | <del></del> | | |------------|------------|----------------------|----------------|-------------------|-----------------------------| | R1<br>(kΩ) | R2<br>(MΩ) | C1<br>(pF) | C2<br>(pF) | CKI Freq<br>(MHz) | Conditions | | 0 | 1 | 30<br>30 | 30-36<br>30-36 | 10<br>4 | $V_{CC} = 5V$ $V_{CC} = 5V$ | TABLE III. RC Oscillator Configuration, T<sub>A</sub> = 25°C | R<br>(kΩ) | C<br>(pF) | CKI Freq.<br>(MHz) | Instr. Cycle<br>(μs) | Conditions | | |-----------|-----------|--------------------|----------------------|---------------|--| | 3.3 | 82 | 2.2 to 2.7 | 3.7 to 4.6 | $V_{CC} = 5V$ | | | 5.6 | 100 | 1.1 to 1.3 | 7.4 to 9.0 | $V_{CC} = 5V$ | | | 6.8 | 100 | 0.9 to 1.1 | 8.8 to 10.8 | $V_{CC} = 5V$ | | Note: (R/C Oscillator Configuration): $3k \le R \le 200k$ , $50 \text{ pF} \le C \le 200 \text{ pF}$ . #### C. R/C Oscillator CKI can be configured as a single pin RC controlled oscillator. In RC oscillator mode, G7 is available as a general purpose input and/or HALT restart control. Table III shows the variation in the oscillator frequencies as functions of the component (R and C) values. #### **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. (Stopping the clock input will draw more current than setting the G7 data bit.) 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 G7 pin. A low on the RESET line reinitializes the microcontroller and starts execution from address 0000H. In external and RC oscillator modes, a low to high transition on the G7 pin also causes the microcontroller to come out of the HALT mode. Execution resumes at the address following the HALT instruction. Except for the G7 data bit, which gets reset, all RAM locations retain the values they had prior to execution of the "HALT" instruction. It is required that the first instruction following the "HALT" instruction be a "NOP" in order to synchronize the clock. #### INTERRUPTS The device has a sophisticated interrupt structure to allow easy interface to the real world. There are three possible 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 interrupts 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 an 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 inter- 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. Note: There is always the possiblity of an interrupt occurring during an instruction which is attempting to reset the GIE bit or any other interrupt enable bit. If this occurs when a single cycle instruction is being used to reset the interrupt enable bit, the interrupt enable bit will be reset but an interrupt may still occur. This is because interrupt processing is started at the same time as the interrupt bit is being reset. To avoid this scenario, the user should always use a two, three, or four cycle instruction to reset interrupt enable bits. FIGURE 6. Interrupt Block Diagram TL/DD/11299-9 #### **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 EP-ROM area and unbalanced stack situations. Reading an undefined EPROM location returns 00 (hexadecimal) as its contents. The opcode for a software interrupt is also "00". Thus a program accessing undefined EPROM will cause a software interrupt. Reading an undefined RAM location returns an FF (hexadecimal). The subroutine stack on the device grows down for each subroutine call. By initializing the stack pointer to the top of RAM, 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 EPROM location and will trigger a software interrupt. #### MICROWIRE/PLUS 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. FIGURE 7. MICROWIRE/PLUS Block Diagram 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. 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, SLO and SL1, in the CNTRL register. Table IV details the different clock rates that may be selected. **TABLE IV** | 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 time. #### 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 device 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 by the device. The MICROWIRE/PLUS Master always initiates all data exchanges (Figure 8). The MSEL bit in the CNTRL register must be set to enable the SO and SK functions on 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 V 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 FIGURE 8. MICROWIRE/PLUS Application bit in the CNTRL register enables the SO and SK functions on the G Port. The SK pin must be selected as an input and the SO pin selected as an output pin by appropriately setting up the Port G configuration register. Table V 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 (Figure 8). **TABLE V** | 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 it 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 VI details various timer operating modes and their requisite control settings. #### **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 allows the generation of square-wave outputs or pulse width modulated outputs under software control (Figure 9). TL/DD/11299-11 #### **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 (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 TIO 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 (Figure 10). **TABLE VI. 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 | t <sub>c</sub> | | | 101 | Timer w/Auto-Load Reg./Toggle TIO Out | Timer Underflow | t <sub>c</sub> | | | 110 | Timer w/Capture Register | TIO Pos. Edge | t <sub>c</sub> | | | 111 | Timer w/Capture Register | TIO Neg. Edge | t <sub>c</sub> | | Bit 0 ## Functional Description (Continued) FIGURE 9. Timer/Counter Auto Reload Mode Block Diagram FIGURE 10. Timer Capture Mode Block Diagram #### 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. TL/DD/11299-14 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) Enable MICROWIRE/PLUS functions SO and SK MSEL TRUN Start/Stop the Timer/Counter (1 = run, 0 = stop) 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 | S1 | S0 | |-------|-----|-----|------|------|------|----|-------| | Bit 7 | | | | | - | | Rit 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 External interrupt pending IPND ENTI Timer interrupt enable Timer interrupt pending TPND С Carry Flag HC Half carry Flag | HC C | TPND | ENTI | IPND | BUSY | FNI | GIF | |-------|----------|------|------|------|-----|------| | Bit 7 | <u> </u> | | | | | Diag | ## **Addressing Modes** #### REGISTER INDIRECT This is the "normal" mode of addressing for the device. The operand is the memory location addressed by the B register or X register. #### DIRECT The instruction contains an 8-bit address field that directly points to the data memory location 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 -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. ## **Memory Map** All RAM, ports and registers (except A and PC) are mapped into data memory address space. | RAM Select | Address | Contents | |------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 64 On-Chip RAM Bytes<br>Selected by ECON reg. | 00-2F<br>30-7F | 48 On-Chip RAM Bytes<br>Unused RAM Address Space (Reads as all 1's) | | 128 On-Chip RAM Bytes<br>Selected by ECON reg. | 00-6F<br>70-7F | 112 On-chip RAM Bytes<br>Unused RAM Address Space (Reads as all 1's) | | | 80 to BF | Expansion Space for On-Chip EERAM | | | 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 | 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) | | | D8<br>D9<br>DA<br>DB<br>DC<br>DD-DF | Port C Data Register Port C Configuration Register Port C Input Pins (Read Only) Reserved for Port C Port D Data Register Reserved for Port D | | | E0 to EF E0-E7 E8 E9 EA EB EC ED EE | On-Chip Functions and Registers Reserved for Future Parts 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 Register<br>B Register | Reading unused memory locations below 7FH will return all ones. Reading other unused memory locations will return undefined data. http://www.national.com Downloaded from Elcodis.com electronic components distributor #### **Instruction Set** | REGISTER AND SYMBOL DEFINITION | | | | | | | | | | | | | | | | | | |--------------------------------|---|-----|---|----|----|----|---|-----|----|----|----|-----|----|-----|----|----|--| | | c | ITI | M | EI | DE | n. | ю | V L | œ. | חו | Aλ | : О | TE | IG. | C) | 15 | | #### Registers - A 8-bit Accumulator register B 8-bit Address register X 8-bit Address register - SP 8-bit Stack pointer register PC 15-bit Program counter register - 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 [B] Memory indirectly addressed by B register[X] Memory indirectly addressed by X register Mem Direct address memory or [B] 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 #### Instruction Set | ADD | add | A ← A + Meml | |---------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADC | add with carry | A ← A + Meml + C, C ← Carry | | | add will ourly | | | SUBC | avilada ad videla a una | HC ← Half Carry | | SUBC | subtract with carry | A ← A + Memi + C, C ← Carry | | | | HC ← Half Carry | | AND | Logical AND | A ← A and Meml | | OR | Logical OR | A ← A or Memi | | 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. | | 00,, | Octon | | | BOIT | | Mem (bit = 0 to 7 immediate) | | RBIT | Reset bit | O to bit, | | | | Mem | | IFBIT | If bit | If bit. | | | 1 | Mem is true, do next instr. | | | | Weith's tide, do next instr. | | Χ | Exchange A with memory | $A \longleftrightarrow Mem$ | | LD A | Load A with memory | A ← Memi | | LD mem | Load Direct memory Immed. | Mem ← Imm | | LD Reg | Load Register memory Immed. | | | | Load register themory infined. | Reg ← Imm | | Χ | Exchange A with memory [B] | $A \longleftrightarrow [B] (B \leftarrow B \pm 1)$ | | Х | Exchange A with memory [X] | $A \longleftrightarrow [X] (X \leftarrow X \pm 1)$ | | LD A | Load A with memory [B] | $A \leftarrow [B] (B \leftarrow B \pm 1)$ | | LDA | | | | | Load A with memory [X] | $A \leftarrow [X] (X \leftarrow X \pm 1)$ | | LD M | Load Memory Immediate | $[B] \leftarrow Imm (B \leftarrow B \pm 1)$ | | CLRA | Clear A | A ← 0 | | INCA | Increment A | $A \leftarrow A + 1$ | | DECA | | \ \tag{\tau} \tau \tau \\ \ta | | | Decrement A | $A \leftarrow A - 1$ | | LAID | Load A indirect from ROM | A ← ROM(PU,A) | | DCORA | DECIMAL CORRECT A | A ← BCD correction (follows ADC, SUBC) | | RRCA | ROTATE A RIGHT THRUC | $C \rightarrow A7 \rightarrow \rightarrow A0 \rightarrow C$ | | SWAPA | Swap nibbles of A | A7A4 ←→ A3A0 | | SC | Set C | | | • | 1 | C ← 1, HC ← 1 | | RC | Reset C | $C \leftarrow 0, HC \leftarrow 0$ | | IFC | lf C | If C is true, do next instruction | | IFNC | If not C | If C is not true, do next instruction | | JMPL | luma abastuta laura | The state of s | | | 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 (r is -31 to +32, not 1)$ | | JSRL | Jump subroutine long | $[SP] \leftarrow PL,[SP-1] \leftarrow PU,SP-2,PC \leftarrow ii$ | | JSR | Jump subroutine | $[SP] \leftarrow PL,[SP-1] \leftarrow PU,SP-2,PC110 \leftarrow i$ | | JID | | [01] T FL,[0F-1] T FU,3F-2,FU11U T | | | Jump indirect | PL ← ROM(PU,A) | | RET | Return from subroutine | $SP+2,PL \leftarrow [SP],PU \leftarrow [SP-1]$ | | | Detume and Claim | SP+2,PL ← [SP],PU ← [SP-1],Skip next instruction | | RETSK | Return and Skip | | | | , · | | | RETSK<br>RETI | Return from Interrupt | $SP+2,PL \leftarrow [SP],PU \leftarrow [SP-1],GIE \leftarrow 1$ | | RETSK | , · | | | • | OPC | ODE LI | ST | | | Т | | | Bits 3 | 1 | <del></del> 1 | | 1 | | | | | | |----------|-----|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|--------------------------------------------| | | | 0 | <u>-</u> | 2 | ъ | 4 | 2 | ဖ | | Φ | 6 | <b>⋖</b> | <u>m</u> | <u> </u> | | ш | Т | | | | 0 | INTR | JP + 2 | JP + 3 | JP + 4 | JP + 5 | 다<br>-<br>-<br>- | 7 + 4L | JP + 8 | 9 + 9 | JP + 10 | JP + 11 | JP + 12 | JP +13 | JP + 14 | JP + 15 | JP + 16 | | | | - | JP + 17 | JP + 18 | JP + 19 | JP + 20 | JP + 21 | JP + 22 | JP + 23 | JP + 24 | JP + 25 | JP + 26 | JP + 27 | JP + 28 | JP + 29 | JP + 30 | JP + 31 | JP + 32 | | | | 2 | JMP<br>0000-00FF | JMP<br>0100-01FF | JMP<br>0200-02FF | JMP<br>0300-03FF | JMP<br>0400-04FF | JMP<br>0500-05FF | JMP<br>0600-06FF | JMP<br>0700-07FF | JMP<br>0800-08FF | JMP<br>0900-09FF | JMP<br>0A00-0AFF | JMP<br>0B00-0BFF | JMP<br>0C00-0CFF | JMP<br>0D00-0DFF | JMP<br>0E00-0EFF | JMP<br>0F00-0FFF | | | | 3 | JSR<br>0000-00FF | JSR<br>0100-01FF | JSR<br>0200-02FF | JSR<br>0300-03FF | JSR<br>0400-04FF | JSR<br>0500-05FF | JSR<br>0600-06FF | JSR<br>0700-07FF | JSR<br>0800-08FF | JSR<br>0900-09FF | JSR<br>0A00-0AFF | JSR<br>0B00-0BFF | JSR<br>0C00-0CFF | JSR<br>0D00-0DFF | JSR<br>0E00-0EFF | JSR<br>0F00-0FFF | | | | 4 | IFBNE 0 | IFBNE 1 | IFBNE 2 | IFBNE 3 | IFBNE 4 | FBNE 5 | IFBNE 6 | IFBNE 7 | IFBNE 8 | IFBNE 9 | IFBNE 0A | IFBNE 0B | IFBNE 0C | IFBNE 0D | IFBNE 0E | IFBNE 0F | g table) | | | 5 | LD B, 0F | LD B, 0E | LD B, 0D | 20 PD D | 80 '8 OT | LD B, 0A | 6'BQT | 8'B Q7 | LD B, 7 | LDB,6 | LD B, 5 | LD B, 4 | E B 3 | LD B, 2 | LD B, 1 | LD B, 0 | is an unused opcode (see following table) | | 7-4 | 9 | * | * | * | * | CLRA | SWAPA | DCORA | * | RBIT<br>0,[B] | RBIT<br>1,[B] | RBIT<br>2,[B] | RBIT<br>3,[B] | RBIT<br>4,[B] | RBIT<br>5,[B] | RBIT<br>6, [B] | RBIT<br>7,[B] | poodo pesnu | | Bits 7-4 | 7 | 1FBIT<br>0,[B] | 1,[B] | FBIT<br> 2,[B] | IFBIT<br>3,[B] | IFBIT<br>4,[B] | FBIT<br>5,[8] | IFBIT<br>6,[B] | 1FBIT<br>7,[B] | SBIT<br>0,[B] | SBIT<br>1,[B] | SBIT<br>2,[B] | SBIT<br>3,[B] | SBIT<br>4,[B] | SBIT<br>5,[B] | SBIT<br>6, [B] | SBIT<br>7,[B] | is an u | | | 8 | ADC A,<br>[B] | SUBC<br>A,[B] | IFEQ<br>A,[B] | IFGT<br>A,[B] | ADD<br>A,[B] | AND<br>A,[B] | XOR<br>A,[B] | OR<br>A,[B] | FC | IFINC | NCA | DECA | * | RETSK | RET | RETI | fion | | | 6 | ADC A,<br>#i | SUBC A, | IFEQ A, | IFGT A,<br>#i | ADD A,<br>#i | AND A, | XOR A,<br>#i | OR A,<br>#i | LD A,<br>#i | * | LD<br>[B+],#i | LD<br>[B-],#i | X A,Md | LD A, | LD<br>[B], #i | * | Md is a directly addressed memory location | | | 4 | RC | SC | X A,<br>[B+] | Х А,<br>[В - ] | LAID | 음 | X<br>B | * | * | * | LD A,<br>[B+] | LD A,<br>[B-] | JMPL | JSRL | LD A, | * | addresser | | | 80 | RRCA | * | X A,<br>[X+] | X A,<br>[X-] | * | * | ××Ξ | * | NOP | * | LD A, | LD A,<br>[X-] | LD Md, | BIO | Z Å | * | is a directly | | | ပ | DRSZ 0F0 | DRSZ 0F1 | DRSZ 0F2 | DRSZ 0F3 | DRSZ 0F4 | DRSZ 0F5 | DRSZ 0F6 | DRSZ 0F7 | DRSZ 0F8 | DRSZ 0F9 | DRSZ 0FA | DRSZ 0FB | DRSZ 0FC | DRSZ 0FD | DRSZ 0FE | DRSZ 0FF | | | | ۵ | LD 0F0,#i | LD 0F1, #i | LD 0F2,#i | LD 0F3,#i | LD 0F4, #i | LD 0F5,#i | LD 0F6,#i | LD 0F7,#i | LD 0F8, # i | LD 0F9,#i | LD 0FA, #i | LD 0FB, #i | LD 0FC, #i | LD 0FD, #i | LD 0FE, #i | LD 0FF, #1 | is the immediate data | | | ш | JP -31 | JP -30 | JP -29 | JP -28 | JP -27 | JP -26 | JP -25 | JP -24 | JP -23 | JP -22 | JP -21 | JP -20 | JP -19 | JP -18 | JP -17 | JP -16 | - | | | L. | JP -15 | JP -14 | JP-13 | JP -12 | JP-11 | JP -10 | 6- AC | 9- AC | 7- AC | JP -6 | JP -5 | JP -4 | JP -3 | JP -2 | 1- JD | 0- AL | where, | http://www.national.com 2-70 #### **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. Skipped instructions require x number of cycles to be skipped, where x equals the number of bytes in the skipped instruction opcode. 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 Instructions (Bytes/Cycles) | | [B] | Direct | lmmed. | |-------|-----|--------|--------| | 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 | | | | DRSZ | | 1/3 | | | SBIT | 1/1 | 3/4 | | | RBIT | 1/1 | 3/4 | | | IFBIT | 1/1 | 3/4 | | #### Memory Transfer Instructions (Bytes/Cycles) | | 1 | ister<br>rect<br>[X] | 1 | 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 | | LD B,lmm | | | | 1/1 | | | | LD B,Imm | | i | | 2/3 | | | | LD Mem,Imm | | | 3/3 | | 2/2 | | | LD Reg,Imm | | | : | 2/3 | | | <sup>(</sup>If B < 16) (If B > 15) #### Instructions Using A & C | Instructions | Bytes/Cycles | |--------------|--------------| | CLRA | 1/1 | | INCA | 1/1 | | DECA | 1/1 | | LAID | 1/3 | | DCORA | 1/1 | | RRCA | 1/1 | | SWAPA | 1/1 | | SC | 1/1 | | RC | 1/1 | | IFC | 1/1 | | IFNC | 1/1 | #### **Transfer of Control Instructions** | Instructions | Bytes/Cycles | |--------------|--------------| | JMPL | 3/4 | | JMP | 2/3 | | JP | 1/3 | | JSRL | 3/5 | | JSR | 2/5 | | JID | 1/3 | | RET | 1/5 | | RETSK | 1/5 | | RETI | 1/5 | | INTR | 1/7 | | NOP | 1/1 | <sup>\* = &</sup>gt; Memory location addressed by B or X or directly. ## 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 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 | | | ## **Development Support** #### SUMMARY - iceMASTERTM: IM-COP8/400—Full feature in-circuit emulation for all COP8 products. A full set of COP8 Basic and Feature Family device and package specific probes are available. - COP8 Debug Module: Moderate cost in-circuit emulation and development programming unit. - COP8 Evaluation and Programming Unit: EPU-COP880C—low cost In-circuit simulation and development programming unit. - Assembler: COP8-DEV-IBMA. A DOS installable crossdevelopment Assembler, Linker, Librarian and Utility Software Development Tool Kit. - C Compiler: COP8C. A DOS installable cross development Software Tool Kit. - OTP/EPROM Programmer Support: Covering needs from engineering prototype, pilot production to full production environments. ## ICEMASTER (IM) IN-CIRCUIT EMULATION The iceMASTER IM-COP8/400 is a full feature, PC-based in-circuit emulation tool developed and marketed by Meta-Link Corporation to support the whole COP8 family of products. National is a resale vendor for these products. See Figure 12 for configuration. The iceMASTER IM-COP8/400 with its device specific COP8 Probe provides a rich feature set for developing, testing and maintaining product: - Real-time in-circuit emulation; full 2.4-5.5VDC operation range, full DC-10 MHz clock. Chip options are programmable or jumper selectable. - Direct connection to application board by package compatible socket or surface mount assembly. - Full 32 kbyte of loadable programming space that overlays (replaces) the on-chip ROM or EPROM. On-chip RAM and I/O blocks are used directly or recreated on the probe as necessary. - Full 4k frame synchronous trace memory. Address, instruction, and 8 unspecified, circuit connectable trace lines. Display can be HLL source (e.g., C source), assembly or mixed. - A full 64k hardware configurable break, trace on, trace off control, and pass count increment events. - Tool set integrated interactive symbolic debugger—supports both assembler (COFF) and C Compiler (.COD) linked object formats. - Real time performance profiling analysis; selectable bucket definition. - Watch windows, content updated automatically at each execution break. - Instruction by instruction memory/register changes displayed on source window when in single step operation. - Single base unit and debugger software reconfigurable to support the entire COP8 family; only the probe personality needs to change. Debugger software is processor customized, and reconfigured from a master model file. - Processor specific symbolic display of registers and bit level assignments, configured from master model file. - Halt/Idle mode notification. - On-line HELP customized to specific processor using master model file. - Includes a copy of COP8-DEV-IBMA assembler and linker SDK. #### **IM Order Information** | Base Unit: | | |--------------------|----------------------------------------| | IM-COP8/400-1 | iceMASTER base unit, 110V power supply | | IM-COP8/400-2 | iceMASTER base unit, 220V power supply | | iceMASTER Probe | | | MHW-880C20DWPC | 20 DIP | | MHW-880C28DWPC | 28 DIP | | MHW-880C40DWPC | 40 DIP | | MHW-880C44PWPC | 44 PLCC | | DIP to SO Adapters | | | MHW-SOIC20 | 20 SO | | MHW-SOIC28 | 28 SO | FIGURE 12. COP iceMASTER Environment #### ICEMASTER DEBUG MODULE (DM) The iceMASTER Debug Module is a PC based, combination in-circuit emulation tool and COP8 based OTP/EPROM programming tool developed and marketed by MetaLink Corporation to support the whole COP8 family of products. National is a resale vendor for these products. See Figure 13 for configuration. The iceMASTER Debug Module is a moderate cost development tool. It has the capability of in-circuit emulation for a specific COP8 microcontroller and in addition serves as a programming tool for COP8 OTP and EPROM product families. Summary of features is as follows: - Real-time in-circuit emulation; full operating voltage range operation, full DC-10 MHz clock. - All processor I/O pins can be cabled to an application development board with package compatible cable to socket and surface mount assembly. - Full 32 kbyte of loadable programming space that overlays (replaces) the on-chip ROM or EPROM. On-chip RAM and I/O blocks are used directly or recreated as necessary. - 100 frames of synchronous trace memory. The display can be HLL source (C source), assembly or mixed. The most recent history prior to a break is available in the trace memory. - · Configured break points; uses INTR instruction which is modestly intrusive. - Software—only supported features are selectable. - · Tool set integrated interactive symbolic debugger-supports both assembler (COFF) and C Compiler (.COD) SDK linked object formats. - Instruction by instruction memory/register changes displayed when in single step operation. - · Debugger software is processor customized, and reconfigured from a master model file. - · Processor specific symbolic display of registers and bit level assignments, configured from master model file. - · Halt/Idle mode notification. - · Programming menu supports full product line of programmable OTP and EPROM COP8 products. Program data is taken directly from the overlay RAM. - Programming of 44 PLCC and 68 PLCC parts requires external programming adapters. - Includes wall mount power supply. - On-board VPP generator from 5V input or connection to external supply supported. Requires VPP level adjustment per the family programming specification (correct level is provided on an on-screen pop-down display). - On-line HELP customized to specific processor using master model file. - Includes a copy of COP8-DEV-IBMA assembler and linker SDK. #### **DM Order Information** | Debug Module Unit | | | | | | |--------------------|---------|--|--|--|--| | COP8-DM/880C | | | | | | | Cable Adapters | | | | | | | DM-COP8/20D | 20 DIP | | | | | | DM-COP8/28D | 28 DIP | | | | | | DM-COP8/40D | 40 DIP | | | | | | DM-COP8/44P | 44 PLCC | | | | | | DIP to SO Adapters | | | | | | | COP8-DM/20D-SO | 20 SO | | | | | | COP8-DM/28D-SO | 28 SO | | | | | FIGURE 13, COP8-DM Environment #### ICEMASTER EVALUATION PROGRAMMING UNIT (EPU) The iceMASTER EPU-COP880C is a PC based, in-circuit simulation tool to support the feature family COP8 products. See *Figure 14* for configuration. The simulation capability is a very low cost means of evaluating the general COP8 architecture. In addition, the EPU has programming capability, with added adapters, for programming the whole COP8 product family of OTP and EPROM products. The product includes the following features: - Non-real-time in-circuit simulation. Program overlay memory is PC resident; instructions are downloaded over RS-232 as executed. Approximate performance is 20 kHz. - Includes a 40 pin DIP cable adapter. Other target packages are not supported. All processor I/O pins are cabled to the application development environment. - Full 32 kbytes of loadable programming space that overlays (replaces) the on-chip ROM or EPROM. On-chip RAM and I/O blocks are used directly or recreated as necessary. - On-chip timer and WATCHDOG™ execution are not well synchronized to the instruction simulation. - 100 frames of synchronous trace memory. The display can be HLL source (e.g., C source), assembly or mixed. The most recent history prior to a break is available in the trace memory. - Up to 8 software configured break points; uses INTR instruction which is modestly intrusive. - Common look-feel debugger software across all Meta-Link products—only supported features are selectable. - Tool set integrated interactive symbolic debugger—supports both assembler (COFF) and C Compiler (.COD) SDK linked object formats. - Instruction by instruction memory/register changes displayed when in single step operation. - Processor specific symbolic display of registers and bit level assignments, configured from master model file. - Halt/Idle mode notification. Restart requires special handling. - Programming menu supports full product line of programmable OTP and EPROM COP8 products. Only a 40 ZIF socket is available on the EPU unit. Adapters are available for other part package configurations. - Integral wall mount power supply provides 5V and develops the required V<sub>PP</sub> to program parts. - Includes a copy of COP8-DEV-IBMA assembler, linker SDK. #### **EPU Order Information** | Evaluation Programm | ning Unit | | | | |---------------------|---------------------------------------------------------------------------------------------------------|--|--|--| | EPU-COP880C | Evaluation Programming Unit with debugger and programmer control software and 40 ZIF programming socket | | | | | General Programming | g Adapters | | | | | COP8-PGMA-DS | 28 and 20 DIP and SOIC adapter | | | | | COP8-PGMA-DS44P | 28 and 20 DIP and SOIC plus<br>44 PLCC adapter | | | | FIGURE 14. EPU-COP8 Tool Environment #### COP8 ASSEMBLER/LINKER SOFTWARE **DEVELOPMENT TOOL KIT** National Semiconductor offers a relocateable COP8 macro cross assembler, linker, librarian and utility software development tool kit. Features are summarized as follows: - · Basic and Feature Family instruction set by "device" - · Nested macro capability. - Extensive set of assembler directives. - · Supported on PC/DOS platform. - · Generates National standard COFF output files. - · Integrated Linker and Librarian. - · Integrated utilities to generate ROM code file outputs. - DUMPCOFF utility. This product is integrated as a part of MetaLink tools as a development kit, fully supported by the MetaLink debugger. It may be ordered separately or it is bundled with the Meta-Link products at no additional cost. #### **Order Information** | Assembler SDK: | | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | COP8-DEV-IBMA | Assembler SDK on installable 3.5" PC/DOS Floppy Disk Drive format. Periodic upgrades and most recent version is available on National's BBS and Internet. | #### **COP8 C COMPILER** A C Compiler is developed and marketed by Byte Craft Limited. The COP8C compiler is a fully integrated development tool specifically designed to support the compact embedded configuration of the COP8 family of products. Features are summarized as follows: - · ANSI C with some restrictions and extensions that optimize development for the COP8 embedded application. - BITS data type extension. Register declaration #pragma with direct bit level definitions. - · C language support for interrupt routines. - · Expert system, rule based code geration and optimiza- - Performs consistency checks against the architectural definitions of the target COP8 device. - Generates program memory code. - Supports linking of compiled object or COP8 assembled object formats. - · Global optimization of linked code. - Symbolic debug load format fully source level supported by the MetaLink debugger. #### **CROSS REFERENCE TABLE** The following cross reference table lists the COP800 devices which can be emulated with the COP87XXC single-chip, form fit and function emulators. #### Single-Chip Emulator Selection Table | Device<br>Number | Package | Description | Emulates | |------------------|---------|-----------------------------------|---------------------------------| | COP8780CV | 44 PLCC | One Time<br>Programmable<br>(OTP) | COP880C | | COP8780CEL | 44 LDCC | UV Erasable | COP880C | | COP8780CN | 40 DIP | ОТР | COP880C | | COP8780CJ | 40 DIP | UV Erasable | COP880C | | COP8781CN | 28 DIP | ОТР | COP881C,<br>COP840C,<br>COP820C | | COP8781CJ | 28 DIP | UV Erasable | COP881C,<br>COP840C,<br>COP820C | | COP8781CWM | 28 SO | ОТР | COP881C,<br>COP840C,<br>COP820C | | COP8782CN | 20 DIP | ОТР | COP842C,<br>COP822C | | COP8782CJ | 20 DIP | UV Erasable | COP842C,<br>COP822C | | COP8782CWM | 20 SO | ОТР | COP842C,<br>COP822C | #### INDUSTRY WIDE OTP/EPROM PROGRAMMING SUPPORT Programming support, in addition to the MetaLink development tools, is provided by a full range of independent approved vendors to meet the needs from the engineering laboratory to full production. #### **Approved List** | Manufacturer | North<br>America | Europe | Asia | |--------------------|---------------------------------------------------------|-------------------------------------------|-----------------------------------------| | BP<br>Microsystems | (800) 225-2102<br>(713) 688-4600<br>Fax: (713) 688-0920 | + 49-8152-4183<br>+ 49-8856-932616 | + 852-234-16611<br>+ 852-2710-8121 | | Data I/O | (800) 426-1045<br>(206) 881-6444<br>Fax: (206) 882-1043 | +44-0734-440011 | Call<br>North America | | HI-LO | (510) 623-8860 | Call Asia | +886-2-764-0215<br>Fax: +886-2-756-6403 | | ICE<br>Technology | (800) 624-8949<br>(919) 430-7915 | + 44-1226-767404<br>Fax: 0-1226-370-434 | | | MetaLink | (800) 638-2423<br>(602) 926-0797<br>Fax: (602) 693-0681 | + 49-80 9156 96-0<br>Fax: + 49-80 9123 86 | +852-737-1800 | | Systems<br>General | (408) 263-6667 | +41-1-9450300 | +886-2-917-3005<br>Fax: +886-2-911-1283 | | Needhams | (916) 924-8037<br>Fax: (916) 924-8065 | | | #### **AVAILABLE LITERATURE** For more information, please see the COP8 Basic Family User's Manual, Literature Number 620895, COP8 Feature Family User's Manual, Literature Number 620897 and National's Family of 8-bit Microcontrollers COP8 Selection Guide, Literature Number 630009. #### **DIAL-A-HELPER SERVICE** Dial-A-Helper is a service provided by the Microcontroller Applications group. The Dial-A-Helper is an Electronic Information System that may be accessed as a Bulletin Board System (BBS) via data modem, as an FTP site on the Internet via standard FTP client application or as an FTP site on the Internet using a standard Internet browser such as Netscape or Mosaic. The Dial-A-Helper system provides access to an automated information storage and retrieval system. The system capabilities include a MESSAGE SECTION (electronic mail, when accessed as a BBS) for communications to and from the Microcontroller Applications Group and a FILE SEC-TION which consists of several file areas where valuable application software and utilities could be found. #### DIAL-A-HELPER BBS via a Standard Modem Modem: CANADA/U.S.: (800) NSC-MICRO (800) 672-6427 **EUROPE:** (+49) 0-8141-351332 Baud: 14.4k Set-Up: Length: 8-Bit Parity: None Stop Bit: 1 Operation: 24 Hours, 7 Days #### **DIAL-A-HELPER via FTP** ftp nscmicro.nsc.com user: anonymous password: username@yourhost.site.domain #### DIAL-A-HELPER via a WorldWide Web Browser ftp://nscmicro.nsc.com #### National Semiconductor on the WorldWide Web See us on the WorldWide Web at: http://www.national.com ## 6501128 0082782 568 **=** #### **CUSTOMER RESPONSE CENTER** Complete product information and technical support is available from National's customer response centers. | CANADA/U.S.: | Tel: | (800) 272-9959 | | |--------------|----------------|------------------------|--| | | email: | support @tevm2.nsc.com | | | EUROPE: | email: | europe.support@nsc.com | | | | Deutsch Tel: | + 49 (0) 180-530 85 85 | | | | English Tel: | + 49 (0) 180-532 78 32 | | | | Français Tel: | + 49 (0) 180-532 93 58 | | | | Italiano Tel: | + 49 (0) 180-534 16 80 | | | JAPAN: | Tel: | +81-043-299-2309 | | | S.E. ASIA: | Beijing Tel: | (+86) 10-6856-8601 | | | | Shanghai Tel: | (+86) 21-6415-4092 | | | | Hong Kong Tel: | (+852) 2737-1600 | | | | Korea Tel: | (+82) 2-3771-6909 | | | | Malaysia Tel: | (+60-4) 644-9061 | | | | Singapore Tel: | (+65) 255-2226 | | | | Taiwan Tel: | +886-2-521-3288 | | | AUSTRALIA: | Tel: | (+61) 3-9558-9999 | | | INDIA: | Tel: | (+91) 80-559-9467 | | ## **Programming Considerations** In addition to the application program, the ECON register needs to be programmed as well. The following tables provide examples of some ECON register values. For more detailed information refer to the ECON REGISTER section. #### **EPROM Security Disabled** | RAM<br>Memory | External<br>CKI | RC<br>Oscillator | Crystal<br>Oscillator | |---------------|-----------------|------------------|-----------------------| | 64 Bytes | 38 | 30 | 20 | | 128 Bytes | 3A | 32 | 22 | #### **EPROM Security Enabled** | | | <u> </u> | | |---------------|-----------------|------------------|-----------------------| | RAM<br>Memory | External<br>CKI | RC<br>Oscillator | Crystal<br>Oscillator | | 64 Bytes | 18 | 10 | 00 | | 128 Bytes | 1A | 12 | 02 | EPROM programmer manufacturers may not all calculate a "checksum" the same way. Before implementing an inhouse verification by comparing checksums, need to ensure how each programming system utilized calculates a checksum. It is strongly recommended not to include the ECON register in the checksum for not all programmers include this byte in their calculated checksum. #### **ERASING THE COP8780C EPROM** The EPROM program memory is erased by exposing the transparent window on the UV erasable packages to an ultraviolet light source. Erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms (Å). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the 3000Å to 4000Å range. After programming, "truly opaque" labels should be placed over the window of the device to prevent functional failure due to the generation of photo currents, erasure and excessive HALT current. The term "truly opaque" needs additional clarification when used in the context of covering quartz windows on these devices. The typical white colored stickers or labels are normally used for they are easy to write on. These stickers are not opaque but translucent, they do let a certain percentage of UV-light through. The black write-protect labels supplied with 5.25" floppy disks work extremely well. If problems are encountered during programming (fails blank check) or during normal operation (intermittent functional or logical failures), need to determine first if an appropriate opaque label is being used to cover the quartz window at all times. Note that the device will also draw more current than normal (especially in HALT mode) when the window of the device is not covered with an opaque label. The recommended erasure procedure for the device is exposure to short wave ultraviolet light which has a wavelength of 2537Å. The integrated dose (UV intensity $\times$ exposure time) for erasure should be a minimum of 30W-sec/cm<sup>2</sup>. The device should be placed within one inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. The following table shows the minimum erasure time for various light intensities. #### Minimum Erasure Time | Light Intensity<br>(Micro-Watts/cm²) | Erasure Time*<br>(Minutes) | |--------------------------------------|----------------------------| | 15,000 | 36 | | 10,000 | 50 | | 8,500 | 60 | <sup>\*</sup>Does not include light intensity ramp up time. An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance. Lamps lose intensity as they age. When a lamp has aged, the system should be checked to make certain that adequate UV dosages are being applied for full erasure. Common symptoms of insufficient erasure are: - · Inability to be programmed. - Operational malfunctions associated with V<sub>CC</sub>, temperature, or clock frequency. - · Loss of data in program memory. - A change in configuration values in the ECON register.