## 16 bits, Fixed-point Digital Signal Processor

$\mu$ PD77016 is a 16 bits fixed-point DSP (Digital Signal Processor) developed for digital signal processing with its demand for high speed and precision.

## FEATURES

- FUNCTIONS
- Instruction cycle: 30 ns (MIN.) with 33 MHz clock
- Dual load/store
- Hardware loop function
- Conditional execution
- Executes product-sum operation in one instruction cycle
- PROGRAMMING
- 16 bits $\times 16$ bits +40 bits $\rightarrow 40$ bits multiply accumulator
- 8 general registers (40 bits each)
- 8 ROM/RAM data pointer: each data memory area has 4 registers
- 10 source interrupts (external: 4, internal: 6)
- 3 operand instructions (example: R0 = R0 +R1L*R2L)
- Nonpipeline on execution stage
- MEMORY AREAS
- Program memory area: 64 K words $\times 32$ bits
- Two independent data memory areas: 64 K words $\times 16$ bits (X/Y memory)
- ON-CHIP PERIPHERAL
- I/O port: 4 bits
- Serial I/O (16 bits): 2 channels
- CMOS
- +5 V single power supply


## ORDERING INFORMATION

Part Number Package
$\mu$ PD77016GM-KMD 160-pin plastic QFP (FINE PITCH) $(24 \times 24 \mathrm{~mm})$


## FUNCTIONAL PIN GROUPS


$\star$ Functional Differences among the $\mu$ PD7701× Family

| Item | $\mu \mathrm{PD} 77016$ | $\mu \mathrm{PD} 77015$ | $\mu \mathrm{PD} 77017$ | $\mu \mathrm{PD} 77018$ | $\mu \mathrm{PD} 77018 \mathrm{~A}$ | $\mu$ PD77019 | $\mu \mathrm{PD} 77019-013$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Internal instruction RAM | 1.5 K words | 256 words |  |  |  | 4K words |  |
| Internal instruction ROM | None | 4K words | 12K words | 24K words |  |  | None |
| External instruction memory | 48K words | None |  |  |  |  |  |
| Data RAM (X/Y memory) | 2K words each | 1K words each | 2K words each | 3K words each |  |  |  |
| Data ROM (X/Y memory) | None | 2K words each | 4K words each | 12 K words each |  |  | None |
| External data memory | 48 K words each | 16K words each |  |  |  |  |  |
| Instruction cycle <br> (Maximum operation speed) | 30 ns ( 33 MHz ) |  |  |  | $16.6 \mathrm{~ns}(60 \mathrm{MHz})$ |  |  |
| External clock <br> (at maximum operation speed) | 66 MHz | $33 / 16.5 / 8.25 / 4.125 \mathrm{MHz}$ <br> Variable multiple rate ( $1,2,4,8$ ) by mask option. |  |  | $60 / 30 / 20 / 15 / 7.5 \mathrm{MHz}$ <br> Variable multiple rate (1, 2, 3, 4, 8 ) by mask option. |  | $15 \mathrm{MHz}$ <br> Multiple rate is fixed to 4. |
| Crystal <br> (at maximum operation speed) | - | 33 MHz |  |  | 60 MHz |  | - |
| Instruction | - | STOP instruction is added. |  |  |  |  |  |
| Serial interface (2 Channels) | Channel 1 has the same functions as channel 2. | Channel 1 has the same functions as that of the $\mu$ PD77016. <br> Channel 2 has no SORQ2 or SIAK2 pin (Channel 2 is used for CODEC connection). |  |  |  |  |  |
| Power supply | 5 V | 3 V |  |  |  |  |  |
| Package | 160-pin plastic QFP | 100-pin plastic TQFP |  |  | 100-pin plastic TQFP 116-pin plastic BGA | 100-pin plastic TQFP |  |

Remark The $\mu$ PD77019-013 internal ROM area is masked already by the void code to use as RAM based DSP without mask code ordering process.

## PIN CONFIGURATION

## $\mu$ PD77016GM-KMD

160-pin plastic QFP (FINE PITCH) ( $24 \times 24 \mathrm{~mm}$ ) (Top View)


## PIN IDENTIFICATION

| $\overline{\text { BSTB }}$ | Bus Strobe |
| :---: | :---: |
| CLKIN: | Clock Input |
| CLKOUT: | Clock Output |
| D0-D15: | 16 Bits Data Bus |
| DA0-DA15: | External Data Memory Address Bus |
| GND: | Ground |
| HA0, HA1: | Host Data Access |
| $\overline{\mathrm{HCS}}$ : | Host Chip Select |
| HD0-HD7: | Host Data Bus |
| HOLDAK: | Hold Acknowledge |
| HOLDRQ: | Hold Request |
| HRD: | Host Read |
| HRE: | Host Read Enable |
| HWE: | Host Write Enable |
| HWR: | Host Write |
| IA0-IA15: | Instruction Memory Address Output |
| ID0-ID31: | Instruction Data Input |
| INT1-INT4: | Interrupt |
| $\overline{\mathrm{MRD}}$ : | Memory Read Output |
| $\overline{\mathrm{MWR}}$ : | Memory Write Output |
| N.C: | No Connection |
| P0-P3: | Port |
| PWR: | Program Memory Write Strobe |
| RESET: | Reset |
| SCK1,SCK2: | Serial Clock Input |
| SI1,SI2: | Serial Data Input |
| SIAK1,SIAK2: | Serial Input Acknowledge |
| SIEN1,SIEN2: | Serial Input Enable |
| SO1,SO2: | Serial Data Output |
| SOEN1,SOEN2: | Serial Output Enable |
| SORQ1,SORQ2 | : Serial Output Request |
| TCK: | Test Clock Input |
| TDI: | Test Data Input |
| TDO: | Test Data Output |
| TICE: | Test In-Circuit Emulator |
| TMS: | Test Mode Select |
| Vdd: | Power Supply |
| WAIT: | Wait Input |
| $\bar{X} / \mathrm{Y}$ : | X/Y Memory Select |


| Pin No. | Symbol | Pin No. | Symbol | Pin No. | Symbol | Pin No. | Symbol |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\overline{\text { RESET }}$ | 41 | D15 | 81 | $\overline{H W R}$ | 121 | ID31 |
| 2 | $\overline{\text { INT4 }}$ | 42 | D14 | 82 | HAO | 122 | ID30 |
| 3 | $\overline{\text { INT3 }}$ | 43 | D13 | 83 | HA1 | 123 | ID29 |
| 4 | $\overline{\mathrm{INT}}$ | 44 | D12 | 84 | HD7 | 124 | ID28 |
| 5 | INT1 | 45 | GND | 85 | HD6 | 125 | ID27 |
| 6 | WAIT | 46 | VDD | 86 | HD5 | 126 | ID26 |
| 7 | $\overline{\text { HOLDRQ }}$ | 47 | D11 | 87 | HD4 | 127 | ID25 |
| 8 | CLKIN | 48 | D10 | 88 | HD3 | 128 | ID24 |
| 9 | P3 | 49 | D9 | 89 | HD2 | 129 | $\overline{\text { PWR }}$ |
| 10 | P2 | 50 | D8 | 90 | HD1 | 130 | GND |
| 11 | P1 | 51 | D7 | 91 | HDO | 131 | VDD |
| 12 | P0 | 52 | D6 | 92 | HRE | 132 | ID23 |
| 13 | CLKOUT | 53 | D5 | 93 | HWE | 133 | ID22 |
| 14 | GND | 54 | D4 | 94 | GND | 134 | ID21 |
| 15 | VDD | 55 | GND | 95 | VDD | 135 | ID20 |
| 16 | $\overline{\text { MWR }}$ | 56 | Vod | 96 | TDO | 136 | ID19 |
| 17 | $\overline{\text { MRD }}$ | 57 | D3 | 97 | TICE | 137 | ID18 |
| 18 | $\overline{\text { BSTB }}$ | 58 | D2 | 98 | TCK | 138 | ID17 |
| 19 | HOLDAK | 59 | D1 | 99 | TDI | 139 | ID16 |
| 20 | $\bar{X} / Y$ | 60 | D0 | 100 | TMS | 140 | GND |
| 21 | DA15 | 61 | GND | 101 | IA15 | 141 | VDD |
| 22 | DA14 | 62 | Vod | 102 | IA14 | 142 | ID15 |
| 23 | DA13 | 63 | SI1 | 103 | IA13 | 143 | ID14 |
| 24 | DA12 | 64 | SIEN1 | 104 | IA12 | 144 | ID13 |
| 25 | GND | 65 | SCK1 | 105 | GND | 145 | ID12 |
| 26 | Vdo | 66 | SIAK1 | 106 | Vdo | 146 | ID11 |
| 27 | DA11 | 67 | SO1 | 107 | IA11 | 147 | ID10 |
| 28 | DA10 | 68 | SORQ1 | 108 | IA10 | 148 | ID9 |
| 29 | DA9 | 69 | SOEN1 | 109 | IA9 | 149 | ID8 |
| 30 | DA8 | 70 | GND | 110 | IA8 | 150 | GND |
| 31 | DA7 | 71 | Vdo | 111 | IA7 | 151 | Vod |
| 32 | DA6 | 72 | SOEN2 | 112 | IA6 | 152 | ID7 |
| 33 | DA5 | 73 | SORQ2 | 113 | IA5 | 153 | ID6 |
| 34 | DA4 | 74 | SO2 | 114 | IA4 | 154 | ID5 |
| 35 | GND | 75 | SIAK2 | 115 | GND | 155 | ID4 |
| 36 | Vod | 76 | SCK2 | 116 | Vdo | 156 | ID3 |
| 37 | DA3 | 77 | SIEN2 | 117 | IA3 | 157 | ID2 |
| 38 | DA2 | 78 | SI2 | 118 | IA2 | 158 | ID1 |
| 39 | DA1 | 79 | $\overline{\mathrm{HCS}}$ | 119 | IA1 | 159 | ID0 |
| 40 | DAO | 80 | $\overline{\text { HRD }}$ | 120 | IAO | 160 | NC |

