# μPD78214 Family (μPD78212/213/214/P214) 8-Bit, K-Series Microcontrollers With A/D Converter, Real-Time Output Ports July 1993 ## Description The μPD78212, μPD78213, μPD78214, and μPD78P214 are members of the K-Series® of microcontrollers and are designed for real-time embedded control applications. These 8-bit, single-chip microcontrollers have a minimum instruction time of 333 ns at 12 MHz (500 ns for the μPD78213). They feature 8-bit hardware multiply and divide instructions, four banks of main registers, an advanced interrupt handling facility, a powerful set of memory mapped on-chip peripherals, and the ability to address up to 1M bytes of external data memory. On-board memory includes 384 or 512 bytes of RAM, 8K or 16K bytes of mask ROM, or 16K bytes of UV EPROM or one-time programmable (OTP) ROM. The advanced interrupt handling facility provides two levels of programmable hardware priority control and two separate methods of servicing interrupt requests: vectored and macro service. The macro service facility reduces the overhead involved in servicing peripheral interrupts by transferring data between the memory-mapped special function registers (SFRs) and memory without the use of time consuming interrupt service routines. In addition, the macro service facility can be initialized to automatically alter timer compare register values or to repeatedly output a prespecified pattern at a fixed or variable rate. By using macro service to control the real-time output ports, the $\mu PD78214$ family can easily and accurately drive two independent stepper motors. The combination of the macro service facility, four banks of main registers, extended data memory address space, and powerful on-chip peripherals makes these devices ideal for applications in office automation, communication, HVAC, and industrial control. # **Features** - Complete single-chip microcontroller - --- 8-bit ALU - Program memory (ROM) μPD78213: ROMIess μPD78212: 8K bytes μPD78214/P214: 16K bytes - Data memory (RAM) μPD78212: 384 bytes μPD78213/214/P214: 512 bytes - Powerful instruction set - 8-bit unsigned multiply and divide - 16-bit arithmetic instructions - 1-bit and 8-bit logic instructions - □ Minimum instruction time - 333 ns at 12 MHz (µPD78212/214/P214) - -- 500 ns at 12 MHz (µPD78213) - Memory expansion - 8085 bus-compatible - 64K program address space - 1M data address space - □ Large I/O capacity - Up to 54 I/O port lines on μPD78212/214/P214 - Up to 36 I/O port lines on $\mu$ PD78213 - Software programmable pullup resistors - Memory-mapped on-chip peripherals (special function registers) - □ Timer/counter unit - 16-bit timer 0: Two 16-bit compare registers One 16-bit capture register One external interrupt/capture line - 8-bit timer 1: One 8-bit compare register One 8-bit capture/compare register One external interrupt/capture line -8-bit timer/counter 2: Two 8-bit compare registers One 8-bit capture register One external interrupt/capture line One external event counter line - 8-bit timer 3: One 8-bit compare register - Four 8-bit precision timer-controlled pulse-width modulated (PWM) output lines - □ Two 4-bit (or one 8-bit) real-time output ports - □ Eight-channel 8-bit A/D converter - Programmable priority interrupt controller (two levels) - Two methods of interrupt service - Vectored interrupts - Macro service mode with choice of three different types K-Series is a registered trademark of NEC Electronics, Inc. # μPD78214 Family # Features (cont) - □ Two-channel serial communication interface - Asynchronous serial interface (UART) - Dedicated baud rate generator - Clock-synchronized interface Full-duplex, three-wire mode NEC serial bus interface (SBI) mode - □ Refresh output for pseudostatic RAM - □ STOP and HALT standby functions - □ 5-volt CMOS technology # **Ordering Information** | Part Number | ROM | Package | Package Drawing | |----------------|--------------|-------------------------------|-----------------| | μPD78212CW-xxx | 8K mask ROM | 64-pin plastic shrink DIP | P64C-70-750A, C | | μPD78213CW | ROMless | | | | μPD78214CW-xxx | 16K mask ROM | | | | μPD78P214CW | 16K OTP ROM | | | | μPD78212GC-xxx | 8K mask ROM | 64-pin plastic QFP | P64GC-80-AB8-2 | | μPD78213GC | ROMiess | | | | μPD78214GC-xxx | 16K mask ROM | | | | μPD78P214GC | 16K OTP ROM | | | | μPD78212GJ-xxx | 8K mask ROM | 74-pin plastic QFP | S74GJ-100-5BJ-1 | | μPD78213GJ | ROMless | • | | | μPD78214GJ-xxx | 16K mask ROM | • | | | μPD78P214GJ | 16K OTP ROM | • | | | μPD78213G36 | ROMless | 64-pin plastic QUIP | P64GQ-100-36 | | μPD78214Gxxx36 | 16K mask ROM | • | | | μPD78P214GQ | 16K OTP ROM | • | | | μPD78213L | ROMiess | 68-pin PLCC | P68L-50A1-1 | | μPD78214L-xxx | 16K mask ROM | • | | | μPD78P214L | 16K OTP ROM | | | | μPD78P214DW | 16K UV EPROM | 64-pin shrink cerdip w/window | P64DW-70-750A1 | xxx indicates ROM code suffix # **Pin Configurations** ## 64-Pin Shrink DIP (Plastic or Ceramic ) or 64-Pin Plastic QUIP # Pin Configurations (cont) ### 64-Pin Plastic QFP # Pin Configurations (cont) ### 68-Pin PLCC # Pin Configurations (cont) ### 74-Pin Plastic QFP | Pin Func | ctions; Normal Operating Mode | | | |------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------------------------------------------------------------| | Symbol | First Function | Symbol | Second Function | | P0 <sub>0</sub> - P0 <sub>7</sub> | Port 0; 8-bit tristate output port/real time output port | | <u>. </u> | | P2 <sub>0</sub> | Port 2; 8-bit input port | NMI | External nonmaskable interrupt | | P2 <sub>1</sub><br>P2 <sub>2</sub> | | INTPO<br>INTP1 | Maskable external interrupts | | P2 <sub>3</sub> | | INTP2<br>CI | Maskable external interrupt External clock input to timer/counter 2 | | P2 <sub>4</sub> | | INTP3 | Maskable external interrupt | | P2 <sub>5</sub> | | INTP4 | Maskable external interrupt | | | | ASCK | Asynchronous serial clock input | | P2 <sub>6</sub> | | INTP5 | Maskable external interrupt | | P2 <sub>7</sub> | 4 | SI | Serial data input for three-wire serial I/O mode | | P3 <sub>0</sub> | Port 3; 8-bit, bit-selectable tristate input/output port | RxD | Asyrichronous serial receive data input | | P3 <sub>1</sub> | | TxD | Asynchronous serial transmit data output | | P3 <sub>2</sub> | | SCK | Serial shift clock input/output | | P3 <sub>3</sub> | | so | Serial data output for three-wire serial I/O mod | | · | | SBO | I/O bus for NEC serial bus interface (SBI) | | P3 <sub>4</sub> - P3 <sub>7</sub> | | TO0 - TO3 | Timers T0 to T3 outputs | | P4 <sub>0</sub> - P4 <sub>7</sub> | Port 4; 8-bit tristate input/output port | AD <sub>0</sub> - AD <sub>7</sub> | Low-order 8-bit multiplexed address/data bus | | P5 <sub>0</sub> - P5 <sub>7</sub> | Port 5; 8-bit, bit-selectable tristate input/output port | A <sub>8</sub> - A <sub>15</sub> | High-order 8-bit address bus | | P6 <sub>0</sub> - P6 <sub>3</sub> | Port 6; 4-bit output port | A <sub>16</sub> - A <sub>19</sub> | Extended memory address bus | | P6 <sub>4</sub> | Port 6; 4-bit, bit-selectable tristate input/output port | RD | External memory read strobe output | | P6 <sub>5</sub> | | WR | External memory write strobe output | | P6 <sub>6</sub> | | WAIT | External memory wait signal input | | | | AN6 | Analog voltage input to A/D converter | | P6 <sub>7</sub> | | REFRQ | Refresh pulse output used by external pseudostatic memory | | | | AN7 | Analog voltage input to A/D converter | | P7 <sub>0</sub> - P7 <sub>5</sub> | Port 7; 6-bit input port | ANO - AN5 | Analog voltage inputs to A/D converter | | ASTB | Address strobe output used to latch the low-order 8 address for external memory | | • | | RESET | External system reset input | - | | | EA | Internal ROM or external memory control signal input. Low-level input selects external memory. High-level input selects internal ROM. A low-level input on a µPD78214 places the device in ROMless mode and external memory is accessed. | - | | | X1 | Crystal/ceramic resonator connection or external clock input | | | | X2 | Crystal/ceramic resonator connection or inverse of external clock | - | | | AVREF | A/D converter reference voltage | - | | | AV <sub>SS</sub> | A/D converter ground | - | | | V <sub>DD</sub> | +5 volt power supply input | - | | | V <sub>SS</sub> | Power supply ground | _ | | | NC | No connection | - | | # **Block Diagram** ## **FUNCTIONAL DESCRIPTION** # Central Processing Unit (CPU) The $\mu$ PD78214 family CPU features 8- and 16-bit arithmetic including an 8 x 8-bit unsigned multiply and 16 x 8-bit unsigned divide (producing a 16-bit quotient and an 8-bit remainder). The multiply executes in 3.67 $\mu$ s and the divide in 12.36 $\mu$ s at 12 MHz (4.00 and 12.69 $\mu$ s respectively for $\mu$ PD78213). A CALLT vector table and a CALLF program area decrease the number of bytes in the call instructions for commonly used subroutines. A 1-byte call instruction (CALLT) can access up to 32 subroutines through the addresses contained in the CALLT vector table. A 2-byte call instruction (CALLF) can access any routine beginning at a specific address in the CALLF area. The internal system clock (f<sub>CLK</sub>) is generated by dividing the oscillator frequency by two. Therefore, at the maximum oscillator frequency of 12 MHz, the internal system clock is 6 MHz. The minimum instruction execution time for an instruction fetched from internal ROM is 333 ns (500 ns when fetched from external memory). ### **Memory Space** The µPD78214 family has a 1M byte address space (see figure 1). The first 64K bytes of this address space (00000H-0FFFFH) can be used as both program and data memory. The remaining 960K bytes of this address space (10000H-FFFFFH) can only be used as data memory and is known as expanded memory. ### **External Memory** The µPD78214 family has an 8-bit wide external data bus and a 16-bit wide external address bus (20-bit wide if expanded memory is enabled). The low-order 8 bits of the address bus are multiplexed to provide the 8-bit data bus and are supplied by I/O port 4. The high-order address bits of the 16-bit address bus are taken from port 5. If expanded memory is enabled, the expanded address nibble is provided by P6<sub>0</sub> to P6<sub>3</sub>. Address latch, read, and write strobes are also provided. The memory expansion mode register (MM) is used to enable external memory, to specify up to two additional wait states or the use of the WAIT input pin for the first 64K bytes of memory, and to enable the high-speed internal ROM fetch. Ports 4, 5, and 6 are available as general purpose I/O ports when only internal ROM is used and no external program or data space is required. # **Expanded Data Memory** The MM register is also used to enable the external expanded data memory space, addresses 10000H to FFFFFH. When the expanded data memory is enabled, the entire 1M byte address space is divided into 16 banks of 64K bytes each. The low-order 4-bits of the P6 or the PM6 registers are used as bank selection registers to supply the address information to $A_{16}$ to $A_{19}$ . Data can easily be transferred from one memory bank to another by using the appropriate instructions. Address lines $A_{16}$ to $A_{19}$ are only active when an instruction that uses expanded addressing is being executed. A programmable wait control register (PW) allows the programmer to specify up to two additional wait states or the use of the $\overline{WAIT}$ input pin for expanded data memory space. # On-Chip RAM The $\mu$ PD78213/214/P214 have a total of 512 bytes of on-chip RAM (384 bytes in the $\mu$ PD78212). The upper 256-byte area (FE00H-FEFFH) features high-speed access and is known as "Internal RAM." The remainder (FD00H-FDFFH and FD80H-FDFFH in the $\mu$ PD78212) is accessed at the same speed as external memory and is known as "Peripheral RAM." The general register banks and the macro service control words are stored in Internal RAM. The remainder of Internal RAM and any unused register bank locations are available for general storage. # **On-Chip Program Memory** The $\mu$ PD78212 and $\mu$ PD78214 contain 8K and 16K bytes of internal ROM respectively. The $\mu$ PD78P214 contains 16K bytes of UV EPROM or one-time programmable ROM. Instructions from on-chip program memory can be fetched at high speed or at the same rate as from external memory. The $\mu$ PD78213 does not have on-chip program memory. ### **CPU Control Registers** **Program Counter.** The program counter is a 16-bit binary counter register that holds the address of the next instruction to be executed. During reset, the program counter is loaded with the address stored in locations 0000H and 00001H. **Stack Pointer.** The stack pointer is a 16-bit register that holds the address of the last item pushed onto the stack. It is decremented before new data is pushed onto the stack and incremented after data is popped off the stack. **Program Status Word.** The program status word (PSW) is an 8-bit register that contains flags that are set or reset depending on the results of an instruction. This register can be written to or read from 8 bits at a time. The individual flags can also be manipulated on a bit-by-bit basis. The assignment of PSW bits follows. | 7 | | | | | | | 0 | |-------------------------------------|------|--------------------------------|---------------------------|------------------------------------------------|------------|-------|----| | IE | z | RBS1 | AC | RBS0 | 0 | ISP | CY | | CY<br>ISP<br>RBSO,<br>AC<br>Z<br>IE | RBS1 | Inter<br>Regi<br>Auxil<br>Zero | ster ba<br>iary c<br>flag | riority s<br>ank sele<br>arry flac<br>equest e | ction<br>3 | flags | | # **General Registers** The general-purpose registers (figure 2) consist of four banks of registers located at addresses FEE0H to FEFFH in Internal RAM. Each bank consists of eight 8-bit general registers that can also be used in pairs to function as four 16-bit registers. Two bits in the PSW (RBSO and RBS1) specify which of the register banks is active. The bits are set under program control. Registers have both functional names (like A, X, B, C for 8-bit registers and AX, BC for 16-bit registers) and absolute names (like R1, R0, R3, R2 for 8-bit registers and RP0, RP1, etc. for 16-bit registers). Each instruction determines whether a register is referred to by its functional or absolute name and whether it is 8 or 16 bits. Figure 2. General Registers # Addressing The $\mu$ PD78214 family features 1-byte addressing of both the special function registers and the portion of on-chip RAM from FE20H to FEFFH. The 1-byte sfr addressing accesses the entire SFR area, while the 1-byte saddr addressing access the first 32 bytes of the SFR area and 224 bytes of Internal RAM. The 16-bit SFRs and words of memory in these areas can be addressed by 1-byte saddrp addressing, which is valid for even addresses only. Since many instructions use 1-byte addressing, access to these locations is almost as fast and versatile as access to the general registers. There are seven addressing modes for data in main memory: direct, register, register indirect with autoincrement and decrement, saddr, SFR, based, and indexed. There are also both 8-bit and 16-bit immediate operands. # **Special Function Registers** The input/output ports, timers, capture and compare registers, and mode and control registers for both the peripherals and the CPU are collectively known as special function registers. They are all memory-mapped between FF00H and FFFFH and can be accessed either by main memory addressing or by 1-byte sfr addressing. They are either 8 or 16 bits as required, and many of the 8-bit registers are capable of single-bit access as well. Locations FF00H through FF0FH are known as the external SFR area. Registers in external circuitry interfaced and mapped to these addresses can be addressed with sfr addressing. Table 1 is a list of the special function registers. Table 1. Special Function Registers | | | | | | ss Units | | | |---------------|------------------------------------------------|--------|-----|---|----------|----|-------------------| | Address | Register (SFR) | Symbol | R/W | 1 | 8 | 16 | State After Reset | | OFF00H | Port 0 | P0 | R/W | x | x | | Undefined | | 0FF02H | Port 2 | P2 | R | x | х | | Undefined | | OFF03H | Port 3 | P3 | R/W | × | x | _ | Undefined | | OFF04H | Port 4 | P4 | R/W | x | x | _ | Undefined | | OFF05H | Port 5 | P5 | R/W | x | x | | Undefined | | OFF06H | Port 6 | P6 | R/W | x | x | _ | x0H | | OFF07H | Port 7 | P7 | R | x | х | _ | Undefined | | OFF0AH | Port 0 buffer register (low) | POL | R/W | × | x | _ | Undefined | | OFFOBH | Port 0 buffer register (high) | POH | R/W | x | × | _ | Undefined | | 0FF0CH | Real-time output port control register | RTPC | R/W | х | × | | 00H | | 0FF10H-0FF11H | 16-bit compare register 0 (16-bit timer 0) | CR00 | R/W | | _ | х | Undefined | | 0FF12H-0FF13H | 16-bit compare register (16-bit timer 0) | CR01 | R/W | _ | | х | Undefined | | 0FF14H | 8-bit compare register (8-bit timer 1) | CR10 | R/W | | × | _ | Undefined | | OFF15H | 8-bit compare register (8-bit timer/counter 2) | CR20 | R/W | | × | | Undefined | | OFF16H | 8-bit compare register (8-bit timer/counter 2) | CR21 | R/W | | х | | Undefined | | 0FF17H | 8-bit compare register (8-bit timer 3) | CR30 | R/W | | × | _ | Undefined | | 0FF18H-0FF19H | 16-bit capture register (16-bit timer 0) | CR02 | R | | | х | Undefined | | OFF1AH | 8-bit capture register (8-bit timer/counter 2) | CR22 | R | | × | | Undefined | | 0FF1CH | 8-bit capture/compare register (8-bit timer 1) | CR11 | R/W | | x | | Undefined | | OFF20H | Port 0 mode register | РМ0 | w | | × | | FFH | | 0FF23H | Port 3 mode register | РМ3 | W | | x | | FFH | | 0FF25H | Port 5 mode register | PM5 | w | | × | | FFH | | 0FF26H | Port 6 mode register | РМ6 | R/W | х | × | | FxH | | 0FF30H | Capture/compare control register 0 | CRC0 | W | _ | x | | 10H | | OFF31H | Timer output control register | тос | W | _ | x | _ | 00H | | 0FF32H | Capture/compare control register 1 | CRC1 | W | | x | | 00H | | 0FF34H | Capture/compare control register 2 | CRC2 | W | | × | | 00H | | OFF40H | Pullup resistor option register | PUO | R/W | x | × | _ | 00H | | 0FF43H | Port 3 mode control register | РМСЗ | R/W | х | × | | 00H | | 0FF50H-0FF51H | 16-bit timer register 0 | TMO | R | | | × | 0000Н | | 0FF52H | 8-bit timer register 1 | TM1 | R | _ | × | | 00H | | OFF54H | 8-bit timer register 2 | TM2 | R | _ | × | _ | 00H | | OFF56H | 8-bit timer register 3 | ТМЗ | R | _ | × | | 00H | | 0FF5CH | Prescaler mode register 0 | PRM0 | W | | × | | 00H | | 0FF5DH | Timer control register 0 | TMC0 | R/W | _ | x | _ | 00H | | OFF5EH | Prescaler mode register 1 | PRM1 | W | _ | x | | 00H | | 0FF5FH | Timer control register 1 | TMC1 | R/W | | х | | 00H | | OFF68H | A/D converter mode register | ADM | R/W | × | х | | 00H | | OFF6AH | A/D conversion result register | ADCR | R | | х | _ | Undefined | | OFF80H | Clocked serial interface mode register | CSIM | R/W | х | х | | 00H | | | | | | | | | | Table 1. Special Function Registers (cont) | | | | | Acce | ss Units | (Bits) | | |---------------|------------------------------------------------------|--------|-----|------|----------|--------|-------------------| | Address | Register (SFR) | Symbol | R/W | 1 | 8 | 16 | State After Reset | | 0FF82H | Serial bus interface control register | SBIC | R/W | × | × | _ | 00H | | OFF86H | Serial shift register | SIO | R/W | _ | × | | Undefined | | 0FF88H | Asynchronous serial interface mode register | ASIM | R/W | х | × | _ | 80H | | OFF8AH | Asynchronous serial interface status register | ASIS | R | x | × | | 00H | | DFF8CH | Serial receive buffer: UART | RxB | R | | х | | Undefined | | OFF8EH | Serial transmit shift register: UART | TxS | w | | x | | Undefined | | 0FF90H | Baud rate generator control register | BRGC | w | _ | × | | 00H | | OFFC0H | Standby control register | STBC | R/W | _ | x | _ | 0000x000B | | 0FFC4H | Memory expansion mode register | ММ | R/W | x | × | | 20H | | 0FFC5H | Programmable wait control register | PW | R/W | х | × | _ | 80H | | 0FFC6H | Refresh mode register | RFM | R/W | х | x | _ | 00H | | OFFDOH-OFFDFH | External SFR area | _ | R/W | x | x | _ | Undefined | | OFFEOH | Interrupt request flag register L | IFOL | R/W | х | × | | 00H | | OFFE1H | Interrupt request flag register H | IFOH | R/W | х | × | _ | 00H | | OFFEOH-OFFE1H | interrupt request flag register | IF0 | R/W | _ | _ | х | 0000H | | OFFE4H | Interrupt mask flag register L | MKOL | R/W | х | x | _ | FFH | | OFFE5H | Interrupt mask flag register H | МКОН | R/W | х | × | _ | FFH | | OFFE4H-OFFE5H | Interrupt mask flag register | МКО | R/W | _ | | × | FFFFH | | OFFE8H | Priority specification flag register L | PROL | R/W | × | × | _ | FFH | | OFFE9H | Priority specification flag register H | PROH | R/W | x | × | _ | FFH | | OFFE8H-OFFE9H | Priority specification flag register | PR0 | R/W | _ | _ | х | FFFFH | | 0FFECH | Interrupt service mode specification flag register L | ISMOL | R/W | х | × | | 00H | | OFFEDH | Interrupt service mode specification flag register H | ISMOH | R/W | х | × | _ | 00H | | OFFECH-OFFEDH | Interrupt service mode specification flag register | ISMO | R/W | _ | _ | х | 00H | | OFFF4H | External interrupt mode register 0 | INTMO | R/W | x | х | | 00H | | OFFF5H | External interrupt mode register 1 | INTM1 | R/W | × | х | _ | 00H | | OFFF8H | Interrupt status register | IST | R/W | × | × | | 00H | Figure 3. Pin I/O Circuits # Input/Output Ports There are up to 54 port lines on the $\mu$ PD78212/214/P214 and up to 36 port lines on the $\mu$ PD78213. (Ports 4, 5, and two bits of port 6 are not available on the $\mu$ PD78213 since the $\mu$ PD78213 must always use external memory.) Table 2 lists the features of each port and figure 3 shows the structure of each port pin. The pin levels of all port 2, 3, and 7 pins can always be read or tested regardless of the dual pin function. Table 2. Digital Port Functions | Port | Operational Features | Configuration | Direct Drive<br>Capability | Software Pullup<br>Resistor Connection | |--------|----------------------------------------------------------------|-----------------|----------------------------|----------------------------------------------------| | Port 0 | 8-bit high impedance output | | Transistor | | | Port 2 | 8-bit Schmitt trigger input | : | | In 6-bit unit (P2 <sub>2</sub> - P2 <sub>7</sub> ) | | Port 3 | 8-bit input or output | Bit selectable | | Byte selectable, input bits only | | Port 4 | 8-bit input or output | Byte selectable | LED | Byte selectable | | Port 5 | 8-bit input or output | Byte selectable | LED | Byte selectable, input bits only | | Port 6 | 4-bit output (bits 0 to 3) 4-bit input or output (bits 4 to 7) | Bit selectable | | In 4-bit unit, input bits only | | Port 7 | 6-bit input | | | | Note: Software pullup resistors can be internally connected only on a port-by-port basis to port bits set to input mode. Pullup resistors are not connected to port bits set to output mode. ### Real-time Output Port The real-time output port (RTPC) shares pins with port 0. It can be used as two independent 4-bit real-time output ports or one 8-bit real-time output port. In the real-time output mode, data stored beforehand in the buffer registers, P0H and P0L, is transferred immediately to the output latch of P0 on the occurrence of a timer 1 interrupt (INTC10 or INTC11) or external interrupt (INTP0) (see figure 4). By using the real-time output port with the macro service function, port 0 can be used to output preprogrammed patterns at preprogrammed variable time intervals. In this mode, two independent stepper motors can accurately be driven at a fixed or variable rate. Figure 4. Real-Time Output Port # Analog-to-Digital (A/D) Converter The $\mu$ PD78214 family A/D converter (see figure 5) uses the successive-approximation method for converting up to eight multiplexed analog inputs into 8-bit digital data. The conversion time per input is 30 $\mu$ s at 12 MHz operation. A/D conversion can be started by an external interrupt, INTP5, or under software control. The A/D converter can operate in either scan mode or select mode. In scan mode, from one to eight sequential inputs can be programmed for conversion. The A/D data, stores it in the A/D conversion result (ADCR) register, and generates an interrupt (INTAD). This converted data can be easily transferred to memory by using the macro service function. In select mode, only one of the eight A/D inputs can be selected for conversion. The ADCR register is continually updated and can be read at any time. If the A/D converter is started by an external interrupt, an INTAD interrupt occurs at the completion of each conversion. If the A/D converter is started by software, no interrupts are generated. Figure 5. A/D Converter ### Serial Interface The µPD78214 family has two independent serial interfaces. The first is a standard UART. The UART (figure 6) permits full-duplex operation and can be programmed for 7- or 8-bits of data after the start bit, followed by one or two stop bits. Odd, even, zero or no parity can also be selected. The serial clock for the UART can be provided by an on-chip baud rate generator or timer 3. By using either the internal system clock or an external clock input into the ASCK pin, the baud rate generator is capable of generating all of the commonly used baud rates. The UART generates three interrupts: INTST (transmission complete), INTSR (reception complete), and INTSER (reception error). Figure 6. Asynchronous Serial Interface The second interface is an 8-bit clock-synchronized serial interface (figure 7). It can be operated in either a three-wire serial I/O mode or NEC serial bus interface (SBI) mode. In the three-wire serial I/O mode, the 8-bit shift register (SIO) is loaded with a byte of data and eight clock pulses are generated. These eight pulses shift the byte of data out of the SO line (MSB first) and in from the SI line providing full-duplex operation. This interface can also be set to receive or to transmit data only. The INTCSI interrupt is generated after each 8-bit transfer. One of three internal clocks or an external clock clocks the data. Figure 7. Clock-Synchronized Serial Interface The NEC SBI mode is a two-wire high-speed proprietary serial interface available on most devices in the NEC μPD75xxx and μPD78xxx product lines. Devices are connected in a master/slave configuration (see figure 8). There is only one master device at a time; all others are slaves. The master sends addresses, commands. and data over the serial bus line (SB0) using a fixed hardware protocol synchronized with the SCK line. Each slave $\mu$ PD78214 family device can be programmed in software to respond to any one of 256 addresses. There are also 256 commands and 256 data types. Since all commands are user definable, any software protocol, simple or complex, can be defined. It is even possible to develop commands to change a slave into a master and the previous master into a slave. Figure 8. SBI Mode Master/Slave Configuration ### **Timers** The $\mu$ PD78214 family has one 16-bit timer and three 8-bit timers. The 16-bit timer counts the internal system clock ( $f_{CLK}/8$ ) while the three 8-bit timers can be programmed to count a number of prescaled values of the internal system clock. One of the 8-bit timers can also count external events. Timer 0 consists of a 16-bit timer (TM0), two 16-bit compare registers (CR00 and CR01), and a 16-bit capture register (CR02). Timer 0 can be used as two interval timers, to output a programmable square wave or two pulse-width modulated signals, or to measure pulse widths (see figure 9). Timer 1 consists of an 8-bit timer (TM1), 8-bit compare register (CR10), and 8-bit capture/compare register (CR11). Timer 1 can be used as two interval timers or to measure pulse widths. In addition, it can be used to generate the output trigger for the real-time output port (see figure 10). Timer/counter 2 consists of an 8-bit timer (TM2), two 8-bit compare registers (CR20 and CR21), and an 8-bit capture register (CR22). Timer/counter 2 can also be used as two interval timers, to output a programmable square wave or two pulse-width modulated signals, or to measure pulse widths. In addition, it can be used to count external events sensed on the CI line or as a one-shot timer (see figure 11). Timer 3 consists of an 8-bit timer (TM3) and an 8-bit compare register (CR30). Timer 3 can be used as an interval timer or as a clock for the clock-synchronized serial interface (see figure 12). Figure 9. 16-Bit Timer 0 Figure 10. 8-Bit Timer 1 Figure 11. 8-Bit Timer/Counter 2 Figure 12. 8-Bit Timer 3 ### Interrupts The $\mu$ PD78214 family has 18 maskable hardware interrupt sources; 6 are external and 12 are internal. Since there are only 16 interrupt vectors and sets of control flags, 2 of the 6 external maskable interrupts, INTP4 and INTP5, share interrupt vectors and control flags with INTC30 and INTAD respectively. The active interrupt source for each shared vector must be chosen by the program. In addition, there is one nonmaskable interrupt and one software interrupt. The software interrupt, generated by the BRK instruction, is not maskable (see table 3). Table 3. Interrupt Sources and Vector Addresses | Interrupt<br>Request<br>Type | Default<br>Priority | Interrupt Request Generation Source | Macro Service<br>Type | Vector<br>Table<br>Address | |------------------------------|---------------------|--------------------------------------------------------------------|-----------------------|----------------------------| | Software | None | BRK instruction execution | _ | 003EH | | Nonmaskable | None | NMI (pin input edge detection) | _ | 0002H | | Maskable | 0 | INTPO (pin input edge detection) | A, B | 0006H | | | 1 | INTP1 (pin input edge detection) | A, B | 0008H | | | 2 | INTP2 (pin input edge detection) | A, B | 000AH | | | 3 | INTP3 (pin input edge detection) | В | 000CH | | | 4 | INTC00 (TM0-CR00 coincidence signal generation) | В | 001 4H | | | 5 | INTC01 (TM0-CR01 coincidence signal generation) | В | 0016H | | | 6 | INTC10 (TM1-CR10 coincidence signal generation) | A, B, C | 0018H | | | 7 | INTC11 (TM1-CR11 coincidence signal generation) | A, B, C | 001AH | | | 8 | INTC21 (TM2-CR21 coincidence signal generation) | A, B | 001 CH | | | 9 | INTP4 (pin input edge detection) | В | 000EH | | | | INTC30 (TM3-CR30 coincidence signal generation) | A, B | • | | | 10 | INTP5 (pin input edge detection) | В | 0010H | | | | INTAD (end of A/D conversion) | A, B | • | | | 11 | INTC20 (TM2-CR20 coincidence signal generation) | A, B | 0012H | | | 12 | INTSER (generation of asynchronous serial interface receive error) | _ | 0020H | | | 13 | INTSR (end of asynchronous serial interface reception) | A, B | 0022H | | | 14 | INTST (end of asynchronous serial interface transmission) | A, B | 0024H | | | 15 | INTCSI (end of clocked serial interface transmission) | A, B | 0026H | **Interrupt Servicing.** The $\mu$ PD78214 family provides two levels of programmable hardware priority control and two different methods of handling maskable interrupt requests: standard vectoring and macro service. The programmer can choose the priority and mode of servicing each maskable interrupt by using the interrupt control registers. Interrupt Control Registers. The $\mu$ PD78214 family has four 16-bit interrupt control registers. Each bit in each register is dedicated to one of the 16 active maskable interrupt sources. The interrupt request flag register (IF0) contains an interrupt request flag for each interrupt. The interrupt mask register (MK0) is used to enable or disable any interrupt. The interrupt service mode register (ISM0) specifies whether an interrupt is processed by vectoring or macro service. The priority flag register (PR0) can be used to specify a high or a low priority level for each interrupt. Two other 8-bit registers are associated with interrupt processing. The interrupt status register (IST) indicates if a nonmaskable interrupt request on the NMI pin is being processed and can be used to allow nesting of nonmaskable interrupt requests. The IE and the ISP bits of the program status word are also used to control interrupts. If the IE bit is zero, all maskable interrupts, but not macro service, are disabled. The IE bit can be set or cleared using the EI and DI instructions, respectively, or by directly writing to the PSW. The IE bit is cleared each time an interrupt is accepted. The ISP bit is used by hardware to hold the priority level flag of the interrupt being serviced. Interrupt Priority. The nonmaskable interrupt (NMI) has priority over all other interrupts. Two hardware controlled priority levels are available for the maskable interrupts. Either a high or a low priority level can be assigned by software to each of the maskable interrupts. Interrupt requests of a priority higher than the processor's current priority level are accepted; requests of the same or lower priority are held pending until the processor's priority state is lowered by program control within the current service routine or by a return instruction from the current service routine. Interrupt requests programmed to be handled by macro service have priority over all vectored interrupt service regardless of the assigned priority level, and macro service requests are accepted even when the interrupt enable bit in the PSW is set to the disable state (see figure 13). The default priorities listed in table 3 are fixed by hardware and are effective only when it is necessary to choose between two interrupt requests of the same software-assigned priority. For example, the default priorities would be used after the completion of a high priority routine if two interrupts of the same priority routine were pending. The software interrupt, initiated by the BRK instruction, is executed regardless of the processor's priority level and the state of the IE bit. It does not alter the processor's priority level. Figure 13. Interrupt Service Sequence **Vectored Interrupt.** When vectored interrupt is specified for a given interrupt request, (1) the program status word and the program counter are saved on the stack, (2) the processor's priority is set to that specified for the interrupt, (3) the IE bit in the PSW is set to zero, and (4) the routine whose address is in the interrupt vector table is entered. At the completion of the service routine, the RETI instruction (RETB instruction for the software interrupt) reverses the process and the $\mu$ PD78214 family device resumes the interrupted routine. ### Macro Service When macro service is specified for a given interrupt, the macro service hardware temporarily stops the executing program and begins to transfer data between the special function register area and the memory space. One byte is transferred each interrupt. When the data transfer is complete, control is returned to the executing program, providing a completely transparent method of interrupt service. Macro service significantly improves response time and makes it unnecessary to save any registers. For each request on the interrupt line, one operation is performed, and an 8-bit counter is decremented. When the counter reaches zero, a vectored interrupt service routine is entered according to the specified priority. Macro service is provided for all of the maskable interrupt requests except INTSER, the asynchronous serial interface receive error interrupt request. Each interrupt request has a dedicated macro service control word stored in Internal RAM (see figure 14). The function to be performed is specified in the control word. The µPD78214 family provides three different types of macro service transfers. Figure 14. Macro Service Control Word Map | 0FEDFH | Channel Pointer | l) | |--------|-----------------|----------------| | OFEDEH | Mode Register | INTSR | | 0FEDOH | Channel Pointer | l) | | 0FEDCH | Mode Register | INTST | | 0FEDBH | Channel Pointer | l) | | 0FEDAH | Mode Register | INTCSI | | 0FED9H | Channel Pointer | ) | | 0FED8H | Mode Register | INTC10 | | 0FED7H | Channel Pointer | INTC11 | | 0FED6H | Mode Register | FINICII | | 0FED5H | Channel Pointer | ) | | 0FED4H | Mode Register | INTP4/INTC30 | | 0FED3H | Channel Pointer | INTP5/INTAD | | 0FED2H | Mode Register | J INT PS/INTAD | | 0FED1H | Channel Pointer | INTCOO | | 0FED0H | Mode Register | J INVICOO | | 0FECFH | Channel Pointer | INTC01 | | 0FECEH | Mode Register | J INTOUT | | OFECDH | Channel Pointer | INTC20 | | 0FECCH | Mode Register | ) IN 1020 | | 0FECBH | Channel Pointer | 1 | | 0FECAH | Mode Register | INTC21 | | 0FEC9H | Channel Pointer | INTPO | | 0FEC8H | Mode Register | J INTEG | | 0FEC7H | Channel Pointer | ) INTP1 | | 0FEC6H | Mode Register | SINIPI | | 0FEC5H | Channel Pointer | INTP2 | | 0FEC4H | Mode Register | ) "" | | 0FEC3H | Channel Pointer | INTP3 | | 0FEC2H | Mode Register | | | | | 85YL-9022A | Macro Service Type A. A byte of data is transferred in either direction between a special function register, preassigned for each interrupt request, and a buffer in Internal RAM (FExx). The preassigned SFRs for the 12 interrupt requests that support macro service Type A transfers are listed in table 4. Table 4. Macro Service Type A Interrupts and Assigned SFRs | Interrupt Request | Source/Destination SFR | |----------------------------------------------------------|--------------------------------------------------| | INTC10: TM1-CR10 coincidence | CR10: Timer 1 8-bit compare register | | INTC11: TM1-CR11 coincidence | CR11: Timer 1 8-bit capture/<br>compare register | | INTC20: TM2-CR20 coincidence | CR20: Timer 2 8-bit compare register | | INTC21: TM2-CR21 coincidence | CR21: Timer 2 8-bit compare register | | INTC30: TM3-CR30 coincidence | CR30: Timer 3 8-bit compare register | | INTSR: End of asynchronous serial interface reception | RxB: Serial receive buffer | | INTST: End of asynchronous serial interface transmission | TxS: Serial transmit shift register | | INTCSI: End of clocked serial interface transmission | SIO: Serial shift register | | INTAD: End of A/D conversion | ADCR: A/D conversion result register | | INTP0: External interrupt pin P0 <sub>1</sub> | CR11: Timer 1 8-bit capture/<br>compare register | | INTP1: External interrupt pin P0 <sub>2</sub> | CR22: Timer 2 8-bit capture register | | INTP2: External interrupt pin P0 <sub>3</sub> | TM2: Timer 2 8-bit timer register | Macro Service Type B. A byte of data is transferred in either direction between any specified special function register and a buffer anywhere in the 64K byte address space. Macro service Type B transfers can be initiated by any maskable interrupt except INTSER. Macro Service Type C. A byte of data is transferred from a buffer anywhere in the 64K byte address space to one of the 8-bit compare registers of timer 1. At the same time, a second byte of data is transferred from a buffer anywhere in the 64K byte address space to the real-time output port buffer. Macro service Type C transfers can be initiated by INTC10 with data transferred to CR10 and POL or POH, or by INTC11 with data transferred to CR11 and POL or POH. In addition, the macro service Type C transfer can be initialized to automatically alter timer compare register values or to repeatedly output a prespecified pattern at a fixed or variable rate. By using macro service Type C transfers to control the real-time output ports, the $\mu$ PD78214 family can easily and accurately drive two independent stepper motors. -40 to +85°C -65 to +150°C ### Refresh The refresh signal is used with any pseudostatic RAM equivalent of the NEC $\mu$ PD428128. The refresh cycle can be set to one of four intervals: 16, 32, 64, or $128/f_{CLK}$ (2.6, 5.3, 10.7, and 21.3 $\mu$ s at 12 MHz). The refresh cycle is timed to follow a read or write operation to avoid interference with external memory access cycles. # Standby Modes HALT and STOP modes are provided to reduce power consumption when CPU action is not required. In HALT mode, the CPU is stopped but the system clock continues to run. The HALT mode is released by any unmasked interrupt, an external NMI, or an external reset pulse. In STOP mode, both the CPU and the system clock are stopped, further minimizing the power consumption. The STOP mode is released by either an external reset pulse or an external NMI. The HALT and STOP modes are entered by programming the standby control register (STBC). This register is a protected location and can be written to only by a special instruction. If the third and fourth bytes of the instruction are not complements of each other, the data is not written and the next instruction is executed. ### **External Reset** The µPD78214 family is reset by taking the RESET pin low. The RESET input pin contains a noise filter to protect against spurious system resets caused by noise. On power-up, the RESET pin must remain low until the power supply reaches its operating voltage and the oscillator has stabilized. During reset, the program counter is loaded with the address contained in the reset vector table (address 0000H, 0001H); program execution starts at that address upon the RESET pin going high. White RESET is low, all external lines except Vss, VDD, AVss, AVREF, X1, and X2 are in the high impedance state. ### **ELECTRICAL SPECIFICATIONS** ## Absolute Maximum Ratings | $T_A = +25^{\circ}C$ | | |------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | Operating voltage, V <sub>DD</sub> AV <sub>REF</sub> AV <sub>SS</sub> | -0.5 to +7.0 V<br>-0.5 to V <sub>DD</sub> +0.5 V<br>-0.5 to +0.5 V | | Input voltage, V <sub>11</sub><br>V <sub>12</sub> (Note 1)<br>V <sub>13</sub> (Note 2 for µPD78P214) | -0.5 to V <sub>DD</sub> + 0.5 V<br>-0.5 to AV <sub>REF</sub> + 0.5 V<br>-0.5 to +13.5 V | | Output voltage, V <sub>0</sub> | –0.5 to $V_{DD}$ + 0.5 $V$ | | Low-level output current, I <sub>OL</sub><br>per pin<br>total, all output pins | 15 mA<br>100 mA | | High-level output current, I <sub>OH</sub><br>per pin<br>total, all output pins | 10 mA<br>50 mA | #### Notes: - (1) Pins P7<sub>0</sub>/AN0 P7<sub>5</sub>/AN5, P6<sub>6</sub>/WAIT/AN6, and P6<sub>7</sub>/REFRQ/AN7 when the pin is used as the A/D converter input or is selected by bits AN10-AN12 of the ADM register when the A/D converter is not in operation. However, V<sub>I1</sub> absolute maximum ratings should also be satisfied. - (2) P2<sub>0</sub>/NMI, EA/V<sub>PP</sub>, and P2<sub>1</sub>/INTP0/A<sub>9</sub> pins in the PROM programming mode Exposure to absolute maximum ratings for extended periods may affect device reliability; exceeding the ratings could cause permanent damage. The device should be operated within the limits specified under DC and AC characteristics. # **Operating Conditions** Operating temperature, TOPT Storage temperature, TSTG | Oscillation Frequency | TA | $V_{DD}$ | |-------------------------------|--------------|-----------| | f <sub>XX</sub> = 4 to 12 MHz | -40 to +85°C | +5 V ±10% | ### Capacitance $T_A = +25^{\circ}C; V_{DD} = V_{SS} = 0 V$ | Item | Symbol | Max | Unit | Conditions | |--------------------------|-----------------|-----|------|--------------------------| | Input capacitance | CI | 20 | рF | f = 1 MHz; | | Output capacitance | Co | 20 | pF | pins not used for | | Input/output capacitance | C <sub>IO</sub> | 20 | рF | measuremer<br>are at 0 V | ## **DC** Characteristics $T_A = -40 \text{ to } +85^{\circ}\text{C}; V_{DD} = +5 \text{ V } \pm 10\%; V_{SS} = 0 \text{ V}$ | Item | Symbol | Min | Тур | Max | Unit | Conditions | |--------------------------------------|-------------------|-----------------------|-----|-------------------|------|------------------------------------------| | Low-level input voltage | V <sub>IL</sub> | 0 | | 0.8 | ٧ | | | High-level input voltage | V <sub>IH1</sub> | 2.2 | | V <sub>DD</sub> | ٧ | Except the specified pins (Notes 1, 2) | | | V <sub>IH2</sub> | 2.2 | | AV <sub>REF</sub> | ٧ | Specified pins (Note 1) | | | V <sub>IH3</sub> | 0.8 V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | Specified pins (Note 2) | | Low-level output voltage | V <sub>OL1</sub> | | | 0.45 | ٧ | I <sub>OL</sub> = 2.0 mA | | | V <sub>OL2</sub> | | | 1.0 | V | I <sub>OL</sub> = 8.0 mA (Note 3) | | High-level output voltage | V <sub>OH1</sub> | V <sub>DD</sub> – 1.0 | | | V | l <sub>OH</sub> = -1.0 mA | | | V <sub>OH2</sub> | V <sub>DD</sub> – 0.5 | | | ٧ | $I_{OH} = -100 \mu\text{A}$ | | | V <sub>OH3</sub> | 2.0 | | | V | I <sub>OH</sub> = -5.0 mA (Note 4) | | X1 low-level input current | IIL | | | -100 | μΑ | $0 \le V_i \le V_{iL}$ | | X1 high-level input current | lін | | | 100 | μΑ | $V_{1H3} \leq V_{I} \leq V_{DD}$ | | Input leakage current | ILI | | - | ±10 | μΑ | $0V \le V_1 \le V_{DD}$ | | Output leakage current | ILO | | | ±10 | μA | $0V \le V_O \le V_{DD}$ | | AV <sub>REF</sub> current | AIREF | | 1.5 | 5.0 | mA | Operating mode, f <sub>XX</sub> = 12 MHz | | V <sub>DD</sub> power supply current | l <sub>DD1</sub> | | 20 | 40 | mA | Operating mode, f <sub>XX</sub> = 12 MHz | | | l <sub>DD2</sub> | | 7 | 20 | mA | HALT mode, f <sub>XX</sub> = 12 MHz | | Data retention voltage | V <sub>DDDR</sub> | 2.5 | | 5.5 | V | STOP mode | | Data retention current | DDDR | | 2 | 20 | μΑ | STOP mode; V <sub>DDDR</sub> = 2.5 V | | | | | 5 | 50 | μΑ | STOP mode; V <sub>DDDR</sub> = 5 V ±10% | | Pullup resistor | RL | 15 | 40 | 80 | kΩ | V <sub>1</sub> = 0 V | ### Notes: - (1) Pins P7<sub>0</sub>/AN0 P7<sub>5</sub>/AN5, P6<sub>8</sub>/WAIT/AN6, and P6<sub>7</sub>/REFRQ/AN7 when the pin is used as the A/D converter input or is selected by bits AN10 AN12 of the ADM register when the A/D converter is not in operation. - (2) X1, X2, $\overline{\text{RESET}}$ , P2<sub>0</sub>/NMI, P2<sub>1</sub>/INTP0, P2<sub>2</sub>/INTP1,P2<sub>3</sub>/INTP2/CI, P2<sub>4</sub>/INTP3, P2<sub>5</sub>/INTP4/ASCK, P2<sub>6</sub>/INTP5, P2<sub>7</sub>/SI, P3<sub>2</sub>/SCK, P3<sub>3</sub>/SO/SB0, and $\overline{\text{EA}}$ pins. - (3) Pins $P4_0/AD_0 P4_7/AD_7$ , and $P5_0/A_8 P5_7/A_{15}$ . - (4) Pins P0<sub>0</sub> P0<sub>7</sub>. AC Characteristics—Read/Write Operation $T_A = -40 \text{ to } +85^{\circ}\text{C}; V_{DD} = +5 \text{ V } \pm 10\%; V_{SS} = 0 \text{ V; } f_{XX} = 12 \text{ MHz; } C_L = 100 \text{ pF}$ | Item | Symbol | Calculation Formula (2, 3) | Min | Max | Unit | Conditions | |----------------------------------------|---------------------|------------------------------|-----|-----|------|------------------------------| | X1 input clock cycle time | tcyx | _ | 82 | 250 | ns | | | Address setup time to ASTB ↓ | t <sub>SAST</sub> | t <sub>CYX</sub> - 30 | 52 | | ns | | | Address hold time from ASTB 4 (Note 1) | thsta | _ | 25 | | ns | | | Address hold time from RD† | tHRA | | 30 | | ns | | | Address hold time from WR † | t <sub>HWA</sub> | | 30 | | ns | <del></del> | | Address to RD ↓ delay time | tDAR | 2t <sub>CYX</sub> - 35 | 129 | | ns | | | Address float time to RD ↓ | tFAR | t <sub>CYX</sub> /2 - 30 | 11 | | ns | | | Address to data input time | t <sub>DAID</sub> | (4+2n)t <sub>CYX</sub> - 100 | | 228 | ns | No wait states | | ASTB ↓ to data input time | t <sub>DSTID</sub> | (3+2n)t <sub>CYX</sub> - 65 | | 181 | ns | No wait states | | RD ↓ to data input time | t <sub>DRID</sub> | (2+2n)t <sub>CYX</sub> - 64 | | 100 | ns | No wait states | | ASTB ↓ to RD ↓ delay time | tDSTR | t <sub>CYX</sub> - 30 | 52 | | ns | | | Data hold time from RD 1 | tHRID | _ | 0 | | ns | | | RD ↑ to address active time | †DRA | 2t <sub>CYX</sub> - 40 | 124 | | ns | | | RD † to ASTB † delay time | †DRST | 2t <sub>CYX</sub> - 40 | 124 | | ns | - | | RD low-level width | twar | (2+2n)t <sub>CYX</sub> - 40 | 124 | | ns | No wait states | | ASTB high-level width | twsтн | t <sub>CYX</sub> - 30 | 52 | •• | ns | | | Address to WR ↓ delay time | t <sub>DAW</sub> | 2t <sub>CYX</sub> - 35 | 129 | | ns | | | ASTB ↓ to data output time | tostop | t <sub>CYX</sub> + 60 | | 142 | ns | | | WR ↓ to data output time | towop | | | 60 | ns | | | ASTB i to WR i delay time | <sup>†</sup> DSTW1 | t <sub>CYX</sub> - 30 | 52 | | ns | <del></del> | | | t <sub>DSTW2</sub> | 2t <sub>CYX</sub> - 35 | 129 | | ns | Refresh mode | | Data setup time to WR † | tsopwa | (3+2n)t <sub>CYX</sub> - 100 | 146 | | ns | No wait states | | Data setup time to WR ↓ | tsopwr | t <sub>CYX</sub> - 60 | 22 | | ns | Refresh mode | | Data hold time from WR † (Note 1) | thwoD | _ | 20 | | ns | | | WR ↑ to ASTB ↑ delay time | towst | t <sub>CYX</sub> - 40 | 42 | | ns | | | WR low-level width | twwL1 | (3+2n)t <sub>CYX</sub> - 50 | 196 | | ns | No wait states | | | twwL2 | (2+2n)t <sub>CYX</sub> - 50 | 114 | | ns | Refresh mode; No wait states | | Address to WAIT ↓ input time | †DAWT | 3t <sub>CYX</sub> - 100 | | 146 | ns | | | ASTB ↓ to WAIT ↓ input time | tDSTWT | 2t <sub>CYX</sub> - 80 | | 84 | ns | | | WAIT hold time from ASTB ↓ | thstwt | 2Xt <sub>CYX</sub> + 10 | 174 | | ns | One external wait state | | ASTB ↓ to WAIT ↑ delay time | t <sub>DSTWTH</sub> | 2(1+X)t <sub>CYX</sub> - 55 | | 273 | ns | One external wait state | | RD ↓ to WAIT input time | tDRWTL | t <sub>CYX</sub> - 60 | | 22 | ns | | | WAIT hold time from RD ↓ | t <sub>HRWT</sub> | (2X -1)t <sub>CYX</sub> + 5 | 87 | | ns | One external wait state | | RD ↓ to WAIT ↑ delay time | t <sub>DRWTH</sub> | (2X+1)t <sub>CYX</sub> - 60 | | 186 | пѕ | One external wait state | | WAIT ↑ to data input time | t <sub>DWTID</sub> | t <sub>CYX</sub> - 20 | | 62 | ns | | | WAIT ↑ to WR ↑ delay time | towtw | 2t <sub>CYX</sub> - 10 | 154 | | ns | | | WAIT † to RD † delay time | t <sub>DWTR</sub> | t <sub>CYX</sub> - 10 | 72 | - | ns | <u> </u> | | WR ↓ to WAIT input time | t <sub>DWWTL</sub> | t <sub>CYX</sub> - 60 | | 22 | ns | Refresh disabled | # AC Characteristics—Read/Write Operation (cont) | Item | Symbol | Calculation Formula (2, 3) | Min | Max | Unit | Conditions | |------------------------------|---------------------|-----------------------------|-----|-----|------|-------------------------------------------| | WAIT hold time from WR↓ | tHWWT1 | (2X-1)t <sub>CYX</sub> + 5 | 87 | _ | ns | One external wait state; refresh disabled | | | tHWWT2 | 2(X-1)t <sub>CYX</sub> + 5 | 5 | | ns | One external wait state; refresh enabled | | WR ∔ to WAIT ↑ delay time | t <sub>DWWTH1</sub> | (2X+1)t <sub>CYX</sub> - 60 | | 186 | ns | One external wait state; refresh disabled | | | tDWWTH2 | 2Xt <sub>CYX</sub> - 60 | | 104 | ns | One external wait state; refresh enabled | | RD ↑ to REFRQ ↓ delay time | <sup>t</sup> DRRFQ | 2t <sub>CYX</sub> - 10 | 154 | | ns | | | WR ↑ to REFRQ ↓ delay time | †DWRFQ | t <sub>CYX</sub> - 10 | 72 | | ns | | | REFRQ low-level width | twrFQL | 2t <sub>CYX</sub> - 44 | 120 | _ | ns | | | REFRQ † to ASTB † delay time | †DRFQST | 4t <sub>CYX</sub> - 48 | 280 | | ns | | ### Notes: - (1) The hold time includes the time during which V<sub>OH</sub> and V<sub>OL</sub> are retained under the following load conditions: $C_L=100$ pF and $R_L=2$ k $\Omega$ - (2) n indicates the number of internal wait states. - (3) x indicates the number of external wait states (1, 2, 3, ...) # **Serial Port Operation** $T_A = -40 \text{ to } +85^{\circ}\text{C}; V_{DD} = +5 \text{ V} \pm 10\%; V_{SS} = 0 \text{ V}; f_{XX} = 12 \text{ MHz}; C_L = 100 \text{ pF}$ | Item | Symbol | Min | Max | Unit | Conditions | |-----------------------------------------|---------------------|-----|-----|------|---------------------------------------------------------| | Serial clock cycle time | tcysk | 1.0 | | μs | External clock input | | | | 1.3 | | μs | internal clock/16 output | | | | 5.3 | | μs | Internal clock/64 output | | Serial clock low-level width | twskL | 420 | | ns | External clock input | | | | 556 | | ns | Internal clock/16 output | | | | 2.5 | | με | Internal clock/64 output | | Serial clock high-level width | twskH | 420 | · | ns | External clock input | | | | 556 | | ns | Internal clock/16 output | | | | 2.5 | | μs | Internal clock/64 output | | SI, SB0 setup time to SCK † | tsssk | 150 | | ns | <del></del> | | SI, SB0 hold time from SCK † | tHSSK | 400 | | ns | *** | | SO/SB0 output delay time from SCK ↓ | t <sub>DSBSK1</sub> | 0 | 300 | ns | CMOS push-pull output<br>(3-line serial I/O mode) | | | t <sub>DSBSK2</sub> | 0 | 800 | ns | Open-drain output (SBI mode), $R_L = 1 \text{ k}\Omega$ | | SB0 high, hold time from SCK † | †HSBSK | 4 | | tcyx | SBI mode | | SB0 low, setup time to <del>SCK</del> ↓ | tssbsk | 4 | | tcyx | SBI mode | | SB0 low-level width | twssL | 4 | | tcyx | | | SB0 high-level width | twsBH | 4 | | tcyx | | # A/D Converter Operation $T_A = -40 \text{ to } +85^{\circ}\text{C}; V_{DD} = +5 \text{ V } \pm 10\%; V_{SS} = \text{AV}_{SS} = 0 \text{ V}$ | Item | Symbol | Min | Тур | Max | Unit | Conditions | |---------------------------|-----------------|------|------|-------------------------|------|---------------------------------------------------------------------------------| | Resolution | | 8 | | | Bit | | | Full-scale error (Note 1) | | | | 0.4 | % | $AV_{REF} = 4.0 \text{ V to V}_{DD}; T_A = -10 \text{ to } +70^{\circ}\text{C}$ | | | | | | 0.8 | % | $AV_{REF} = 3.4 \text{ V to V}_{DD}; T_A = -10 \text{ to } +70^{\circ}\text{C}$ | | | | | | 0.8 | % | AV <sub>REF</sub> = 4.0 V to V <sub>DD</sub> | | Quantization error | | | | ±1/2 | LSB | | | Conversion time | tconv | 360 | _ | | tcyx | 83 ns ≤ t <sub>CYX</sub> ≤ 125 ns (Note 2) | | | | 240 | | | tcyx | 125 ns ≤ t <sub>CYX</sub> ≤ 250 ns (Note 3) | | Sampling time | tSAMP | 72 | | | tcyx | 83 ns ≤ t <sub>CYX</sub> ≤ 125 ns (Note 2) | | | | 48 | | | tcyx | 125 ns ≤ t <sub>CYX</sub> ≤ 250 ns (Note 3) | | Analog input voltage | VIAN | -0.3 | | AV <sub>REF</sub> + 0.3 | ٧ | | | Analog input impedance | R <sub>AN</sub> | | 1000 | | ΜΩ | | | Analog reference voltage | AVREF | 3.4 | | V <sub>DD</sub> | ٧ | | | AV <sub>REF</sub> current | Alaer | | 1.5 | 5.0 | mA | Operating mode, f <sub>XX</sub> = 12 MHz | | | | | 0.2 | 1.5 | mA | STOP mode | #### Note - Quantization errror is not included. Unit is defined as percent of full-scale value. - (2) FR bit of ADM register is 0. - (3) FR bit of ADM registers is 1. # **Interrupt Timing Operation** $T_A = -40 \text{ to } +85^{\circ}\text{C}; V_{DD} = +5 \text{ V } \pm 10\%; V_{SS} = 0 \text{ V}$ | Item | Symbol | Min | Max | Unit | Conditions | |------------------------------|-------------------|-----|-----|------|------------| | NMI low-level width | t <sub>WNIL</sub> | 10 | | μs | | | NMI high-level width | twnih | 10 | | μs | | | INTP0-INTP5 low-level width | twiTL | 24 | | tcyx | | | INTP0-INTP5 high-level width | twпн | 24 | | tcyx | | | RESET low-level width | twrsl. | 10 | | μs | | | RESET high-level width | †wrsн | 10 | | με | | ### **Data Retention Characteristics** $T_A = -40 \text{ to } +85^{\circ}\text{C}$ | Item | Symbol | Min | Тур | Max | Unit | Conditions | |------------------------------------------------------------|-------------------|-----------------------|-----|---------------------------------------|------------|------------------------------| | Data retention voltage | V <sub>DDDR</sub> | 2.5 | | 5.5 | V | STOP mode | | Data retention current | IDDDR | | 2 | 20 | <u>μ</u> Α | V <sub>DDDR</sub> = 2.5 V | | | | | 5 | 50 | μA | V <sub>DDDR</sub> = 5 V ±10% | | V <sub>DD</sub> rise time | t <sub>RVD</sub> | 200 | | | μs | | | V <sub>DD</sub> fall time | t <sub>FVD</sub> | 200 | | | μs | | | V <sub>DD</sub> retention time<br>(from STOP mode setting) | t <sub>HVD</sub> | 0 | | | ms | | | STOP release signal input time | †DREL | 0 | | · · · · · · · · · · · · · · · · · · · | ms | | | Oscillation stabilization wait time | twarr | 30 | | | ms | Crystal resonator | | | | 5 | - | _ | ms | Ceramic resonator | | Low-level input voltage | VIL | 0 | | 0.1 V <sub>DDDR</sub> | ٧ | Specified pins (Note 1) | | High-level input voltage | VIH | 0.9 V <sub>DDDR</sub> | | V <sub>DDDR</sub> | ٧ | Specified pins (Note 1) | Note: $\overline{\text{RESET}}$ , P2<sub>0</sub>/NMI, P2<sub>1</sub>/INTP0, P2<sub>2</sub>/INTP1, P2<sub>3</sub>/INTP2/CI, P2<sub>4</sub>/INTP3, P2<sub>5</sub>/INTP4/ASCK, P2<sub>6</sub>/INTP5, P2<sub>7</sub>/SI, P3<sub>2</sub>/ $\overline{\text{SCK}}$ , P3<sub>3</sub>/SO/SB0, and $\overline{\text{EA}}$ pins. # Recommended Resonator Circuit # Recommended External Clock Circuit # **External Clock Operation** $T_A = -40 \text{ to } +85^{\circ}\text{C}; V_{DD} = +5 \text{ V } \pm 10\%; V_{SS} = 0 \text{ V}$ | | 7 00 | | | | | | |---------------------------|------------------|-----|-----|------|------------|--| | Item | Symbol | Min | Max | Unit | Conditions | | | X1 input low-level width | t <sub>WXL</sub> | 30 | 130 | ns | | | | X1 input high-level width | twxH | 30 | 130 | ns | | | | X1 input rise time | t <sub>XR</sub> | 0 | 30 | ns | | | | X1 input fall time | t <sub>XF</sub> | 0 | 30 | ns | | | | X1 input clock cycle time | tcyx | 82 | 250 | ns | | | ## **Recommended Ceramic Resonators** | Manufacturer | Frequency<br>(MHz) | Part Number | C1 (pF) | C2 (pF) | |---------------|--------------------|----------------|----------|----------| | Murata Mfg. | 12 | CSA12.0MT | 30 | 30 | | | | CST12.0MTW (1) | None (2) | None (2) | | | 4 | CSA4.00MG040 | 100 | 100 | | | | CST4.00MG040 | None (2) | None (2) | | Kyocera Corp. | 12 | KBR12.0M | 33 | 33 | ### Notes: - (1) Recommended for $\mu$ PD78212/213/214 only. - (2) C1 and C2 are contained in the resonator. # Recommended Crystal Resonators | Manufacturer | Frequency<br>(MHz) | Part<br>Number | C1 (pF) | C2 (pF) | |--------------|--------------------|----------------|---------|---------| | Kinseki | 12 | HC-49/U | 18 | 18 | # **Timing Waveforms** # Voltage Thresholds for AC Timing Measurements # Read Operation # Write Operation # External WAIT Signal Input (Read Operation) # External WAIT Signal Input (Write Operation) ## Refresh After Read # Refresh After Write # Timing Waveforms (cont) # Serial Operation # Timing Waveforms (cont) # Interrupt Input # External Clock # Reset Input ### Data Retention Characteristics # NEC ### μPD78P214 PROGRAMMING In the $\mu$ PD78P214, the mask ROM of $\mu$ PD78214 is replaced by a one-time programmable ROM (OTP ROM) or a reprogrammable, ultraviolet erasable ROM (UV EPROM). The ROM is 16,384 x 8 bits and can be programmed using a general-purpose PROM writer with a $\mu$ PD27C256A programming mode. The PA-78P214CW/GC/GJ/GQ/L are the socket adaptors used for configuring the $\mu$ PD78P214 to fit a standard PROM socket. Refer to tables 5 and 6 and figures 15 through 18 for special information applicable to PROM programming. Table 5. Pin Functions During PROM Programming | Pin | Pin* | Function | | | | | | |---------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------|--|--|--|--|--| | P0 <sub>0</sub> - P0 <sub>7</sub> A <sub>0</sub> -A <sub>7</sub> | | Address input pins for PROM operations | | | | | | | P5 <sub>0</sub> /A <sub>8</sub> | Ag | Address input pin for PROM operations | | | | | | | P2 <sub>1</sub> /INTP0 | A <sub>9</sub> | Address input pin for PROM operations | | | | | | | P5 <sub>2</sub> /A <sub>10</sub> - P5 <sub>6</sub> /A <sub>14</sub> | A <sub>10</sub> - A <sub>14</sub> | Address input pins for PROM operations | | | | | | | P4 <sub>0</sub> /AD <sub>0</sub> - P4 <sub>7</sub> /AD <sub>7</sub> | D <sub>0</sub> - D <sub>7</sub> | Data pins for PROM operations | | | | | | | P6 <sub>5</sub> /WR | CE | Strobes data into the PROM | | | | | | | P6 <sub>4</sub> /RD | ŌĒ | Enables a data read from the PROM | | | | | | | P2 <sub>0</sub> /NMI | NMI | PROM programming mode is<br>entered by applying +12.5 volts to<br>this pin | | | | | | | RESET | RESET | PROM programming mode requires applying a low voltage to this pin | | | | | | | EA | V <sub>PP</sub> | High voltage applied to this pin for program write/verify | | | | | | | V <sub>DD</sub> | V <sub>DD</sub> | Positive power supply pin | | | | | | | V <sub>SS</sub> | Vss | Ground | | | | | | | | | | | | | | | <sup>\*</sup> Pin name in PROM programming mode. Table 6. Summary of Operation Modes for PROM Programming | Mode | NMI | RESET | CE | ŌĒ | V <sub>PP</sub> | V <sub>DD</sub> | D <sub>0</sub> - D <sub>7</sub> | |-----------------|---------|-------|----|-----|-----------------|-----------------|---------------------------------| | Program write | +12.5 V | L | Ļ | Н | +12.5 V | +6 V | Data input | | Program verify | +12.5 V | L | Н | L | +12.5 V | +6 V | Data output | | Program inhibit | +12.5 V | L | Н | Н | +12.5 V | +6 V | High Z | | Read out | +12.5 V | L | L | L | +5 V | +5 V | Data output | | Output disable | +12.5 V | L | L | Н | +5 V | +5 V | High Z | | Standby | +12.5 V | L | Н | L/H | +5 V | +5 V | High Z | Note: When +12.5 V is applied to $V_{pp}$ and +6 V to $V_{DD}$ , both $\overline{CE}$ and $\overline{OE}$ cannot be set to low level (L) simultaneously. # Pin Functions in μPD78P214 PROM Programming Mode Figure 15. 64-Pin Plastic and Ceramic Shrink DIP 64-Pin Plastic QUIP # Pin Functions in μPD78P214 PROM Programming Mode (cont) Figure 16. 64-Pin Plastic QFP # Pin Functions in μPD78P214 PROM Programming Mode (cont) Figure 17. 68-Pin PLCC # Pin Functions in μPD78P214 PROM Programming Mode (cont) Figure 18. 74-Pin Plastic QFP #### PROM Write Procedure - (1) Set the pins not used for programming as indicated in figures 15 through 18. Connect the RESET pin to a low level, the V<sub>DD</sub> and V<sub>PP</sub> pins to +5 V, and apply +12.5 V to the NMI pin. The CE and OE pins should be high. - (2) Apply +6 V to the V<sub>DD</sub> pin and +12.5 V to the V<sub>PP</sub> pin. - (3) Provide the initial address to the $A_0$ to $A_{14}$ pins. - (4) Provide write data. - (5) Provide 1-ms program pulse (active low) to the CE pin. - (6) This data is now verified with a pulse (active low) to the OE pin. If the data has been written, proceed to step 8; if not, repeat steps 4 to 6. If the data cannot be correctly written after 25 attempts, go to step 7. - (7) Classify as defective and stop write operation. - (8) Provide write data and supply program pulse (for additional writing) for 3 ms times the number of writes performed in step 5. - (9) Increment the address. - (10) Repeat steps 4 to 9 until the end address. NEC reserves address 4000H for future functional extension. If a PROM writer cannot specify a final programming address, FFH must be written in address 4000H. ### **PROM Read Procedure** - (1) Set the pins not used for programming as indicated in figures 15 through 18. Fix the RESET pin to a low level, the V<sub>DD</sub> and V<sub>PP</sub> pins to +5 V, and apply +12.5 V to the NMI pin. The CE and OE pins should be high. - (2) Input the address of the data to be read to pins A<sub>0</sub> - A<sub>14</sub>. - (3) Read mode is entered with a pulse (active low) on both the $\overline{CE}$ and $\overline{OE}$ pins. - (4) Data is output to the D<sub>0</sub> to D<sub>7</sub> pins. #### **EPROM Erasure** Data in an EPROM is erased by exposing the quartz window in the ceramic package to light having a wavelength shorter than 400 nm, including ultraviolet rays, direct sunlight, and fluorescent light. To prevent unintentional erasure, mask the window. Typically, data is erased by 254-nm ultraviolet rays. A minimum lighting level of 15 Ws/cm² (ultraviolet ray intensity x exposure time) is required to completely erase written data. Erasure by an ultraviolet lamp rated at 12 mW/cm² takes approximately 15 to 20 minutes. Remove any filter on the lamp and place the device within 2.5 cm of the lamp tubes. # NEC # **DC Programming Characteristics** $T_A = 25 \pm 5^{\circ}C$ ; $V_{IP} = 12.5 \pm 0.5 \text{ V}$ applied to NMI pin; $V_{SS} = 0 \text{ V}$ | Parameter | Symbol | Symbol* | Min | Тур | Max | Unit | Condition | |------------------------------------|------------------|------------------|-----------------------|--------------------|------------------------|------|-----------------------------------------------------------------| | High-level input voltage | V <sub>IH</sub> | VIH | 2.4 | | V <sub>DDP</sub> + 0.3 | ٧ | | | Low-level input voltage | $V_{IL}$ | VIL | -0.3 | | 0.8 | ٧ | | | Input leakage current | I <sub>LIP</sub> | ել | | | 10 | μΑ | $0 \le V_{ } \le V_{DDP}$ | | High-level output voltage | V <sub>OH1</sub> | V <sub>OH1</sub> | 2.4 | | | V | $I_{OH} = -400 \mu\text{A}$ | | | V <sub>OH2</sub> | V <sub>OH2</sub> | V <sub>DD</sub> - 0.7 | | | ٧ | $I_{OH} = -100 \mu A$ | | Low-level output voltage | VoL | V <sub>OL</sub> | | | 0.45 | ٧ | I <sub>OL</sub> = 2.1 mA | | Output leakage current | lo | | | | 10 | μΑ | $0 \le V_O \le V_{DDP}, \overline{OE} = V_{IH}$ | | NMI pin high-voltage input current | l <sub>IP</sub> | | | | ±10 | μΑ | | | V <sub>DDP</sub> power voltage | V <sub>DDP</sub> | Vcc | 5.75 | 6.0 | 6.25 | ٧ | Program memory write mode | | | | | 4.5 | 5.0 | 5.5 | ٧ | Program memory read mode | | Vpp power voltage | V <sub>PP</sub> | Vpp | 12.2 | 12.5 | 12.8 | ٧ | Program memory write mode | | | | | | $V_{PP} = V_{DDP}$ | | V | Program memory read mode | | V <sub>DDP</sub> power current | lDD | lcc | | 5 | 30 | mA | Program memory write mode | | | | | | 5 | 30 | mA | Program memory read mode $\overline{CE} = V_{IL}, V_I = V_{IH}$ | | V <sub>PP</sub> power current | Ірр | lpp | | 5 | 30 | mA | Program memory write mode | | | | | | 1 | 100 | μΑ | Program memory read mode | <sup>\*</sup> Corresponding symbols of the $\mu$ PD27C256A. AC Programming Characteristics (Write Mode) $T_A=25\pm 5^{\circ}C; V_{IP}=12.5\pm 0.5 \text{ V applied to NMI pin; } V_{SS}=0 \text{ V; } V_{DD}=6\pm 0.25 \text{ V; } V_{PP}=12.5\pm 0.3 \text{ V}$ | Parameter | Symbol | Symbol* | Min | Тур | Max | Unit | Conditions | |------------------------------------------------|-------------------|------------------|------|-----|-------|------|------------| | Address setup time to CE ↓ | tsac | t <sub>AS</sub> | 2 | | | μs | | | Data input to OE ↓ delay time | t <sub>DDOO</sub> | toes | 2 | | | με | | | Input data setup time to CE ↓ | tsinc | t <sub>DS</sub> | 2 | | | μs | | | Address hold time from CE ↑ | t <sub>HCA</sub> | t <sub>AH</sub> | 2 | | | μs | | | Input data hold time from CE ↑ | tHCID | t <sub>DH</sub> | 2 | | | μs | | | Output data hold time from OE † | t <sub>HOOD</sub> | t <sub>DF</sub> | 0 | | 130 | ns | | | V <sub>pp</sub> setup time to CE ↓ | tsvpc | t <sub>VPS</sub> | 1 | | | ms | | | V <sub>DDP</sub> setup time to <del>CE</del> ↓ | tsvDC | tvcs | 1 | | | ms | | | Initial program pulse width | twL1 | t <sub>PW</sub> | 0.95 | 1.0 | 1.05 | ms | | | Additional program pulse width | t <sub>WL2</sub> | topw | 2.85 | | 78.75 | ms | | | NMi high-voltage input setup time to CE ↓ | tspc | | 2 | | | μs | | | OE ↓ to data output time | tDOOD | toE | | | 150 | ns | | <sup>\*</sup> Corresponding symbols of the $\mu$ PD27C256A. AC Programming Characteristics (Read Mode) $T_A = 25 \pm 5^{\circ}C; V_{IP} = 12.5 \pm 0.5 \text{ V} \text{ applied to NMI pin; } V_{SS} = 0 \text{ V}; V_{DD} = 5 \pm 0.5 \text{ V}; V_{PP} = V_{DDP}$ | Parameter | Symbol | Symbol* | Min | Тур | Max | Unit | Condition | |-----------------------------|-------------------|-----------------|-----|-----|-----|------|---------------------------| | Address to data output time | t <sub>DAOD</sub> | tacc | | | 200 | ns | CE = OE = V <sub>II</sub> | | CE ↓ to data output time | t <sub>DCOD</sub> | t <sub>CE</sub> | | | 200 | ns | OE = VII | | OE ↓ to data output time | t <sub>DOOD</sub> | toE | | | 75 | ns | CE = V <sub>II</sub> | | Data hold time from OE † | tHCOD | t <sub>DF</sub> | 0 | | 60 | ns | CE = V <sub>II</sub> | | Data hold time from address | t <sub>HAOD</sub> | tон | 0 | | | ns | CE = OE = V <sub>II</sub> | <sup>\*</sup> Corresponding symbols of the $\mu$ PD27C256A. # **PROM Timing Diagrams** # PROM Write/Verify Mode # **PROM Timing Diagrams (cont)** # **PROM Read Mode**