## CONTENTS

1. PIN FUNCTIONS ..... 9
1.1 Pin Functions ..... 9
1.2 Recommended Connection for Unused Pins ..... 14
2. FUNCTIONS ..... 15
2.1 Pipeline Processing ..... 15
2.1.1 Outline ..... 15
2.1.2 Instructions with Delay ..... 15
2.2 Program Control Unit ..... 16
2.3 Operation Unit ..... 16
2.3.1 General register (R0 to R7) ..... 16
2.3.2 MAC: Multiply ACcumulator ..... 17
2.3.3 ALU: Arithmetic Logic Unit ..... 17
2.3.4 BSFT: Barrel ShiFTer ..... 17
2.3.5 SAC: Shifter And Count Circuit ..... 17
2.3.6 CJC: Condition Judge Circuit ..... 17
2.4 Memory ..... 18
2.4.1 Instruction RAM Outline ..... 19
2.4.2 Data Memory Outline ..... 19
2.4.3 Data Memory Addressing ..... 19
2.5 On-chip Peripheral Circuit ..... 20
2.5.1 Serial Interface Outline ..... 20
2.5.2 Host Interface Outline ..... 20
2.5.3 General Input/output Ports Outline ..... 20
2.5.4 Wait Cycle Register ..... 20
3. INSTRUCTIONS ..... 21
3.1 Outline ..... 21
3.2 Instruction Set and Operation ..... 22
4. ELECTRICAL SPECIFICATIONS ..... 29
5. PACKAGE DRAWING ..... 50
6. RECOMMENDED SOLDERING CONDITIONS ..... 51

## 1. PIN FUNCTIONS

### 1.1 Pin Functions

- Power supply

| Symbol | Pin No. | I/O |  | Function |
| :--- | :--- | :--- | :--- | :--- |
| VDD | $15,26,36,46,56,62,71$, <br> $95,106,116,131,141,151$ | - | +5 V power supply |  |
| GND | $14,25,35,45,55,61,70$, <br> $94,105,115,130,140,150$ | - | Ground |  |

- System control

| Symbol | Pin No. | I/O | Function |
| :--- | :--- | :---: | :--- |
| CLKIN | 8 | I | External clock input |
| CLKOUT | 13 | $O$ | Internal system clock output |
| $\overline{\text { RESET }}$ | 1 | I | Internal system reset signal input |

- Interrupt

| Symbol | Pin No. | I/O | Function |
| :---: | :--- | :---: | :--- |
| $\overline{\mathrm{INT4}}-\overline{\mathrm{INT} 1}$ | $2,3,4,5$ | 1 | Maskable external interrupt input <br> • Falling edge detection |

- External data memory interface

| Symbol | Pin No. | I/O | Function |
| :---: | :---: | :---: | :---: |
| $\bar{X} / Y$ | 20 | $\begin{gathered} 0 \\ (3 S) \end{gathered}$ | Memory select signal output <br> - $0: \mathrm{X}$ memory is used. <br> - 1: Y memory is used. |
| DA15 - DA0 | Note 1. | $\begin{gathered} \mathrm{O} \\ \text { (3S) } \end{gathered}$ | Address bus to external data memory <br> - External data memory is accessed. <br> - During the external memory is not accessed, these pins keep the previous level. <br> These pins are set to low level; 0x0000, by reset. They continue outputting low level until the first external memory access. |
| D15-D0 | Note 2. | $\begin{aligned} & \text { I/O } \\ & \text { (3S) } \end{aligned}$ | 16 bits data bus to external data memory <br> - External data memory is accessed. |
| $\overline{\text { MRD }}$ | 17 | $\begin{gathered} 0 \\ (3 \mathrm{~S}) \end{gathered}$ | Read output <br> - Reads external memory |
| $\overline{\text { MWR }}$ | 16 | $\begin{gathered} 0 \\ (3 \mathrm{~S}) \end{gathered}$ | Write output <br> - Writes external memory |
| $\overline{\text { WAIT }}$ | 6 | 1 | Wait signal input <br> Wait cycle is input when external memory is read. <br> 1: No wait <br> 0 : Wait |
| $\overline{\text { HOLDRQ }}$ | 7 | 1 | Hold request signal input <br> - Input low level when external data memory bus is expected to use. |
| $\overline{\text { BSTB }}$ | 18 | 0 | Bus strobe signal output <br> - Outputs low level while the $\mu$ PD77016 is occupying external memory bus. |
| $\overline{\text { HOLDAK }}$ | 19 | 0 | Hold acknowledge signal output <br> - Outputs low level when the $\mu$ PD77016 permits external device to use external data memory bus. |

Note 1. DA15 to DA0 pins are located on Pin No. 21-24, 27-34, 37-40.
2. D15 to D0 pins are located on Pin No. 41-44, 47-54, 57-60.
$\star$ Remark The state of the pins added 3S becomes high impedance when the external memory is not accessed or bus release signal ( $\overline{\text { HOLDAK }}=0$ ) is output.

- Serial interface

| Symbol | Pin No. | I/O | Function |
| :---: | :---: | :---: | :---: |
| SCK1 | 65 | 1 | Clock input for serial 1 |
| SORQ1 | 68 | 0 | Serial output 1 request |
| SOEN1 | 69 | 1 | Serial output 1 enable |
| SO1 | 67 | O (3S) | Serial data output 1 |
| SIEN1 | 64 | 1 | Serial input 1 enable |
| SI1 | 63 | 1 | Serial data input 1 |
| SCK2 | 76 | 1 | Clock input for serial 2 |
| SORQ2 | 73 | O | Serial output 2 request |
| SOEN2 | 72 | 1 | Serial output 2 enable |
| SO2 | 74 | O (3S) | Serial data output 2 |
| SIEN2 | 77 | I | Serial input 2 enable |
| SI2 | 78 | 1 | Serial data input 2 |
| SIAK1 | 66 | O | Serial input 1 acknowledge |
| SIAK2 | 75 | 0 | Serial input 2 acknowledge |

Remark The state of the pins added 3 S becomes high impedance, when data output have been finished or $\overline{\operatorname{RESET}}$ is input.

- Host interface

| Symbol | Pin No. | 1/0 | Function |
| :---: | :---: | :---: | :---: |
| HA1 | 83 | 1 | Specifies register which HD7 to HD0 access <br> 1: Accesses HST: Host interface status register when HA1 = 0 <br> 0: Accesses HDT (out): Host transmit data register when $\overline{\mathrm{HRD}}=0$ <br> 0: Accesses HDT (in): Host receive data register when $\overline{\mathrm{HWR}}=0$ |
| HAO | 82 | 1 | Specifies bits of registers which HD7 to HD0 access <br> - 1: Accesses bits 15-8 of HST, HDT (out), HDT (in) <br> - 0 : Accesses bits 7-0 of HST, HDT (out), HDT (in) |
| $\overline{\mathrm{HCS}}$ | 79 | 1 | Chip select input |
| $\overline{\text { HRD }}$ | 80 | 1 | Host read input |
| HWR | 81 | 1 | Host write input |
| HRE | 92 | 0 | Host read enable output |
| $\overline{\text { HWE }}$ | 93 | 0 | Host write enable output |
| HD7 - HD0 | 84-91 | I/O (3S) | 8 bits host data bus |

Remark The state of the pins added $3 S$ becomes high impedance when the host does not access host interface.

- I/O port

| Symbol | Pin No. | I/O | Function |
| :---: | :---: | :---: | :---: |
| P3-P0 | $9-12$ | $1 / O$ | I/O port |

- External instructions memory interface

| Symbol | Pin No. | I/O | Function |
| :--- | :--- | :--- | :--- |
| IA15-IAO | Note 1. | $\mathrm{O}(3 \mathrm{~S})$ | Address bus to external instruction memory <br> - Even the internal instruction memory is accessed, the <br> address is output to the external instruction memory. <br> In this case, the $\mu$ PD77016 ignores data of external <br> instruction memory output. |
| ID31- ID0 | Note 2. | I/O (3S) | 32 bits instruction input |
| $\overline{\text { PWR }}$ | 129 | $\mathrm{O}(3 \mathrm{~S})$ | Program memory write strobe <br> - Write strobe for external instruction memory. This pin <br> loads program to external instruction memory (not <br> internal memory) while $\mu$ PD77016 is in boot operation. |

Note 1. IA15 to IAO pins are located on these pins: 101 to 104,107 to 114,117 to 120
2. ID31 to ID0 pins are located on these pins: 121 to 128,132 to 139,142 to 149,152 to 159

Remark The state of the pins added 3 S becomes high impedance when RESET is input.

- Debugging interface

| Symbol | Pin No. | I/O |  |
| :--- | :--- | :---: | :--- |
| TDO | 96 | O | For debugging |
| TICE | 97 | 0 | For debugging |
| TCK | 98 | I | For debugging |
| TDI | 99 | I | For debugging |
| TMS | 100 | 1 | For debugging |

### 1.2 Recommended Connection for Unused Pins

| Pin | I/O | Recommended connection |
| :---: | :---: | :---: |
| $\overline{\text { INT1 }}$ - $\overline{\text { INT4 }}$ | 1 | connect to VDD |
| $\bar{X} / Y$ | 0 | open |
| DA0 - DA15 | 0 |  |
| D0-D15 Note 1 | 1/0 | connect to VDD or GND, via a resistor |
| $\overline{\text { MRD, }}$ MWR | 0 | open |
| WAIT | 1 | connect to VDD |
| $\overline{\text { HOLDRQ }}$ | I |  |
| $\overline{\text { BSTB }}$ | 0 | open |
| HOLDAK | 0 |  |
| SCK1, SCK2 | I | connect to VDD or GND |
| SI1, SI2 | 1 |  |
| SOEN1, SOEN2 | 1 | connect to GND |
| SIEN1, SIEN2 | I |  |
| SORQ1, SORQ2 | 0 | open |
| SO1, SO2 | 0 |  |
| SIAK1, SIAK2 | 0 |  |
| HA0, HA1 | 1 | connect to VDD or GND |
| $\overline{\mathrm{HCS}}$ | 1 | connect to VDD |
| $\overline{\text { HRD }}$, $\overline{\text { HWR }}$ | 1 |  |
| $\overline{\text { HRE, }} \overline{\text { HWE }}$ | 0 | open |
| HDO - HD7 ${ }^{\text {Note } 2}$ | 1/0 | connect to VDD or GND, via a resistor |
| P0-P3 | 1/0 |  |
| ID0-ID31 | 1/0 |  |
| IA0-IA15 | 0 | open |
| $\overline{\text { PWR }}$ | 0 |  |
| TCK | 1 | connect to GND, via a resistor |
| TDO, TICE | 0 | open |
| TMS, TDI | 1 | open(pull-up internally) |
| CLKOUT | 0 | open |

Notes 1. Can leave open, if no access to external data memory is executed in the whole of program.
But in the HALT mode when the current consumption is reduced, connect a pin as recommended connection.
2. Can leave open, if $\overline{\mathrm{HCS}}, \overline{\mathrm{HRD}}, \overline{\mathrm{HWR}}$ are fixed to high level. But in the HALT mode when the current consumption is reduced, connect a pin as recommended connection.

Remark I: Input pin, O: Output pin, I/O: Input/Output pin

## 2. FUNCTIONS

### 2.1 Pipeline Processing

This section describes the $\mu$ PD77016 pipeline processing.

### 2.1.1 Outline

The $\mu$ PD77016 basic operations are executed in following 3 -stage pipeline.
(1) instruction fetch; if
(2) Instruction decoding; id
(3) execution; ex

When the $\mu$ PD77016 operates a result of a instruction just executed before, the data is input to ALU in parallel with written back to general registers. Pipeline processing actualizes programming without delay time to execute instructions and write back data. Three successive instructions and their processing timing are shown below.

## Pipeline Processing Timing



### 2.1.2 Instructions with Delay

The following instructions have delay time in execution.
(1) Instructions to control interrupt

2 instruction cycles have been taken between instruction fetch and execution.
(2) Inter-register transfer instructions and immediate data set instructions

When data is set in data pointer, it needs 2 instruction cycles before the data is valid.

### 2.2 Program Control Unit

Program control unit controls not only count up of program counter in normal operation, but loop, repeat, branch, halt and interrupt.

In addition to loop stack of loop 4 level and program stack of 15 level, software stack can be used for multiloop and multi-interrupt/subroutine call.

The $\mu$ PD77016 has external 4 interruptions and internal 6 interruptions from peripheral, and specifies interrupt enable or disable independently.

The HALT instruction causes the $\mu$ PD77016 to place in low power standby mode.
When the HALT instruction is executed, power consumption decreases. HALT mode is released by interrupt input or hardware reset input. It takes several system clock to recover.

### 2.3 Operation Unit

Operation unit consists of the following five parts.

- 40 bits general register $\times 8$ for data load/store and input/output of operation data
-16 bits $\times 16$ bits +40 bits $\rightarrow 40$ bits multiply accumulator
-40 bits Data ALU
- 40 bits barrel shifter
- SAC: shifter and count circuit.

Standard word length is 40 bits to make overflow check and adjustment easy, and to accumulate the result of 16 bits $\times 16$ bits multiplication correctly.


### 2.3.1 General register (R0 to R7)

The $\mu$ PD77016 has eight 40 bits registers for operation input/output and load/store with memory. General register consists of the following three parts.

- ROL to R7L (bit 15 to bit 0)
- R0H to R7H (bit 31 to bit 16)
- R0E to R7E (bit 39 to bit 32)

But each of RnL, RnH and RnE are treated as a register in the following conditions.

## (1) General register used as 40 bits register

General registers are treated as 40 bits register, when they are used for the following aims.
(a) Operand for triminal operation (except for multiplier input)
(b) Operand for dyadic operation (except for multiplier and shift value)
(c) Operand for monadic operation (except for exponent instructions)
(d) Operand for operation
(e) Operand for conditional judge
(f) Destination for load instruction (with sign extension and 0 clear)

## (2) General register used as 32 bits register

Bit 31 to bit 0 of general register are treated as 32 bits register, when it is used for a operand of exponent instruction.
(3) General register used as 24 bits register

Bit 39 to bit 16 of general register are treated as 24 bits register, when it is used for destination with extended sign for a load/store instruction.
(4) General register used as 16 bits register

Bit 31 to bit 16 of general register are treated as 16 bits register, when it is used for the following aims.
(a) Signed operand for multiplier
(b) Source/destination for load/store instruction

Bit 15 to bit 0 of general register are treated as 16 bits register, when it is used for the following aims.
(c) Unsigned operand for multiplier
(d) Shift value for shift instruction
(e) Source/destination for load/store instruction
(f) Source/destination for inter-register transfer instruction
(g) Destination for immediate data set instruction
(f) Hardware loop times
(5) General register used as 8 bits register

Bit 39 to bit 32 of general register are treated as 8 bits register, when it is used for source/destination of load/ store instruction.

### 2.3.2 MAC: Multiply ACcumulator

MAC multiplies a pair of 16 bits data, and adds or subtract the result and 40 bits data. MAC outputs 40 bits data.

MAC operates three types of multiplication: signed data $\times$ signed data, signed data $\times$ unsigned data and unsigned data $\times$ unsigned data.

Result of multiplication and 40 bits data for addition can be added after 1 or 16 bits arithmetic shift right.

### 2.3.3 ALU: Arithmetic Logic Unit

ALU performs arithmetic operation and logic operation. Both input/output data are 40 bits.

### 2.3.4 BSFT: Barrel ShiFTer

BSFT performs shift right/left operation. Both input/output data are 40 bits. There are two types of shift right operations; arithmetic shift right which sign is extended, and logic shift right which is input 0 in MSB first.

### 2.3.5 SAC: Shifter And Count Circuit

SAC calculates and outputs shift value for normalization. SAC is input 32 bits data and outputs the 40 bits data. Then, bit 39 to bit 5 of output data is always 0 .

### 2.3.6 CJC: Condition Judge Circuit

CJC judges whether condition is true or false with 40 bits input data. A conditional instruction is executed when the result is true, and not executed when the result is false.

### 2.4 Memory

The $\mu$ PD77016 has one instruction memory area ( 64 K words $\times 32$ bits) and two data memory areas ( 64 K words $\times 16$ bits each). It adopts Harvard-type architecture, with instruction memory area and data memory areas separated.

The $\mu$ PD77016 has 2 sets of data addressing units, which are dedicated for addressing data memory area. Each addressing unit consists of four data pointers, four index registers, a modulo register and addressing ALU. Memory areas are shown below.

X memory area addresses are specified by DP0 to DP3, and Y memory area addresses are specified by DP4 to DP7. After memory access, DPn (with the same subscript), can be modified by DNn value. Modulo operation is performed with DMX for DP0 to DP3, with DMY for DP4 to DP7.


Caution When any data is accessed or stored to system address, normal operation of the $\mu$ PD77016 is not assured.

### 2.4.1 Instruction RAM Outline

The $\mu$ PD77016 has an instruction RAM ( 1.5 words $\times 32$ bits). A system vector area is assigned to 64 words of the instruction RAM. Internal RAM is initialized and rewritten by boot program.

Additionally external memory expansion is available as the $\mu$ PD77016 has interface with the external instruction memory. When RAM is used as the external memory, it can be initialized and rewritten by boot program.

Boot up ROM contains the program loading instruction code to internal and external instruction RAM.
When the external instruction memory area is accessed, instruction cycle can be 2 or more by wait function.

### 2.4.2 Data Memory Outline

The $\mu$ PD77016 has two data memory areas ( 64 words $\times 16$ bits each) in $X$ and $Y$ memory areas.
Each memory areas consists of 2 K words $\times 16$ bits data RAM. Additionally, data memory expansion is available as the $\mu$ PD77016 has interface with the external data memory.

Each data memory area includes on-chip peripheral area which consists of 64 words.
When the external data memory area is accessed, instruction cycle can be 2 or more by wait function.

### 2.4.3 Data Memory Addressing

There are following two types of data memory addressing.

- Direct addressing

The address is specified in the instruction field.

- Indirect addressing

The address is specified by the data pointer (DP). DP can get a bit reverse before addressing. It can update the DP value after accessing data memory.

### 2.5 On-chip Peripheral Circuit

The $\mu$ PD77016 includes serial interface, host interface, general input/output ports and wait cycle registers. They are mapped in both $X$ and $Y$ memory areas, and are accessed as memory mapped I/O by the $\mu$ PD77016 CPU.

### 2.5.1 Serial Interface Outline

The $\mu$ PD77016 has 2 channel serial interfaces. Serial I/O clock must be provided from external. Frame length can be programmed independently to be 8 bits or 16 bits. MSB first or LSB first can also be selected. Data is input/output by hand shaking for an external device, and by interrupts, polling or wait function in internal.

### 2.5.2 Host Interface Outline

The $\mu$ PD77016 has 8 bits parallel ports as host interface to input/output data to and from host CPU and DMA controller. When an external device accesses host interface, HA0 and HA1 pins; which are host address input pins; specifies bit 15 to bit 8 and bit 7 to bit 0 . The $\mu$ PD77016 includes 3 registers consisting of 16 bits, which are dedicated for input data, output data and status. The $\mu$ PD77016 has three types of interface method for internal and external data; interrupts, polling and wait function.

### 2.5.3 General Input/output Ports Outline

General input/output ports consist of 4 bits. User can set each port as input or output. The $\mu$ PD77016 includes two registers. One is 4 bits register for input/output data, and the other is 16 bits for control.

### 2.5.4 Wait Cycle Register

The wait cycle registers consist of 16 bits. It is used to set wait cycle number when external memory is accessed. $0,1,3$, or 7 wait cycle can be set in every data area which is divided into 8, and in every $X$ and $Y$ memory area which is divided into 4.

When data area is accessed, wait cycle can be also set by $\overline{\text { WAIT }}$ pin.

## 3. INSTRUCTIONS

### 3.1 Outline

All $\mu$ PD77016 instructions are one-word instructions, consisting of 32 bits. And they are executed in 30 ns (min.) per instruction. There are following 9 instruction types.

## (1) Trinomial instructions

: specify the Acc operation. 3 of general registers are specified optionally as the operation object.

## (2) Dyadic operation instructions

: specify the Acc, ALU or shifter operation. 2 of general registers are specified optionally as the operation object. Some instructions can specify a general register and immediate data.
(3) Monadic operation instructions
: specify operations by ALU. 1 general register is specified optionally as the operation object.
(4) Load/store instructions
: transfer 16 bits data from memory to general registers, from general registers to memory and between general registers.
(5) Inter-register transfer instructions
: transfer data between general register and other registers.
(6) Immediate data set instructions
: set immediate data at general registers or each registers of address operation unit.
(7) Branch instructions
: specify the direction of the program flow.
(8) Hardware loop instructions
: specify times of instruction repeating.

## (9) Control Instructions

: specify the control program.

### 3.2 Instruction Set and Operation

An operation is written according to the rules for expressing. An expression of instructions having two or more descriptions can have only one selected.
(a) Expressions and selectable registers

Expression and selectable registers are shown as follows.

| Expression | Selectable registers |
| :---: | :---: |
| ro, ro', ro" | R0-R7 |
| rl, rl' | ROL - R7L |
| rh, rh' | ROH - R7H |
| re | R0E - R7E |
| reh | R0EH - R7EH |
| dp | DP0 - DP7 |
| dn | DN0 - DN7 |
| dm | DMX, DMY |
| dpx | DP0 - DP3 |
| dpy | DP4-DP7 |
| dpx_mod | DPn, DPn++, DPn--, DPn\#\#, DPn\%\%, !DPn\#\# ( $\mathrm{n}=0-3$ ) |
| dpy_mod | DPn, DPn++, DPn--, DPn\#\#, DPn\%\%, !DPn\#\# ( $\mathrm{n}=4-7$ ) |
| dp_imm | DPn\#\#imm ( $\mathrm{n}=0-7$ ) |
| *xxx | content of memory address $\times \times \times$ <br> Example When the content of DP0 register is 1000, *DP0 shows the content of memory address 1000. |

(b) Modifying data pointers

Data pointers are modified after memory access. The results are valid immediately after instruction execution.
It is impossible to modify without memory access.

| Description | Operation |
| :---: | :---: |
| DPn | No operation: DPn value does not change. |
| DPn++ | $\mathrm{DPn} \leftarrow \mathrm{DPn}+1$ |
| DPn-- | $\mathrm{DPn} \leftarrow \mathrm{DPn}-1$ |
| DPn\#\# | DPn $\leftarrow$ DPn + DNn: Adds DN0-DN7 corresponding to DP0-DP7 Example DPO $\leftarrow$ DPO + DNO |
| DPn\%\% | $(\mathrm{n}=0-3) \quad \mathrm{DPn}=((\mathrm{DPL}+\mathrm{DNn}) \bmod (\mathrm{DMX}+1))+\mathrm{DP}$ н |
|  | $(\mathrm{n}=4-7) \quad \mathrm{DPn}=((\mathrm{DP}\llcorner+\mathrm{DNn}) \bmod (\mathrm{DMY}+1))+\mathrm{DP}$ н |
| !DPn\#\# | Access memory after DPn value is bit-reversed After memory access, DPn $\leftarrow \mathrm{DPn}+\mathrm{DNn}$ |
| DPn\#\#imm | $\mathrm{DPn} \leftarrow \mathrm{LPn}+\mathrm{imm}$ |

(c) Concurrent processing instructions
shows concurrent processing instruction.

Instruction names are shown in abbreviation.

| TRI | $:$ Trinomial |
| :--- | :--- |
| DYAD | : Dyadic |
| MONAD | $:$ Monadic |
| TRANS | $:$ Inter-register transfer |
| IMM | : Immediate data set |
| BR | : Branch |
| LOOP | : Hardware loop |
| CTR | : Control |

(d) State of Overflow flag (OV)

The following marks show the $\mu$ PD77016 overflow flag state.

- Not affected
$\mathfrak{\imath}$ : 1 is set when the result of operation is overflow.

Caution If overflow does not occur after operation, OV is not reset, and keeps the state before operation.

|  | Name | Mnemonic | Operation | Concurrent Writing Processing |  |  |  |  |  |  |  |  | Flag <br> OV |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | TRI. | DYAD. | MONAD. | Load/ store | TRANS. | IMM. | BR. | LOOP. | CTL. |  |
| Trinomial | Multiply add | $\mathrm{ro}=\mathrm{ro}+\mathrm{rh} * \mathrm{rh}^{\prime}$ | $\mathrm{ro} \leftarrow \mathrm{ro}+\mathrm{rh} * \mathrm{rh}^{\prime}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | Multiply sub | $\mathrm{ro}=\mathrm{ro}-\mathrm{rh} * \mathrm{rh}^{\prime}$ | ro $\leftarrow$ ro-rh*rh' |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | Sign unsign Multiply add | $\mathrm{ro}=\mathrm{ro}+\mathrm{rh} * \mathrm{rl}$ <br> (rl should be a plus integral number.) | $\mathrm{ro} \leftarrow \mathrm{ro}+\mathrm{rh} * \mathrm{rl}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | Unsign unsign Multiply add | $\mathrm{ro}=\mathrm{ro}+\mathrm{rl} * \mathrm{rl}$ <br> (rl and rl' should be a plus integral number.) | $\mathrm{ro} \leftarrow \mathrm{ro}+\mathrm{rl} * \mathrm{rl}^{\prime}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | 1 bit shift Multiply add | $\mathrm{ro}=(\mathrm{ro} \gg 1)+\mathrm{rh} * \mathrm{rh}^{\prime}$ | $\mathrm{ro} \leftarrow \frac{\mathrm{ro}}{2}+\mathrm{rh} * \mathrm{rh}^{\prime}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | 16 bits shift Multiply add | $r \mathrm{r}=(\mathrm{ro>>} 16)+\mathrm{rh} * \mathrm{rh}^{\prime}$ | $\mathrm{ro} \leftarrow \frac{\mathrm{ro}}{2^{16}}+\mathrm{rh} * \mathrm{rh}^{\prime}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | - |
| Dyadic | Multiply | ro=rh*rh' | $\mathrm{ro} \leftarrow \mathrm{rh} * \mathrm{rh}$ ' |  |  |  | $\bigcirc$ |  |  |  |  |  | O |
|  | Add | ro" $=$ ro + ro' | $\mathrm{ro}{ }^{\prime} \leftarrow \mathrm{ro}+\mathrm{ro}{ }^{\prime}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | Immediate add | ro' $=$ ro+imm | ro' $\leftarrow$ ro+imm (imm 1) |  |  |  |  |  |  |  |  |  | $\downarrow$ |
|  | Sub | ro" $=$ ro-ro' | ro" $\leftarrow$ ro-ro' |  |  |  | $\bigcirc$ |  |  |  |  |  | $\downarrow$ |
|  | Immediate sub | ro' $=$ ro-imm | ro ' $\leftarrow$ ro-imm ( imm 1$)$ |  |  |  |  |  |  |  |  |  | $\downarrow$ |
|  | Arithmetic right shift | ro'=ro SRA rl | ro ' $\leftarrow \mathrm{ro} \mathrm{>>} \mathrm{rl}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | - |
|  | Immediate arithmetic right shift | ro'=ro SRA imm | ro' $\leftarrow \mathrm{ro} \gg \mathrm{imm}$ |  |  |  |  |  |  |  |  |  | - |
|  | Logic right shift | ro'=ro SRL rl | ro ' $\leftarrow \mathrm{ro} \mathrm{>>} \mathrm{rl}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | O |
|  | Immediate Logic right shift | ro'=ro SRL imm | ro' $\leftarrow$ ro >> imm |  |  |  |  |  |  |  |  |  | - |
|  | Logic left shift | ro'=ro SLL rl | $\mathrm{ro}{ }^{\prime} \leftarrow \mathrm{ro} \ll \mathrm{rl}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | - |
|  | Immediate logic left shift | ro'=ro SLL imm | ro ' $\leftarrow \mathrm{ro} \ll \mathrm{imm}$ |  |  |  |  |  |  |  |  |  | - |


|  | Name | Mnemonic | Operation | Concurrent Writing Processing |  |  |  |  |  |  |  |  | $\begin{array}{\|c\|} \hline \text { Flag } \\ \hline \text { OV } \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | TRI. | DYAD. | MONAD. | Load/ <br> store | TRANS. | IMM. | BR. | LOOP. | CTL. |  |
| Dyadic | And | ro" = ro \& ro' | ro" $\leftarrow$ ro \& ro' |  |  |  | $\bigcirc$ |  |  |  |  |  | $\bigcirc$ |
|  | Immediate and | $\mathrm{ro}^{\prime}=$ ro \& imm | $\mathrm{ro} ' \leftarrow \mathrm{ro}$ \& imm |  |  |  |  |  |  |  |  |  | $\bigcirc$ |
|  | Or | ro" = ro \| ro' | $\mathrm{ro}{ }^{\prime} \leftarrow \mathrm{ro} \mid \mathrm{ro}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | - |
|  | Immediate or | ro' = ro \| imm | $\mathrm{ro}{ }^{\prime} \leftarrow \mathrm{ro} \mid \mathrm{imm}$ |  |  |  |  |  |  |  |  |  | $\bigcirc$ |
|  | Exclusive or | ro" = ro ^ ro' | $\mathrm{ro}{ }^{\prime} \leftarrow \mathrm{ro}^{\wedge} \mathrm{ro}{ }^{\prime}$ |  |  |  | $\bigcirc$ |  |  |  |  |  | $\bigcirc$ |
|  | Immediate exclusive or | $\mathrm{ro}=\mathrm{ra}^{\wedge} \mathrm{imm}$ | $\mathrm{ro} \leftarrow \mathrm{ro} \wedge \mathrm{imm}$ |  |  |  |  |  |  |  |  |  | - |
|  | Less than | ro" = LT(ro, ro') | ```if(ro<ro') {ro" \leftarrow 0x0000000001} else {ro" \leftarrow 0x0000000000}``` |  |  |  | $\bigcirc$ |  |  |  |  |  | - |
| Monadic | Clear | CLR(ro) | $\mathrm{ro} \leftarrow 0 \times 0000000000$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\bigcirc$ |
|  | Increment | ro' = ro + 1 | $\mathrm{ro}{ }^{\prime} \leftarrow \mathrm{ro}+1$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\downarrow$ |
|  | Decrement | ro' = ro-1 | ro ' $\leftarrow \mathrm{ro}-1$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\downarrow$ |
|  | Absolute | ro' = ABS (ro) | $\begin{aligned} & \text { if }(\mathrm{ro}<0) \\ & \quad\{\mathrm{ro'} \leftarrow-\mathrm{ro}\} \\ & \text { else }\left\{\mathrm{ro} \mathrm{o}^{\prime} \leftarrow \mathrm{ro}\right\} \end{aligned}$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\downarrow$ |
|  | One's complement | ro' = ${ }^{\text {ro }}$ | ro' $\leftarrow{ }^{\text {~ro }}$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\bigcirc$ |
|  | Two's complement | ro' = -ro | ro' $\leftarrow-\mathrm{ro}$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\downarrow$ |
|  | Clip | ro' = CLIP (ro) | ```if (ro>0x007FFFFFFF) {ro' \leftarrow0x007FFFFFFFF] else if,(ro<0xFF80000000) {ro' \leftarrow0xFF80000000} else {ro' }\leftarrow\textrm{ro}``` |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\downarrow$ |
|  | Round | ro' = ROUND (ro) | ```if (ro>0x007FFF0000) {ro' \leftarrow0x007FFF0000} else if, (ro>0xFF80000000) {ro' }\leftarrow0\timesFF80000000 else {ro' } (ro + 0x8000) & 0xFFFFFF50000}``` |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\downarrow$ |
|  | Exponent | ro' = EXP (ro) | $\mathrm{ro}^{\prime} \leftarrow \log _{2} \quad\left(\frac{1}{\mathrm{ro}}\right)$ |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\bigcirc$ |
|  | Substitution | $\mathrm{ro}=\mathrm{ro}$ | ro' $\leftarrow$ ro |  |  |  | $\bigcirc$ |  |  |  |  | $\bigcirc$ | $\bigcirc$ |



Note 1. One or both of a mnemonic pair can be written.
2. After execution of load/store, data is modified by mod.
3. One of following mnemonic should be selected: dest, dest' $=\{r o, r e h, r e, r h, r l\}$, source, source' $=\{r e, r h, r l\}$.

|  | Name | Mnemonic | Operation | Concurrent Writing Processing |  |  |  |  |  |  |  |  | $\begin{array}{\|l\|} \hline \text { Flag } \\ \hline \text { OV } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | TRI. | DYAD. | MONAD. | Load/ store | TRANS. | IMM. | BR. | LOOP. | CTL. |  |
| Load/store | Direct addressing <br> load/store Note 1. | dest $=*$ addr | dest $\leftarrow *$ addr |  |  |  |  |  |  |  |  |  |  |
|  |  | *addr = source | *addr $\leftarrow$ source |  |  |  |  |  |  |  |  |  |  |
|  | Immediate index <br> load/store Note 2. | dest $=$ *dp_imm | dest $\leftarrow *$ dp |  |  |  |  |  |  |  |  |  |  |
|  |  | *dp_imm = source | *dp $\leftarrow$ source |  |  |  |  |  |  |  |  |  |  |
| Inter-register transfer | Inter-register transfer Note 3. | dest $=\mathrm{rl}$ | dest $\leftarrow \mathrm{rl}$ |  |  |  |  |  |  |  |  |  |  |
|  |  | $\mathrm{rl}=$ source | $\mathrm{rl} \leftarrow$ source |  |  |  |  |  |  |  |  |  |  |
| Immediate data set | Immediate data set | $\begin{aligned} & \mathrm{rl}=\mathrm{imm} \\ & \text { (provided imm = 0-0xFFFF) } \end{aligned}$ | $\mathrm{rl} \leftarrow \mathrm{imm}$ |  |  |  |  |  |  |  |  |  |  |
|  |  | $\begin{aligned} & \mathrm{dp}=\mathrm{imm} \\ & \text { (provided imm }=0-0 \times F F F F \text { ) } \end{aligned}$ | $\mathrm{dp} \leftarrow \mathrm{imm}$ |  |  |  |  |  |  |  |  |  |  |
|  |  | $\begin{aligned} & \mathrm{dn}=\mathrm{imm} \\ & \text { (provided imm }=0-0 x F F F F \text { ) } \end{aligned}$ | $\mathrm{dn} \leftarrow \mathrm{imm}$ |  |  |  |  |  |  |  |  |  |  |
|  |  | $\begin{aligned} & \mathrm{dm}=\mathrm{imm} \\ & \text { (provided imm = 1-0xFFFF) } \end{aligned}$ | $\mathrm{dm} \leftarrow \mathrm{imm}$ |  |  |  |  |  |  |  |  |  |  |

Note 1. One of following mnemonic should be selected: dest $=\{r o, r e h, r e, r h, r l\}$, source $=\{r e, r h, r l\}$, add $=\left\{\begin{array}{l}0: X-0 x F F F F: X \text { memory } \\ 0: Y-0 x F F F F: Y \text { memory }\end{array}\right\}$.
2. One of following mnemonic should be selected: dest $=\{r o, r e h, r e, r h, r l\}$, source $=\{r e, r h, r l\}$.
3. Any register except general registers should be selected as dest or source.

|  | Name | Mnemonic | Operation | Concurrent Writing Processing |  |  |  |  |  |  |  |  | $\begin{array}{\|l\|} \hline \text { Flag } \\ \hline \text { OV } \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | TRI. | DYAD. | MONAD. | Load/ <br> store | TRANS. | IMM. | BR. | LOOP. | CTL. |  |
| Branch | Jump | JMP imm | $\mathrm{PC} \leftarrow \mathrm{imm}$ |  |  |  |  |  |  |  |  | $\bigcirc$ | $\bigcirc$ |
|  | Inter-register indirect jump | JMP dp | $\mathrm{PC} \leftarrow \mathrm{dp}$ |  |  |  |  |  |  |  |  | $\bigcirc$ | $\bigcirc$ |
|  | Subroutine call | CALL imm | $\begin{aligned} & \mathrm{SP} \leftarrow \mathrm{SP}+1 \\ & \mathrm{STK} \leftarrow \mathrm{PC}+ \\ & \mathrm{PC} \leftarrow \mathrm{imm} \end{aligned}$ |  |  |  |  |  |  |  |  | $\bigcirc$ | - |
|  | Inter-register indirect subroutine call | CALL dp | $\begin{aligned} & S P \leftarrow S P+1 \\ & S T K \leftarrow P C+1 \\ & P C \leftarrow d p \end{aligned}$ |  |  |  |  |  |  |  |  | $\bigcirc$ | O |
|  | Return | RET | $\begin{aligned} & \mathrm{PC} \leftarrow \mathrm{STK} \\ & \mathrm{SP} \leftarrow \mathrm{SP}-1 \end{aligned}$ |  |  |  |  |  |  |  |  | $\bigcirc$ | $\bigcirc$ |
|  | Return from interrupt | RETI | $\mathrm{PC} \leftarrow \mathrm{STK}$ <br> STK $\leftarrow \mathrm{SP}-1$ Restore the interrupt enable flag |  |  |  |  |  |  |  |  | $\bigcirc$ |  |
| Hardware loop | Repeat | REP count | start $R C \leftarrow$ count <br> repeat $R F \leftarrow 0$ <br>  $P C \leftarrow P C$ <br> end $R C \leftarrow R C-1$ <br>  $P C \leftarrow P C+1$ <br>  $R F \leftarrow 1$ |  |  |  |  |  |  |  |  |  |  |
|  | Loop | LOOP count <br> (Mnemonics more than two lines) | start $R C \leftarrow$ count <br> repeat $R F \leftarrow 0$ <br>  $P C \leftarrow P C$ <br> end $R C \leftarrow R C-1$ <br>  $P C \leftarrow P C+1$ <br>  $R F \leftarrow 1$ |  |  |  |  |  |  |  |  |  | - |
|  | Loop pop | LPOP | $\begin{aligned} & \mathrm{LC} \leftarrow \text { LSR3 } \\ & \mathrm{LE} \leftarrow \mathrm{LSR} 2 \\ & \mathrm{LS} \leftarrow \mathrm{LSR} 1 \\ & \mathrm{LSP} \leftarrow \mathrm{LSP}-1 \end{aligned}$ |  |  |  |  |  |  |  |  |  | - |
| Control | No operation | NOP | $\mathrm{PC} \leftarrow \mathrm{PC}+1$ |  |  |  |  |  |  |  |  |  | - |
|  | Halt | HALT | CPU stop |  |  |  |  |  |  |  |  |  | $\bigcirc$ |
|  | If | IF (ro cond) | Conditional judge |  |  | $\bigcirc$ |  | $\bigcirc$ |  | $\bigcirc$ |  |  | $\bigcirc$ |
|  | Forget interrupt | FINT | Forget interrupt request |  |  |  |  |  |  |  |  |  | $\bigcirc$ |

## 4. ELECTRICAL SPECIFICATIONS

Absolute maximum ratings ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ )

| Parameters | Symbol | Conditions | Ratings | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Power supply voltage | Vdd |  | -0.5 to +7.0 | V |
| Input voltage | V |  | -0.5 to $V_{D D}+0.5$ | V |
| Output voltage | Vo |  | -0.5 to $\mathrm{V}_{\mathrm{DD}}+0.5$ | V |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ |  | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Operating ambient temperature | TA |  | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |

## Caution Exposure to Absolute Maximum Ratings for extended periods may affect device reliability; exceeding the ratings could cause permanent damage. The parameters apply independently. The device should be operated within the limits specified under DC and AC Characteristics.

Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=0 \mathrm{~V}$ )

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input capacitance | CI | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}$ <br> Unmeasured pins returned to 0 V. |  |  | 15 | pF |
| Output capacitance | Co |  |  |  | 15 | pF |

DC characteristics ( $\mathrm{T}_{\mathrm{A}}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{VDD}=5 \mathrm{~V} \pm 10 \%$ )

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| High level input voltage | VIH | $\begin{aligned} & \text { except for } \overline{\text { RESET }}, \frac{\text { CLKIN, }}{} \frac{\text { INT1 }}{\overline{\text { INT4 }}, \overline{\text { INAIT, }}, \overline{\text { HCS }},} \end{aligned}$ | 2.2 |  | $V_{D D}+0.5$ | V |
|  | VIHC | $\overline{\text { RESET }} \overline{\text { INT1 }}-\overline{\mathrm{NT} 4}$, $\overline{\text { WAIT, }}$ HCS, $\overline{\text { HRD, }}$ HWR, TCK, TDI, TMS | 0.7Vdo |  | $V_{D D}+0.5$ | V |
| Low level input voltage | VIL | $\begin{aligned} & \text { except for } \overline{\text { RESET }}, \text { CLKIN, } \\ & \frac{\text { INT1 }}{\overline{\text { HRD }}}-\overline{\text { INT4 }}, \overline{\text { HAR }}, \text { TCK, TDI, TMS } \end{aligned}$ | -0.5 |  | +0.8 | V |
|  | VILC | $\overline{\text { RESET }}, \overline{\text { INT1 }}-\overline{\text { INT4 }}, \overline{\text { WAIT }}, \overline{H C S}$, HRD, $\overline{H W R}$, TCK, TDI, TMS | -0.5 |  | 0.2 VDD | V |
| High level CLKIN voltage | VIHX |  | 0.8Vdd |  | $V_{D D}+0.5$ | V |
| Low level CLKIN voltage | VILX |  | -0.5 |  | 0.2 V DD | V |
| High level output voltage | V OH | I он $=-2.5 \mathrm{~mA}$ | 0.8Vdd |  |  | V |
| Low level output voltage | Vol | $\mathrm{loL}=2.5 \mathrm{~mA}$ |  |  | 0.4 | V |
| Low level input current | IIL | TDI, TMS, $\mathrm{V}_{\mathrm{I}}=0 \mathrm{~V}$ |  |  | -400 | $\mu \mathrm{A}$ |
| High level input leak current | ILit | $\mathrm{V}_{1}=\mathrm{V}_{\text {D }}$ |  |  | 10 | $\mu \mathrm{A}$ |
| Low level input leak current | ILIL | except for TDI, TMS, $\mathrm{V}^{\prime}=0 \mathrm{~V}$ |  |  | -10 | $\mu \mathrm{A}$ |
| Power supply current | Ido Note | Active mode, tccl $=15 \mathrm{~ns}$ $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$, no load |  | 140 | 300 | mA |
|  | IdDh | HALT mode, $\mathrm{tccl}=15 \mathrm{~ns}$, $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$, no load |  | 80 |  | mA |
|  | Idds | $\begin{aligned} & \text { CLKIN }=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V} \text {, no load } \end{aligned}$ |  | 10 |  | $\mu \mathrm{A}$ |

Note The TYP. value is measured when a general program is executed, and $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ conditon. The MAX. value is measured when a special program that max. switching required is executed, and $V_{D D}=5.5 \mathrm{~V}$ condition.

Measurement Standards Common to Switching Characteristics

CLKIN


Input (except for CLKIN)


Output


AC Characteristics ( $\mathrm{T}_{\mathrm{A}}=-40$ to $+85^{\circ} \mathrm{C}, \mathrm{VdD}=5 \mathrm{~V} \pm 10 \%, \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ )

## Clock

Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. |
| :--- | :--- | :--- | :--- | :--- | :--- |
| CLKIN cycle time | $\mathrm{t}_{\mathrm{ccl}}$ |  | 15 |  |  |
| CLKIN high level width | $\mathrm{t}_{\mathrm{wClH}}$ |  | 6.75 |  |  |
| CLKIN low level width | $\mathrm{t}_{\mathrm{wCIL}}$ |  | 600 | ns |  |
| CLKIN rise/fall time | $\mathrm{t}_{\mathrm{fcl}}$ |  |  | ns |  |

## Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. |
| :--- | :--- | :--- | :--- | :--- | :--- |
| CLKOUT cycle time | tcco |  |  | $2 t_{c c l}$ |  |
| CLKOUT level width | twco |  | $t_{c c l}-3$ |  |  |
| CLKOUT rise/fall time | trico |  |  | $n s$ |  |

## Reset, Interrupt

## Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { RESET }}$ low level width | tw(RL) |  | 4 tcco |  |  | ns |
| $\overline{\text { RESET }}$ recovery time | trec(R) |  | 4 tcco |  |  | ns |
| $\overline{\text { INT1-INT4 }}$ low level width | $\mathrm{tw}_{\text {w (INTL) }}$ |  | 3 tcco |  |  | ns |
| $\overline{\text { INT1-INT4 }}$ recovery time | trec(INT) |  | 3 tcco |  |  | ns |

## Clock Input/Output Timing



## Reset, Interrupt Timing



Interrupt Timing
$\overline{\text { INT1 }}-\overline{\text { INT4 }}$


## External Data Memory Access

## Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Read data setup time | tsuDDRD |  | 14 |  |  |
| Read data hold time | thDDRD |  | 0 |  |  |
| $\overline{\text { WAIT }}$ setup time | tsuwA |  | 8 |  |  |
| $\overline{\text { WAIT }}$ hold time | thwa |  | 0 |  |  |

## Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address output delay time | tddA |  | 0 |  | 6 | ns |
| $\overline{\mathrm{MRD}}$ output delay time | tddr |  | 0 |  | 8 | ns |
| $\overline{\mathrm{MRD}}$ hold time | thDR |  | 0 |  | 8 | ns |
| Write data setup time | tsDDw |  | $\begin{aligned} & \mathrm{tcCl}_{\mathrm{cl}}+\mathrm{t}_{\mathrm{wClIH}}^{-} \\ & 15+\mathrm{t}_{\mathrm{cD}} \text { Note } \end{aligned}$ |  |  | ns |
| Write data output hold time | thDowd |  | 0 |  | 15 | ns |
| $\overline{\mathrm{MWR}}$ output delay time | tadw |  | $t_{\text {wCIH }}$ - 4 |  |  | ns |
| $\overline{\mathrm{MWR}}$ setup time | tsuDW |  | $t_{\text {wCIL }}-4$ |  |  | ns |
| $\overline{\mathrm{MWR}}$ low level width | twDWL |  | $\begin{gathered} \mathrm{tcCl}^{-4} \\ +\mathrm{tcDw}^{\text {Note }} \end{gathered}$ |  |  | ns |
| $\overline{\mathrm{MWR}}$ high level width | twDwh |  | tccl-4 |  |  | ns |

Note tcDw: Data wait cycle

External Data Memory Read Operation


External Data Memory Write Operation


## External Instruction Memory Access

## Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| ID setup time (to CLKOUT $\uparrow$ ) | tsulD |  | 14 |  |  | ns |
| ID hold time (to CLKOUT $\uparrow$ ) | thiD |  | 0 |  |  | ns |

## Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IA output delay time | tdIA |  |  | 10 |  | ns |
| IA hold time | thiA |  | 0 |  | 6 | ns |
| ID write setup time | tsIDW |  | $\begin{gathered} \mathrm{t}_{\mathrm{cCl}}+\mathrm{t}_{\mathrm{wCIH}} \\ -15 \end{gathered}$ |  |  | ns |
| ID write hold time | thidw |  | 0 |  |  | ns |
| $\overline{\text { PWR }}$ output delay time | talw |  |  | 10 |  | ns |
| Address $\rightarrow \overline{\text { PWR setup time }}$ | td (IAV-IWV) |  | $\begin{aligned} t_{c \mathrm{Cl}} & +t_{\mathrm{wClH}} \\ & -4 \end{aligned}$ |  |  | ns |
| $\overline{\text { PWR }}$ setup time | tsulw |  | $t_{\text {wCIL }}-4$ |  |  | ns |
| $\overline{\text { PWR }}$ width | twiw |  | $\begin{gathered} \mathrm{tcco}-4 \\ +\mathrm{t}_{\mathrm{c} ı \mathrm{w}} \end{gathered}$ |  |  | ns |

Remark tciw: Instruction wait cycle

## External Instruction Memory Read Operation



External Instruction Memory Write Operation


## Bus Arbitration

## Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| HOLDRQ setup time | tsuHRQ |  | 8 |  |  | ns |
| HOLDRQ hold time | thHRQ |  | 0 |  |  | ns |

## Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { BSTB }}$ hold time | thbs |  | 0 |  | 6 | ns |
| $\overline{\text { BSTB }}$ output delay time | tdBS |  | 0 |  | 6 | ns |
| HOLDAK output delay time | tdHAK |  | 0 |  | 6 | ns |
| HOLDAK hold time | thHAK |  | 0 |  | 6 | ns |
| Data hold time when bus arbitration | th (BS-D) |  |  |  | 15 | ns |
| Data valid time after bus arbitration | $\mathrm{tv}_{\text {( }}$ (SS-D) |  |  |  | 15 | ns |

## Bus Arbitration Timing (Bus idle)




Bus Arbitration Timing (Bus slave)


Bus idle


## Serial Interface

## Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SCK input cycle time | tcsc |  | 2 tcco |  |  | ns |
| SCK input high/low level width | twsc |  | 25 |  |  | ns |
| SCK input rise/fall time | trisc |  |  | 3 | 20 | ns |
| SOEN recovery time | trecsoe |  | 10 |  |  | ns |
| SOEN hold time | thsoe |  | 5 |  |  | ns |
| SIEN recovery time | trecSIE |  | 10 |  |  | ns |
| SIEN hold time | thSIE |  | 5 |  |  | ns |
| SI setup time | tsuSI |  | 10 |  |  | ns |
| SI hold time | thsi |  | 0 |  |  | ns |

## Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: |
| SORQ output delay time | tdsor |  | 0 |  |  | 30 |
| SORQ hold time | thsor |  | 0 |  | 30 |  |
| SO valid time | tvso |  | 0 |  | 30 | ns |
| SO hold time | thso |  |  |  | 60 | ns |
| SIAK output delay time | tasIA |  | 0 |  | 30 | ns |
| SIAK hold time | thsIA |  | 0 |  | 30 | ns |

## Notes for Serial Clock

Serial clock inputs SCK1 and SCK2 are sensitive to any kind of interfering signals (noise on power supply, induced voltage, etc.). Spurious signals can cause malfunction of the device. Special care for the serial clock design should be taken. Careful grounding, decoupling and short wiring of SCK1 and SCK2 are recommended. Intersection of SCK1 and SCK2 with other serial interface lines or close wiring to lines carrying high frequency signals or large changing currents should be avoided.

It considers for the serial clock to make a waveform stable especially about the rising and falling.


Example 1. good example Straight rising form and falling form


Example 2. no good example
It doesn't bound. It doesn't make noise one above another.


Example 3. no good example It doesn't make a stair stepping.

## Serial Output Timing 1

$\xrightarrow{Z}$



Serial Input Timing 1
$Z$



## Host Interface

Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{HRD}}$ delay time | tdHR |  | 0 |  |  | ns |
| $\overline{\mathrm{HRD}}$ width | twHR |  | 2 tcco |  |  | ns |
| $\overline{\mathrm{HCS}}, \mathrm{HAO}, \mathrm{HA} 1$ read hold time | thecar |  | 5 |  |  | ns |
| $\overline{\mathrm{HCS}}, \mathrm{HAO}, \mathrm{HA1}$ write hold time | thecaw |  | 5 |  |  | ns |
| $\overline{\text { HRD }}$, $\overline{\text { HWR }}$ recovery time | trechs |  | 2 tcco |  |  | ns |
| $\overline{\text { HWR }}$ delay time | tdHw |  | 0 |  |  | ns |
| $\overline{\mathrm{HWR}}$ width | twhw |  | 2 tcco |  |  | ns |
| $\overline{\text { HWR }}$ hold time | thHDw |  | 5 |  |  | ns |
| $\overline{\mathrm{HWR}}$ setup time | tsuHDW |  | 20 |  |  | ns |

Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HRE, HWE output delay time | tdHE |  |  |  | 30 | ns |
| HRE, HWE hold time | thene |  |  |  | 20 | ns |
| HRD valid time | tvHDR |  |  |  | 30 | ns |
| HRD hold time | thHDR |  | 0 |  |  | ns |



## Host Write Interface Timing



## General Input/Output Ports

## Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| Port input setup time | tsupl |  | 10 |  |  | ns |
| Port input hold time | thPI |  | 10 |  |  | ns |

Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| Port output delay time | tapo |  | 0 |  | 30 | ns |

## General Input/Output Ports Timing



Debugging Interface (JTAG)
Required Timing Condition

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCK cycle time | tctck |  | 4 tcco |  |  | ns |
| TCK high level width | twTCKH |  | 50 |  |  | $n s$ |
| TCK low level width | twTCKL |  | 50 |  |  | $n s$ |
| TCK rise/fall time | tritck |  |  | 3 | 20 | ns |
| TMS, TDI setup time | tsuDI |  | 10 |  |  | ns |
| TMS, TDI hold time | thDI |  | 15 |  |  | ns |
| Input pin setup time | tsuJIn |  | 10 |  |  | ns |
| Input pin hold time | thJIN |  | 0 |  |  | ns |

## Switching Characteristics

| Parameters | Symbol | Conditions | MIN. | TYP. | MAX. |
| :--- | :--- | :--- | :--- | :---: | :---: |
| TDO output delay time | tdDo |  | 0 |  |  |
| Output pin output delay time | tdjout |  |  | 30 | ns |

## Debugging Interface Timing



Remark For the details of JTAG, refer to "IEEE1149.1."

## 5. PACKAGE DRAWING

## 160 PIN PLASTIC QFP (FINE PITCH) ( $\square 24$ )



NOTE
Each lead centerline is located within 0.10 mm ( 0.004 inch ) of its true position (T.P.) at maximum material condition.

| ITEM | MILLIMETERS | INCHES |
| :---: | :---: | :---: |
| A | $26.0 \pm 0.2$ | $1.024_{-0.009}^{+0.008}$ |
| B | $24.0 \pm 0.2$ | $0.945 \pm 0.008$ |
| C | $24.0 \pm 0.2$ | $0.945 \pm 0.008$ |
| D | $26.0 \pm 0.2$ | $1.024_{-0.009}^{+0.008}$ |
| F | 2.25 | 0.089 |
| G | 2.25 | 0.089 |
| H | $0.22_{-0.04}^{+0.05}$ | $0.009 \pm 0.002$ |
| I | 0.10 | 0.004 |
| $J$ | 0.5 (T.P.) | 0.020 (T.P.) |
| K | $1.0 \pm 0.2$ | $0.039_{-0.008}^{+0.009}$ |
| L | $0.5 \pm 0.2$ | $0.020_{-0.009}^{+0.008}$ |
| M | $0.17_{-0.07}^{+0.03}$ | $0.007_{-0.003}^{+0.001}$ |
| N | 0.10 | 0.004 |
| P | 2.7 | 0.106 |
| Q | $0.4 \pm 0.1$ | $0.016_{-0.005}^{+0.004}$ |
| R | $3^{\circ}+7^{\circ}{ }^{\circ}$ | $\begin{aligned} & 3^{\circ}+7^{\circ}{ }^{\circ} \end{aligned}$ |
| S | 3.3 MAX. | 0.130 MAX . |
| S160GM-50-JMD,KMD |  |  |

## 6. RECOMMENDED SOLDERING CONDITIONS

When soldering this product, it is highly recommended to observe the conditions as shown below. If other soldering processes are used, or if the soldering is performed under different conditions, please make sure to consult with our sales offices.

For more details, refer to our document "SEMICONDUCTOR DEVICE MOUNTING TECHNOLOGY MANUAL" (C10535E).

## Surface mount device

$\mu$ PD77016GM-KMD: 160-pin plastic QFP (FINE PITCH) ( $24 \times 24 \mathrm{~mm}$ )

| Process | Conditions | Symbol |
| :---: | :---: | :---: |
| Infrared ray reflow | Peak temperature: $235^{\circ} \mathrm{C}$ or below (Package surface temperature), <br> Reflow time: 30 seconds or less (at $210^{\circ} \mathrm{C}$ or higher), <br> Maximum number of reflow processes: 1 time, <br> Exposure limit ${ }^{\text {Note }}$ : 7 days ( 20 hours pre-baking is required at $125^{\circ} \mathrm{C}$ afterwards). | IR35-207-1 |
| VPS | Peak temperature: $215^{\circ} \mathrm{C}$ or below (Package surface temperature), <br> Reflow time: 40 seconds or less (at $200^{\circ} \mathrm{C}$ or higher), <br> Maximum number of reflow processes: 1 time, <br> Exposure limit ${ }^{\text {Note }: ~} 7$ days ( 20 hours pre-baking is required at $125^{\circ} \mathrm{C}$ afterwards). | VP15-207-1 |
| Partial heating method | Pin temperature: $300^{\circ} \mathrm{C}$ or below, <br> Heat time: 3 seconds or less (Per each side of the device). | - |

Note Maximum allowable time from taking the soldering package out of dry pack to soldering.
Storage conditions: $25^{\circ} \mathrm{C}$ and relative humidity of $65 \%$ or less.

Caution Apply only one kind of soldering condition to a device, except for "partial heating method", or the device will be damaged by heat stress.
[MEMO]
[MEMO]
[MEMO]

## NOTES FOR CMOS DEVICES

## (1) PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

Note: Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it.

## (2) HANDLING OF UNUSED INPUT PINS FOR CMOS

Note: No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS device behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to Vdd or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices.

## (3) STATUS BEFORE INITIALIZATION OF MOS DEVICES

Note: Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function.

## [MEMO]

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.
NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others.
While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.
NEC devices are classified into the following three quality grades:
"Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application.

Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots
Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)
Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.
The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance.
Anti-radioactive design is not implemented in this product.

