# PRELIMINARY

# **4-BIT SINGLE CHIP MICRO CONTROLLER**

#### GENERAL DESCRIPTION

The **NJU3502** is the C-MOS 4-bit Single Chip Micro Controller consisting of the 4-bit CPU Core, Input / Output Selectable I/O ports, Program ROM, Data RAM, Timer, 8bit Serial Interface, and Oscillator Circuit (CR or Ceramic or X'tal). It realizes the control for home appliances or toys by only few external components.

The **NJU3502** is suitable for battery operated appliances because of low operating current, wide operating voltage range, and STANDBY function(HALT mode).

# FEATURES

- Internal Program ROM 1024 X 8 bits
- Internal Data RAM 64 X 4 bits
- Input / Output Port 17 lines(MAX)
  - 10 lines Input / Output direction of each bit is selected by the mask option.
    4 lines Input / Output direction of 4-bit lines group can be changed by the program.
  - Additional functions by the mask option. External Interrupt Terminal : EXTI/PE0 Serial Interface Terminals
  - : SDO/PF0, SDI(O)/PF1 High Output-Current terminal (4 lines)
  - N-Channel FET Open Drain Type  $(I_{OL})$ 
    - 15mA at V<sub>DD</sub>=5V
    - Instruction Set 59 instructions
- Subroutine Nesting 8 levels
- Pulse Edge Detector The rising or falling edge of a pulse is selected by the mask option.
- Instruction Executing Time 6/fosc sec
- Operating Frequency Range 30kHz 4MHz
- Internal Oscillator
  - CR, or Ceramic, or X'tal oscillation and External clock input
- STANDBY function (HALT mode)
- Wide operating voltage range 2.4V 5.5V
- 8-bit Serial Input / Output port
- Timer (8-bit re-load type timer)
- Interrupt factor 3(external, timer, serial Input / Output)
- C-MOS technology
- Package outline SDIP / DMP24



PACKAGE OUTLINE

NJU3502L

NJU3502M

Smallana



26/Mar/2001

# NJU3502

# BLOCK DIAGRAM



# ■ TERMINAL DESCRIPTION 1

| No. | SYMBOL          | INPUT/OUTPUT   | FUNCTION                                                                  |  |  |
|-----|-----------------|----------------|---------------------------------------------------------------------------|--|--|
| 22  | PC0             |                | 4-bit Input / Output PORTC.                                               |  |  |
| 23  | PC1             | INPUT/OUTPUT   |                                                                           |  |  |
| 1   | PC2             | INPUT/OUTPUT   | mask option.                                                              |  |  |
| 2   | PC3             | INPUT/OUTPUT   | C-MOS Input Terminal with Pull-up Resistance(IA)                          |  |  |
| ~   | 100             |                | C-MOS Input Terminal(IC)                                                  |  |  |
|     |                 |                | C-MOS Output Terminal(OB)                                                 |  |  |
| 3   | PD0             |                | 2-bit Input / Output PORTD.                                               |  |  |
| 4   | PD1             |                | Selects a terminal circuit for each port from follows by the              |  |  |
| -   | I DI            |                | mask option.                                                              |  |  |
|     |                 |                | C-MOS Schmitt Trigger Input Terminal with     Pull-up Resistance(IB)      |  |  |
|     |                 |                | <ul> <li>C-MOS Schmitt Trigger Input Terminal(ID)</li> </ul>              |  |  |
|     |                 |                | C-MOS Output Terminal(OB)                                                 |  |  |
|     |                 |                | When the ports are selected as the input terminal, PD0                    |  |  |
|     |                 |                | operates also as RESTART signal input terminal to return                  |  |  |
|     |                 |                | from STANDBY mode, and PD1 operates also as the Edge                      |  |  |
|     |                 |                | Detector Terminal.                                                        |  |  |
| 5   | PA0             | INPUT/OUTPUT   | 4-bit Input / Output PORTA.                                               |  |  |
| 6   | PA1             | INPUT/OUTPUT   | Selects a terminal circuit for each port from follows by the              |  |  |
| 7   | PA2             | INPUT/OUTPUT   | mask option.                                                              |  |  |
| 8   | PA3             | INPUT/OUTPUT   | <ul> <li>C-MOS Input Terminal with Pull-up Resistance(IA)</li> </ul>      |  |  |
|     |                 |                | C-MOS Input Terminal(IC)                                                  |  |  |
|     |                 |                | C-MOS Output Terminal(OB)                                                 |  |  |
| 9   | TEST            | INPUT          | Maker Testing Terminal with Pull-down Resistance                          |  |  |
|     |                 |                | The terminal is recommended to connect to GND.                            |  |  |
| 10  | OSC1            | INPUT          | Internal Oscillator Terminals.                                            |  |  |
| 11  | OSC2            | OUTPUT         | Connects a device selected from the ceramic or the crystal                |  |  |
|     |                 |                | resonator, or the resistor, to these terminals for the internal           |  |  |
|     |                 |                | oscillator.                                                               |  |  |
|     |                 |                | In the external clock operation, OSC1 is the external clock               |  |  |
|     |                 |                | input terminal and OSC2 is normally open terminal.                        |  |  |
| 12  | V <sub>SS</sub> | _              | Power Source (0V)                                                         |  |  |
| 13  |                 | INPUT          | RESET Terminal.                                                           |  |  |
|     | RESET           |                | When the low level input-signal, the system is initialized.               |  |  |
| 14  | EXTI / PE0      | INPUT          | 1-bit Input PORTE.                                                        |  |  |
|     |                 |                | Selects a function of either 1) or 2) for PORTE by the mask               |  |  |
|     |                 |                | option.                                                                   |  |  |
|     |                 |                | 1) External Interrupt Input Terminal with Pull-up Resistance.<br>:EXTI    |  |  |
|     |                 |                | 2) 1-bit Input Terminals as PORTE                                         |  |  |
|     |                 |                | Selects a terminal circuit for each port from follows by the mask option. |  |  |
|     |                 |                | C-MOS Schmitt Trigger Input Terminal with     Pull-up Resistance(IB)      |  |  |
|     |                 |                | C-MOS Schmitt Trigger Input Terminal(ID)                                  |  |  |
|     | Note) INPU      | T/OUTPUT : Inp | ut or Output is selected by the mask option.                              |  |  |
|     | INOU            |                | ut or Output is changed by the program.                                   |  |  |
|     |                 |                |                                                                           |  |  |

# ■ TERMINAL DESCRIPTION 2

| No. | SYMBOL            | INPUT/OUTPUT  | FUNCTION                                                                     |
|-----|-------------------|---------------|------------------------------------------------------------------------------|
| 15  | SDO               | SDO :OUTPUT   | 2-bit Input / Output PORTF.                                                  |
| 16  |                   | PF0 :OUTPUT   | Selects a function of either 1) or 2) for PORTF by the mask                  |
|     | SDI(O)            | SDI(O) :INOUT | option.                                                                      |
|     | / PF1             |               | 1) Serial Interface Function                                                 |
|     |                   | INPUT/OUTPUT  | Serial Data Output Terminal : SDO                                            |
|     |                   |               | Serial Data Input-Output Terminal with Pull-up                               |
|     |                   |               | Resistance : SDI(O)                                                          |
|     |                   |               | <ol><li>2) 2-bit Input / Output Terminals as PORTF.</li></ol>                |
|     |                   |               | Selects a terminal circuit for each port from follows by the mask            |
|     |                   |               | option.                                                                      |
|     |                   |               | C-MOS Input Terminal with Pull-up Resistance (IA):PF1                        |
|     |                   |               | C-MOS Input Terminal(IC):PF1                                                 |
|     | 0.014 /           | 0.01/         | C-MOS Output Terminal(OB):PF0,PF1                                            |
| 17  | SCK /             | SCK :INOUT    | Selects a function of either 1) or 2) by the mask option.                    |
|     | CKOUT             | CKOUT :       | 1) Serial Clock Input or Output Terminal with Pull-up                        |
|     |                   | OUTPUT        | Resistance. :SCK                                                             |
|     |                   |               | 2) Clock Divided by Prescaler Output Terminal with Pull-up                   |
|     |                   |               | Resistance. :CKOUT                                                           |
|     |                   |               | Selects the dividing times of the clock in the prescaler by the mask option. |
| 18  | PB0               | INOUT         | 4-bit Programmable Input / Output PORTB                                      |
| 19  | PB1               | INOUT         | These 4-bit terminals' direction can be changed by the program               |
| 20  | PB2               | INOUT         | as 4-Input or 4-Output.                                                      |
| 21  | PB3               | INOUT         | Use of Pull-up resistance is in accordance with the mask option.             |
|     |                   |               | as Input : C-MOS Input Terminals                                             |
|     |                   |               | <ul> <li>as Output: Nch-FET Open-Drain Output Terminal</li> </ul>            |
| 24  | V <sub>DD</sub>   | -             | Power source (2.4V – 5.5V)                                                   |
|     | Note) INPU        |               | ut or Output is selected by the mask option.                                 |
|     | INOU <sup>-</sup> | T : Inp       | ut or Output is changed by the program.                                      |

#### INTERNAL SYSTEM DESCRIPTION

The **NJU3502** is a C-MOS 4-Bit Single Chip Micro Controller consisted of Original CPU Core, Selectable Input-Output(I/O) Ports(MAX. 17 lines), Program ROM(1024 bytes), Data RAM(64 nibbles), 8-bit Serial Interface, 8-Bit Timer, Interrupt Control Circuit and Oscillator Circuit.

The CPU block in the **NJU3502** is consisted of ALU(Arithmetic Logic Unit) executing the binary adding, subtracting or logical calculating, AC(Accumulator), four Registers, STACK allowing the 8-level subroutinenesting or Interrupt operation, PC(Program Counter) indicating 1024 addresses sequentially, and Timing generator.

The **NJU3502** can be applied to the various markets because of the rich and efficient instruction set(59 instructions), wide operating voltage range(2.4V to 5.5V), low operating current, and STANDBY function reducing the power supply current.

#### (1) INTERNAL REGISTER

• Accumulator(AC)

Accumulator(AC) is structured by the 4-bit register. It holds a data or a result of calculation, and executes the shift-operation(ROTATE) or the data transference between the other registers and Data Memory(RAM).

The accumulator condition is unknown on the "RESET" operation.

X-register(X-reg)

X-register(X-reg) operates as the 4-bit register. Bit0 and bit1 of X-reg operate also as the RAM address pointer with Y-register.

The X-reg condition is unknown on the "RESET" operation.

Y-register(Y-reg)

Y-register(Y-reg) operates as the 4-bit register or the RAM address pointer with bit1 and bit2 of X-reg. The Y-reg condition is unknown on the "RESET" operation.

X'-register(X'-reg)

X'-register(X'-reg) operates as the 4-bit register or a part of Program Memory(ROM) address pointer for looking data in the ROM(TRM instruction) up function.

The X'-reg condition is unknown on the "RESET" operation.

Y'-register(Y'-reg)

Y'-register(Y'-reg) operates as the 4-bit register or the peripheral register number(PHYn) pointer. The Y'-reg condition is unknown on the "RESET" operation.

- (2) INTERNAL FLAG
  - RPC flag(RPC)

RPC flag(RPC) changes the instruction table. Several instructions perform either of the dual tasks in accordance with the RPC flag condition. The RPC flag condition selects either of two couples of registers which are X- and Y-reg, or X'- and Y'-reg. X- or Y- reg is selected when the RPC flag condition is "0"(RPC=0). X'- or Y'- reg is selected when the RPC flag condition is "1"(RPC=1). The RPC flag condition is set to "1"(RPC=1) by SRPC instruction, and is set to "0"(RPC=0) by RRPC instruction. The RPC flag condition is set to "0" on the "RESET" operation.

CARRY flag(CY)

When the carry occurs after the adding calculation, the CY flag condition is set to "1"(CY=1), and when no carry, the CY flag condition is set to "0"(CY=0). When the borrow occurs after the subtracting calculation, the CY flag condition is set to "0"(CY=0), and when no borrow, the CY flag condition is set to "1"(CY=1). The bit-operation instruction operates the bit data rotation on the CY flag combined with the Accumulator or the other register.

The CY flag condition is set to "1"(CY=1) by SEC instruction and is set to "0"(CY=0) by CLC instruction. The CY flag condition is kept until the end of the next instruction executing cycle. The CY flag condition is unknown on the "RESET" operation.

#### STATUS flag(ST)

STATUS flag(ST) is the conditional flag in accordance with the result of the instruction execution. Its condition is in accordance with follows:

- 1) to be same as CY flag condition.
- 2) to be set the condition to "0"(ST=0) when the result of the logical calculation(AND, OR, XOR, YNEA) is zero.

3) to be set the condition to "0"(ST=0) when the result of the comparison(CMP) is zero.

However, ST flag condition is always set to "1"(ST=1) except above three.

ST flag controls the branch operation. Branch instruction does not branch when ST flag condition is "0", and branches when ST flag condition is "1". ST flag condition is kept until the end of the next instruction executing cycle.

The ST flag condition is unknown on the "RESET" operation.

#### (3) FUNCTIONAL BLOCK

ARITHMETIC LOGIC UNIT(ALU)

ARITHMETIC LOGIC UNIT(ALU) is a 4-bit binary paralleled calculation circuit operating binary addition, binary subtraction, comparison, logical AND, logical OR, exclusive OR, and SHIFT(Rotation). And it also can detect CARRY, BORROW or ZERO in accordance with the result of each calculation.

#### PROGRAM MEMORY(ROM)

PROGRAM MEMORY(ROM) consists of 16 pages, and a page consists of 64 bytes memory capacity. Therefore the **NJU3502** prepares the 1024-byte ROM for the application program. The ROM address is indicated by the Program Counter(PC).

# [PROGRAM MEMORY AREA]



#### PROGRAM COUNTER(PC)

PROGRAM COUNTER(PC) consisted of the 10-bit binary counter stores the address for the next operating instruction in ROM. Data figures limited from b0 to b5 on the PC indicate the address in a page, and data figures limited from b6 to b9 on the PC indicate the page in ROM. Although the ROM address can be indicated 1024 addresses continuously, the target address of JMP instruction is restricted by Paging structure in ROM.

The PC condition is set to "0" on the "RESET" operation.



JMP instruction can branch to the optional address in the page. The target address is indicated by the data figures limited from b0 to b5(6 bits) on PC as shown in above. The paging structure can reduce the program size in ROM and the JMP instruction execution time against JPL instruction because JMP instruction is consisted of one byte(8 bits) length. JPL and CALL instructions can branch to the optional address without considering the paging structure, because they consists of two bytes(16 bits) length including the 10 bits of PC.

#### STACK

STACK consists of three types of registers which are the 8 by 10 bits, the 5 by 4 bits, and the 2 by 1 bit registers. The registers of STACK hold the data of PC automatically when the interrupt routine or the subroutine is called. The 5 by 4 bits registers of STACK hold the data of the internal registers automatically when the interrupt operation is executed. The 2 by 1 bit registers of STACK hold the data of the internal flag automatically when the interrupt operation is executed. In the return (RET or RETI) operation, PC, the internal registers, and the internal flags registers get the held data from STACK automatically.



STACK POINTER



#### STACK POINTER(SP)

STACK POINTER(SP) consists of the 3 bits binary counter. SP indicates the number of next operating position in the STACK. It counts one up(increment) after the subroutine call(CALL) or the interrupt operation, and it counts one down(decrement) after the return(RET or RETI) operation.

Data storing operation to STACK after that SP overflowed(over than 7) or under flowed(under than 0), breaks the former held data in STACK. Therefore the subroutine nesting level must be cautioned in the application program.

SP condition is set to "0" on "RESET" operation.

# DATA MEMORY(RAM)

DATA MEMORY(RAM) is formed with the 4-bit length a word. The **NJU3502** prepares 64 words(256 bits) RAM. The data formed with the 4-bit length a word can be read/written from/to RAM, and the data formed with the 1-bit length in a word can be set, reset, or tested by the bit-operation instruction.

The RAM address is indicated indirectly by X- and Y-reg. The lower 2 bits(b0, b1) in X-reg are used as the RAM address pointer and the higher 2 bits(b2, b3) are not used.



#### • PERIPHERAL REGISTERs(PH)

PERIPHERAL REGISTERs(PH) controlling I/O Ports or the ROM address are selected by the data in Y'reg.

The Peripheral Register assigned for each I/O Port can get the signal data from the external application by reading operation, or can output the signal data to the external application by writing operation in accordance with the type of input or output selected by the mask option. Although the data can be read from the Peripheral Register assigned as the Output Port, it sometimes takes the incorrect data of the Output Port.

| Y'-register | Register No. | Peripheral Register Name               | Number<br>of Port | Write or<br>Read ∗1 | Data in<br>Reset |
|-------------|--------------|----------------------------------------|-------------------|---------------------|------------------|
| 0H          | PHY0 (00H)   |                                        |                   |                     | 0                |
| 1H          | PHY1 (01H)   | Serial Input/Output Control Register   | 3                 | WR                  | 0 *2             |
| 2H          | PHY2 (02H)   | Serial Input/Output Shift Register     | 8                 | WR                  | 0 *2             |
| 3H          | PHY3 (03H)   | Timer/Prescaler Control Register       | 3                 | WR                  | 0                |
| 4H          | PHY4 (04H)   | Initial Value Register / Timer Counter | 8                 | WR                  | 0                |
| 5H          | PHY5 (05H)   | Interrupt Control Register             | 3                 | WR                  | 0                |
| 6H          | PHY6 (06H)   | PORTA Output or PORTA Input            | 4                 | W or R              | 0                |
| 7H          | PHY7 (07H)   | PORTB Output or PORTB Input            | 4                 | WR                  | 0                |
| 8H          | PHY8 (08H)   | PORTC Output or PORTC Input            | 4                 | W or R              | 0                |
| 9H          | PHY9 (09H)   | PORTD Output or PORTD Input            | 2/3               | W or R              | 0                |
| AH          | PHY10(0AH)   | PORTE Input                            | 1                 | R                   | 0 *3             |
| BH          | PHY11(0BH)   | PORTF Output or PORTF Input            | 2 / 1             | W or R              | 0 *2             |
| СН          | PHY12(0CH)   | PORTB Input/Output Control Register    | 1                 | WR                  | 0                |
| DH          | PHY13(0DH)   | ROM Addressing Register                | 4                 | WR                  | unknown          |
| EH          | PHY14(0EH)   |                                        |                   |                     |                  |
| FH          | PHY15(0FH)   |                                        |                   |                     |                  |

#### [PERIPHERAL REGISTER TABLE]

\*1 W : Write only

R

: Read only

WR : Read and Write

W or R : Fixed as Read or Write by the mask option

New Japan Radio Co., Ltd.

# NJU3502

\*2 Wiring of terminals

The mask option selects a terminal type from SDO/PF0, SDI(O)/PF1 or SCK/CKOUT as shown in right.



\*3 Wiring of terminals The mask option selects a terminal type from EXTI/PE0 as shown in right.



#### • ROM ADDRESSING REGISTER(PHY13)

ROM ADDRESSING REGISTER(PHY13) indicates the address of ROM with Accumulator and X'-reg for the data transference operation(TRM) from ROM to RAM. The effective bits on PHY13 are b0 and b1, and the other two bits, b2 and b3, are not related.

The PHY13 condition is unknown on "RESET" operation.

#### [ROM ADDRESSING]

| no u  | ised | A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
|-------|------|----|----|----|----|----|----|----|----|----|----|
| b3    | b2   | b1 | b0 | b3 | b2 | b1 | b0 | b3 | b2 | b1 | b0 |
| PHY13 |      |    |    | >  | <' |    |    | A  | С  |    |    |

# INPUT OUTPUT PORT

The **NJU3502** prepares 14 Input-Output lines and 3 dual-function lines for the interface to an external application circuit. All lines are assigned to each Peripheral Register.

Data reading operation from the peripheral register can input the actual signals through the input terminal. Data writing operation to the peripheral register can output the actual signals through the output terminal.

| PORT NAME  | FUNCTION                      | INPUT/OUTPUT                                        |
|------------|-------------------------------|-----------------------------------------------------|
| PORTB      | Input / Output port           | Programmable Input / Output PORT (4-bit).           |
| PORTA      | Input / Output port           | Input / Output selectable ports by the mask option. |
| PORTC      |                               |                                                     |
| PORTD      |                               |                                                     |
| PORTE      | Input port or EXTI            | Input                                               |
| PORTF(PF0) | Output port or SDO            | output                                              |
| PORTF(PF1) | Input / Output port or SDI(O) | Input / Output selectable ports by the mask option. |

#### [FUNCTION OF EACH PORT TABLE]

Note) Pull-up resistance is selected by the mask option.(refer ■ INPUT OUTPUT TERMINAL TYPE)

#### (1) INPUT OUTPUT PORT

• PORTA(PA0 – PA3)

PORTA is a 4-bit input-output PORT. The input or the output is selected for each bit by the mask option. When the port is set as the output, the signal is output through the output terminal by writing data to the PORTA register(PHY6). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY6.

#### [READING PORTA INPUT DATA (PHY6)]



#### [WRITING PORTA OUTPUT DATA (PHY6)]



#### • PORTB(PB0 – PB3)

PORTB is a 4-bit programmable input-output PORT. It is set as the output when LSB of the programmable input/output control register(PHY12) is set to "1", and is set as input when LSB of PHY12 is set to "0". When the PORT is set as the output, the 4-bit signals are output through the output terminals by writing data into the peripheral register assigned for PORTB(PHY7). PHY7 as the output register should be written the output data before the PORTB is set as the output by PHY12, because the conditions of the output terminals are unknown while the output data is not written in PHY7. When this PORT is set as the input, the 4-bit external signals are gotten directly through the input terminals by reading data from PHY7. PHY7 can be written or read independent of the state of PHY12 as the input or output.

The output circuit is Nch open drain type, but the C-MOS input buffer is connected to the output circuit, therefore when the middle revel voltage between  $V_{DD}$  and  $V_{SS}$  is input, the operating current of the chip will increase by through type current.

PORTB is set as the input in accordance with the state of PHY12 set to "0" on the "RESET" operation.

# [READING PORTB INPUT DATA (PHY7)]



#### [WRITING PORTB OUTPUT DATA (PHY7)]



#### PORTC(PC0 – PC3)

PORTC is a 4-bit input-output PORT. The input or the output is selected for each bit by the mask option. When the port is set as the output, the signal is output through the output terminal by writing data to the PORTC register(PHY8). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY8.

#### [READING PORTA INPUT DATA (PHY8)]



#### [WRITING PORTA OUTPUT DATA (PHY8)]



New Japan Radio Co., Ltd.

#### • PORTD(PD0, PD1)

PORTD is a 2-bit input-output PORT. The input or the output is selected for each bit by the mask option. When the port is set as the output, the signal is output through the output terminal by writing data to the PORTD register(PHY9). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from the PHY9. When this PORTD is set as the input, these two ports perform the extra functions as follows:

#### a) PD0 TERMINAL

PD0 terminal performs the extra function as the re-start signal input terminal to return from the "STANDBY" mode. When the rising edge of the signal from the external circuit is input into the PD0 terminal in mode of "STANDBY", the "STANDBY" mode is released and the CPU starts the execution again from the suspended address of program. (refer ■ STANDBY FUNCTION)

#### b) PD1 TERMINAL

PD1 terminal performs the extra function as the edge detector terminal. When the PD1 terminal detects the edge of the signal from the external circuit, the third bit(b2) condition of PHY9 is set to "1". The "b2" of PHY9 is set to "1" even when the edge is input during the "STANDBY" mode. The condition of "b2" is kept until the writing operation to PHY9.

The polarity as low to high or high to low of the input signal edge can be selected by the mask option.

#### [READING PORTD INPUT DATA (PHY9)]



#### [WRITING PORTD OUTPUT DATA (PHY9)]



#### • PORTE(PE0)

PORTE is a 1-bit input PORT. It operates also as EXTI input terminal for the external interrupt input by the mask option. When the PORTE is set as the input PORT, the external signal is gotten directly from the input terminal by reading data from the PHY10.

#### [READING PORTE INPUT DATA (PHY10)]



## • PORTF(PF0, PF1)

PORTF is a 2-bit input-output PORT. It operates also as SDO and SDI(O) terminals for the 8-bit serial interface by the mask option. When the PORTF is selected as the input-output PORT, PF0 is fixed as the output and PF1 can be selected as the input or the output by the mask option. When the PORTF is selected as the output, the two signals are output through the output terminals to the external circuit by writing data to the PORTF register(PHY11). When PF1 is selected as the input, the external signal is gotten directly through the input terminal by reading data from PHY11.





When PF0 is output, its output condition can be monitored.

# [WRITING PORTF OUTPUT DATA (PHY11)]



• PROGRAMMABLE INPUT/OUTPUT PORT CONTROL REGISTER(PHY12)

Programmable Input / Output Port Control Register(PHY12) is a peripheral register to set the programmable input/output PORT(PORTB) as either the input or the output. All bits in PORTB are set as the output when LSB(b0) of PHY12 is set to "1". All bits in PORTB are set as the input when "b1" of PHY12 set to "0".

PORTB is set as the input in accordance with the state of PHY12 which is set to "0" on the "RESET" operation.



The signal from PB0 terminal is stored into the LSB of Accumulator, the signal from PB1 terminal is stored into the b1 of Accumulator, the signal from PB2 terminal is stored into the b2 of Accumulator, and the signal from PB3 terminal is stored into the b3 of Accumulator.

# ■ INPUT OUTPUT TERMINAL TYPE

Each terminal of PORTA,B,C,D,E, and F can select a terminal type from the follows by the mask option which is the same mask of the program coding in ROM and the others. But PORTE selects only the input terminal type. PF0 of PORTF selects only the output terminal type.

| [IN                                   | [INPUT OUTPUT TERMINAL TYPES]                           |              |                 |                                                             |  |  |
|---------------------------------------|---------------------------------------------------------|--------------|-----------------|-------------------------------------------------------------|--|--|
| $\square$                             | Types                                                   | With Pull-up | Without Pull-up | Terminals                                                   |  |  |
| TERMINAL                              | C-MOS                                                   | Type IA      | Type IC         | PA0-PA3,<br>PC0-PC3,<br>SDI(O)/PF1                          |  |  |
| INPUT TE                              | SCHMITT<br>TRIGGER                                      | Type IB      | Type ID         | PD0, PD1,<br>EXTI/PE0                                       |  |  |
| TERMINAL                              | C-MOS                                                   |              | Type OB         | PA0-PA3,<br>PC0-PC3,<br>PD0, PD1,<br>SDO/PF0,<br>SDI(O)/PF1 |  |  |
| OUTPUT                                | N-channel (Nch)<br>OPEN DRAIN                           | Type OA      | Type OC         |                                                             |  |  |
| PROGRAMMABLE INPUT<br>OUTPUT TERMINAI | C-MOS INPUT/<br>N-channel (Nch)<br>OPEN DRAIN<br>OUTPUT | Type C       | Type D          | PB0-PB3                                                     |  |  |

# TIMER

The NJU3502 prepares Programmable Timer consisted of 8-bit binary counter.

#### [Structure of TIMER]



Timer counts only the internal clock. The initial value of the Timer can be set the optional value by the program which instructs to write the data(a value of the time-interval) into the Initial Value Register. In enabling the Timer interrupt, when the Timer counts from "FF" to "00" (overflow), the Timer interrupt request occurs and the internal interrupt process starts the own operation.

In the repeat mode of the Timer operation, when the Timer overflows, the initial value is loaded into the Timer automatically and the Timer continues the count from the loaded initial value (Auto re-load function: See the repeat mode of the Timer operation timing chart). In the single mode of the Timer operation, when the Timer overflows, the count is stopped(See the single mode of the Timer operation timing chart). For starting the count operation again, the start bit(LSB) of Timer Control Register must be set to "1". The latest initial value is set into the Timer and the Timer starts the count.

In enabling the interrupt operation, when the Timer overflows, the Timer overflow flag is set to "1" and the internal interrupt process starts the own operation. In disabling the Timer interrupt, the Timer overflow flag is not set. The Timer overflow flag is initialized by the Timer Start or the Reset signal.

The internal clock into the counter is the divided clock from the internal prescaler. the frequency of the clock can be selected by the mask option from follows which are the dividing numbers based on the inverse of the 1-instruction executing  $period(1/f_{OSC} \times 6)$ .

 $1/2,\,1/4,\,1/8,\,1/16,\,1/32,1/64,\,1/128,\,1/256,\,1/512,\,1/1024,\,1/2048,1/4096$ 

[THE SINGLE MODE OF THE TIMER OPERATION TIMING ] (The initial value is set to "AAh")



[ THE REPEAT MODE OF THE TIMER OPERATION TIMING] (The initial value is set to "AAh")



#### TIMER / PRESCALER CONTROL REGISTER {PHY3 ; (Y'=3)} [Writing to Timer / Prescaler Control Register]



EX.)An example of the start procedure in the single mode and the internal clock operation.

| :    |         |                                                  |                       |
|------|---------|--------------------------------------------------|-----------------------|
| SRPC | ;       | :                                                |                       |
| LDI  | Y,3     | ;PHY3(Timer1/Prescaler Control Register) is poir | ited.                 |
| LDI  | A,%0000 | ;"0000"(BIN) is stored to accumulator            | ∫Single mode,         |
| TAP  |         | ;Data is transferred from accumulator to PHY3    | Prescaler is enable   |
| LDI  | A,%0001 | ;"0001"(BIN) is stored to accumulator            | J                     |
| TAP  |         | ;Data is transferred from accumulator to PHY3    | The count is started. |
| :    |         |                                                  |                       |
| :    |         |                                                  |                       |

Remarks) When the prescaler generating the internal count clock is stopped the operation, Timer is also stopped. But the data in the counter is kept. Therefore Timer can continue to count from the kept condition of the counter when the prescaler is started the operation again. However, the clocks from the prescaler are delivered to Serial I/O, therefore the prescaler requires careful operation, especially stop or start. When the prescaler is started the operation again after it was stopped, it is reset and start to count from "zero".

#### [Reading from Timer / Prescaler Control Register]



EX.)An example of the overflow in the single mode and the internal clock operation.(The data of the Timer / Prescaler Control Register is "0001"(BIN).)



#### • INITIAL VALUE REGISTER / TIMER COUNTER {PHY4;(Y'=4)}

The Initial Value Register consisted of a 8-bit register sets the initial value to the Timer, or gets the counted value from the Timer.

#### [Writing to Initial Value Register]

When a data in RAM or Accumulator is transferred to the Initial Value Register, the data is loaded into the higher 4-bit(b7 to b4) or lower(b3 to b0) of the Initial Value Register in accordance with the condition of LSB of Y-register.



#### [Reading from Timer Counter]

When a current data in the Timer Counter is transferred into RAM or Accumulator, the data is gotten from higher 4-bit(b7 to b4) or lower(b3 to b0) of the Timer Counter in accordance with the condition of LSB of Y-register.



Though the data of the Timer can be read in the count operation, the read data is sometimes incorrect when the clock inputs to the counter during the reading operation.

When the 8-bit counter data is read in count operation as shown in the following timing chart(An example of data reading from the counter to RAM), Timer often counts up between the first 4-bit data reading and the second. In case of the following chart, though the timer data is "0Fh" when the lower 4-bit data is gotten, it is "10h" when the higher 4-bit data is gotten. Therefore the final data becomes to be "1Fh".



#### [An example of data reading from the counter to RAM]

# ■ SERIAL INPUT OUTPUT

SERIAL INPUT OUTPUT consists of the sift registers to convert from 8-bit parallel data to serial data, the 3bit serial clock counter, and the 3-bit serial control register. It operates as the 8-bit serial input or output. The external or internal clock is selected as the shift clock in accordance with the Serial Input / Output control register.

#### [Block diagram of the SERIAL INPUT OUTPUT]



The serial input or output operation starts when the LSB of the Serial Input / Output control register(PHY1) is set to "1". In the external clock operation, the serial input or output operation waits to start until the external clock come in.

When the serial shift register(PHY2) is set the data in advance, the data is output(transmitted) through the SDO or the SDI(O) terminal. The SDI(O) terminal can be changed as a transmitter or a receiver in accordance with the bit3(b3) of PHY1. The data order, MSB or LSB first, is selected by the mask option.

Serial Input Output operates as the 3-wire method using SDI(O), SCK and SDO terminals, or the 2-wire using SDI(O) and SCK terminals.

#### <<The 3-wire method>>

The data synchronized with the falling edge of the SCK clock is output(transmitted) through the SDO terminal. The data synchronized with the rising edge of the SCK clock is input(received) through the SDI(O) terminal.



DI4

#### [The 3-wire transmission timing chart (MSB first)]

DI7

DI6

DI5

<<The 2-wire method>>

SDI(O)

The data synchronized with the falling edge of the SCK clock is transmitted through the SDI(O) terminal. The data synchronized with the rising edge of the SCK clock is received through the SDI(O) terminal.

DI3

DI2

DI1

DI0

In case of the data transmission through the SDI(O) terminal, the SDI(O) terminal must be set as the \* output by the condition of the bit3(b3) of the Serial Input / Output control register(PHY1) set to "1". In case of the data reception through the SDI(O) terminal, the SDI(O) terminal must be set as the input by the condition of the b3 of PHY1 set to "0".

#### [The 2-wire transmission timing chart (LSB first)]



In case of the external clock operation, the external clock is input as the SCK clock to the SCK terminal as shown in the serial transmission timing chart. The signal condition into the SCK terminal must be kept as "High" until the external clock come in. In the transmission, when the SCK with the noise or other redundant signals from the outside of **NJU3502** input to the SCK terminal, Serial Input Output operates incorrectly. The maximum frequency of the SCK is 500kHz.

In case of the internal clock operation, the SCK outputs through the SCK terminal as shown in the serial transmission timing chart. The internal interrupt signal occurs when the 3-bit counter has counted the SCK clock up to 8 times that means 1-byte serial data transmission end. The internal clock as the SCK is the divided clock in the internal prescaler, and the frequency of the clock can be selected by the mask option from follows which are dividing numbers based on the inverse of the 1-instruction executing period( $1/f_{OSC} \times 6$ ).

#### 1/2, 1/4, 1/8, 1/16, 1/32, 1/64, 1/128, 1/256, 1/512, 1/1024, 1/2048, 1/4096

- Remarks1)When the bit2(b2) of Timer / Prescaler control register(PHY3) is set to "1", the prescaler generating the internal serial clock is stopped and the internal serial clock is also stopped. Accordingly, Serial Input Output does not operate.
- Remarks2)If the writing operation is operated to the Serial Input / Output shift register(PHY2) or the Serial Input / Output control register during the transmission or the reception operation, the 3-bit counter is reset and the serial data transmission or reception is stopped. Therefore the writing operation to the above registers must not be operated during the transmission or reception operation.
  - SERIAL INPUT/OUTPUT CONTROL REGISTER {PHY1 ; (Y'=1)}

When the data of bit1(b1) and bit3(b3) of the Serial Input / Output control register are changed, the operation must be performed before starting the serial transmission. (See the following sample program) In changing the condition of b1 or b2 of PHY1 and setting the LSB of PHY1 to start the transmission are operated in the mean time, Serial Input Output operation does not operate correctly.

#### [Writing to the Serial Input / Output Control Register]



EX.)An example of the start procedure in the 3-wire serial data transmission, the external clock operation and the SDI(O) terminal setting as the input .

| :<br>SRPC<br>LDI | ;<br>Y,1 | ;<br>;PHY1(Serial Input / Output control register) is pointed |           |
|------------------|----------|---------------------------------------------------------------|-----------|
| LDI              | A,%0010  | ;"0010"(BIN) is stored to accumulator                         | al clock, |
| TAP              |          | ;Data is transferred from accumulator to PHY1 Input r         | node      |
| LDI              | A,%0011  | ;"0011"(BIN) is stored to accumulator                         | nission   |
| TAP              |          | ;Data is transferred from accumulator to PHY1 J Starts.       |           |
| :                |          |                                                               |           |
| :                |          |                                                               |           |
|                  |          |                                                               |           |

Remarks3)In case of the external clock operation at the both of the transmission and reception mode, inputting the external clock must wait while the 2-instruction execution period after that LSB of Serial Input / Output control register is set to "1"(START). (one instruction execution period = 1 / f<sub>OSC</sub> X 6)

If the external clock is input within the 2-instruction execution period, the Serial Input / Output shift register can not recognize the first SCK. The number of the shift operation is decreased a time, 8 times to 7.

#### [Reading from the Serial Input / Output Control Register]



Remarks4)The end flag of transmission is set to "1" when the serial data(8 bits) transmission operation is ended. It is cleared by setting the serial data transmission start signal in the Serial Input /Output control register.

• SERIAL INPUT/OUTPUT SHIFT REGISTER {PHY2 ; (Y'=2)}

The Serial Input / Output Shift register consisted of a 8-bit register operates to set the transmission data or to get the reception data.

#### [Writing to the Serial Input / Output Shift Register]

The data in RAM or Accumulator is transferred to the Serial Input / Output Shift register, and it is loaded into lower 4-bit(b0 to b3) or higher(b4 to b7) in PHY2 in accordance with the condition of LSB of Y-register.



#### [Reading from the Serial Input / Output Shift Register]

The Serial Input data is transferred to RAM or Accumulator, it is loaded from lower 4-bit(b0 to b3) or higher(b4 to b7) of PHY2 in accordance with the condition of LSB of Y-register.



:

An example of the serial data reception program) In the internal clock operation, SDI(O) terminal is set as the input and the serial input data is transferred to RAM.

|              | :           |                                         |                                                         |
|--------------|-------------|-----------------------------------------|---------------------------------------------------------|
| ; Interro    |             |                                         |                                                         |
|              | ORG         | \$30                                    | ;Interrupt vector address of FULL or EMPTY              |
| SINT         | SRPC<br>LDI | Y,1                                     | ;<br>;The Serial Input / Output control register is set |
|              | TPA         |                                         | ,                                                       |
|              | TBA         | 0                                       | ;The end flag of transmission is tested                 |
|              |             | SIO_OK                                  |                                                         |
|              | JMP         | SINT_E                                  | ;<br>,                                                  |
| ,<br>SIO_OK  | LDI         | Y,2                                     | ;The Serial Input / Output shift register is set        |
|              | RRPC        |                                         | ;RAM to store the serial input data is pointed          |
|              | LDI<br>LDI  | X,SIO_DAT.X<br>Y,SIO_DAT.Y              | ;RAM address, X=0<br>;RAM address, Y=0                  |
|              | TPMIC       |                                         | ;The serial input data is transferred to RAM(lower      |
|              |             |                                         | ; 4-bit) and Y-register is incremented                  |
|              | TPMIC       | Υ                                       | ;The serial input data is transferred to RAM(higher     |
|              |             |                                         | ; 4-bit) and Y-register is incremented                  |
| ;<br>SINT_E  | RETI        |                                         | ; End of the interrupt process                          |
| ,<br>: Seria | al data ir  | nputting process                        |                                                         |
| SIO_IN       | SRPC        | .p.a                                    | ;                                                       |
|              | LDI         | Y,1                                     | ;The Serial Input / Output control register is set      |
|              | LDI         | A,%0000                                 | ;The internal clock operation is set and the SDI(O)     |
|              | TAP         |                                         | ; terminal is set as the input                          |
|              |             | A,%0001                                 | ,<br>;The serial data reception is started              |
|              | TAP         | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                                         |
| ;            |             |                                         |                                                         |
|              | :           |                                         |                                                         |
|              | :<br>WSEG   |                                         | ;The RAM area is set                                    |
| SIO_DAT      | DS          | 2                                       | ;The area to store the serial input data is secured     |
| 0.0_0/(1     | 20          | -                                       |                                                         |

An example of the serial data transmitting program) In the internal clock operation, the SDI(O) terminal is set as the output and the data in RAM is transmitted.

|                        | :                                |                                   |                                                                                                                                                                                        |
|------------------------|----------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ; Interro<br>SINT      | ORG<br>SRPC<br>LDI<br>TPA<br>TBA | \$30<br>Y,1<br>0                  | ;Interrupt vector address of FULL or EMPTY<br>;<br>;The Serial Input / Output control register is set<br>;<br>;The end flag of transmission is tested                                  |
|                        | JMP<br>JMP                       | SIO_OK<br>SINT_E                  | ;<br>;<br>;                                                                                                                                                                            |
| ,<br>SIO_OK            | RRPC<br>LDI<br>LDI<br>LDI<br>TAM | X,SIO_FLG.X<br>Y,SIO_FLG.Y<br>A,1 | ;The end flag of transmission is set<br>;<br>;                                                                                                                                         |
| ,<br>SINT_E            | RETI                             |                                   | ; End of the interrupt process                                                                                                                                                         |
| ,<br>; Seri<br>SIO_OUT |                                  | ransmitting proc<br>;<br>Y,2      | ess<br>;The Serial Input / Output shift register is set                                                                                                                                |
| ,                      | rrpc<br>LDI<br>LDI<br>TMPIC      | X,SIO_DAT.X<br>Y,SIO_DAT.Y<br>Y   | ;RAM to store the serial output data is set<br>;RAM address, X=0<br>;RAM address, Y=1<br>;The data in RAM is transferred to the Serial Input /<br>; Output shift register(lower 4-bit) |
|                        | TMPIC                            | Υ                                 | ; and Y-register is incremented<br>;The data in RAM is transferred to the Serial Input /<br>; Output shift register(higher 4-bit)<br>; & Increments Y                                  |
| ,                      | SRPC<br>LDI<br>LDI               | Y,1<br>A,%1000                    | ;<br>;The Serial Input / Output control register is set<br>;The internal clock operation and the transmission<br>; mode are set                                                        |
| •<br>2                 | TAP<br>LDI<br>TAP                | A,%1001                           | ;<br>;The serial data transmitting operation is started<br>;                                                                                                                           |
| SIO_FLG<br>SIO_DAT     | WSEG<br>DS<br>DS                 | 3<br>1<br>2                       | ;The RAM area<br>;The end flag of transmission<br>;The area to store the serial output data                                                                                            |

#### INTERRUPT

The **NJU3502** prepares three kinds of the interrupt. The interrupt "enable" or "disable" is controlled by the program. The interrupt operates as single process and no multiple. However, when new interrupt request occurs during the other interrupt process, the request is kept, and then the new interrupt process starts after the prior interrupt process. The priority order of the interrupt is that the first is (1)External interrupt-1, the second is (2)Internal interrupt-1, and the third is (3)Internal interrupt-2, as shown below.

When the interrupt request flag is set by the own factor, the interrupt enabled by the interrupt control register(PHY5) stores the data of Program Counter, Accumulator, X-reg, X'-reg, Y-reg, Y'-reg, RPC, and STATUS into the STACK register, and sets the interrupt vector address into Program Counter, and then the interrupt process is started. The return from the interrupt process by "RETI" instruction resets the corresponded interrupt request flag, and regains the held data from STACK, and then the operation before the interrupt process is started continuously. When the interrupt control register disables the interrupt process, the interrupt request flag is not set.

#### [THE PRIORITY ORDER OF THREE FACTORS INTERRUPT]

| Order | Interrupt factor                             | Vector Address(H:HEX) |
|-------|----------------------------------------------|-----------------------|
| (1)   | External interrupt-1                         | 10H                   |
| (2)   | Internal interrupt-1 Timer Overflow          | 20H                   |
| (3)   | Internal interrupt-2 Serial shift register F | Full/Empty 30H        |

The External interrupt-1 enabled by PHY5 is started the interrupt process when the rising edge of signal pulse is input to the external interrupt signal input terminal(EXTI). The External interrupt-1 request flag is reset by 'RETI' instruction. When the external interrupt-1 occurs during the standby mode by the HALT instruction, the External interrupt-1 request signal is latched and its interrupt process is started after that the standby mode is released.

The Internal interrupt enabled by PHY5 is started the interrupt process when the internal interrupt request flag is set.

The Timer interrupt request flag is independent of the overflow flag, and it is reset by "RETI" instruction, (TIMER)START signal of the Timer control register, or RESET signal from the external circuit. Serial Input Output interrupt request flag is set synchronizing with the transmission end flag when its interrupt is enabled by PHY5. And the flag is reset by the "RETI" instruction or the RESET signal from the external circuit.

#### INTERRUPT CONTROL REGISTER {PHY5 ; (Y'=5)}



New Japan Radio Co., Ltd.

| [Enabled all factors                         | (b0 to b2 of PHY5 were set to "1")]                                                                           |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| Interrupt –<br>Enable / Disable              | Enabled all factors                                                                                           |
| External Interrupt-1<br>Request flag         |                                                                                                               |
| Internal Interrupt-1<br>Request flag         |                                                                                                               |
| Internal Interrupt-2<br>Request flag _       |                                                                                                               |
| External Interrupt-1                         | <u> </u>                                                                                                      |
| Internal Interrupt-1                         | <u> </u>                                                                                                      |
| Internal Interrupt-2                         | $\frown$                                                                                                      |
|                                              | External Interrupt-1 Internal Interrupt-1 Internal Interrupt-2<br>Process Process Process                     |
|                                              |                                                                                                               |
|                                              | disabled to the enabled(b0 to b2 of PHY5 are changed from "0" to "1")]                                        |
| Interrupt —<br>Enable / Disable              | Disabled all factors Enabled all factors                                                                      |
| External Interrupt<br>Input(EXTI terminal) — |                                                                                                               |
| External Interrupt-1                         |                                                                                                               |
| Request flag                                 | $\wedge$                                                                                                      |
|                                              | External Interrupt-1                                                                                          |
| * The internal interrupt                     | Process<br>is also ignored while it is disabled.                                                              |
| [From the all factors                        | enabled to the disabled(b0 to b2 of PHY5 are changed from "1" to "0")                                         |
| [                                            | An example of the transition from the<br>enabled all factors to the disabled in the<br>interrupt operation.   |
| Interrupt —<br>Enable / Disable              | Enabled all factors Disabled all factors                                                                      |
| External Interrupt-1<br>Request flag         |                                                                                                               |
| Internal Interrupt-1<br>Request flag         |                                                                                                               |
| External Interrupt-1                         | <u> </u>                                                                                                      |
| Internal Interrupt-1                         |                                                                                                               |
|                                              | External Interrupt-1<br>Process The interrupt operation does<br>not execute after the prior<br>operation end. |

When the interrupt is enabled, the latest interrupt request occurred during the prior other interrupt \* process starts its interrupt process after the prior interrupt operation. However, when the interrupt is disabled during the prior interrupt process as shown in above timing chart, the latest interrupt request does not start. But the prior interrupt process is completed.

New Japan Radio Co., Ltd.

#### STANDBY FUNCTION

STANDBY FUNCTION halts the IC operation and reduces the current consumption.

The STANDBY function starts by the HLT instruction. After the HLT instruction execution cycle, the internal oscillator operation is stopped and all of the operation is halted. In case of the external clock operation, the clock is stopped automatically delivering into the internal system by the internal circuits, and all of the operation is halted as same as the internal oscillator operation. This is STANDBY mode.

In the STANDBY mode, the operating current can be reduced. Though the clock into the internal system is stopped and all of the operation is halted, all conditions of Program Counter, Registers, and data in RAM are kept certainly.

Two ways to release from the STANDBY mode are prepared. One way is the reset operation that when the reset signal is input to RESET terminal, the operation starts from the initial condition. The other way is the restart operation that when the restart signal is input to PD0 terminal, the operation starts from the kept Program Counter location which is the program address after the final operation. In case of the restart signal operation, if the rising signal, low to high, is input to PD0 terminal, the internal oscillator circuit starts at first. After the stabilized clock from the internal oscillator was counted eight times, the clock is started delivering into the internal system. Then the **NJU3502** starts to operate from the kept Program Counter location with all of the kept conditions.(See \*1)

In case of the external clock operation, the external clock must be started to supply to the OSC1 terminal before the STANDBY mode is released. The external clock is recommended to stop supplying to the OSC1 terminal for reducing the power consumption during the STANDBY mode.

\*1: When the restart signal is input to PD0 terminal to release the STANDBY mode, PORTD must be selected as the input by the mask option.

|                                  | ormal<br>peration | _STANDBY<br>Mode | < Oscillation<br>Stability Time | Normal<br>Operation |    |
|----------------------------------|-------------------|------------------|---------------------------------|---------------------|----|
| Oscillator                       |                   |                  |                                 |                     |    |
| System<br>Clock                  | nnn               | •                | Concentration Start             | uuuu                | 11 |
| Execute ——<br>Instruction——      | X HLT X           |                  | next instruction                |                     | X  |
| Restart Signal<br>(PD0 Terminal) |                   |                  |                                 |                     |    |

#### [STANDBY MODE TIMING CHART]

# **CLOCK GENERATION**

The system clock is generated in the internal oscillator circuit using an external Crystal or Ceramic resonator, or the resistor connected to OSC1 and OSC2 terminals. Furthermore, the NJU3502 can operate by the external clock to the OSC1 terminal for the system clock. In the external clock operation, the OSC2 terminal must be opened.

The typical application examples for each oscillator circuit are shown in follows. However a Crystal or a Ceramic operation requires the considered evaluation, because the oscillator operates in accordance with the characteristics of each component.

#### **[OSCILLATOR APPLICATION EXAMPLES]**

1) X'tal/Ceramic oscillation



2) CR oscillation

3) External clock input



The resistor Rf\* is sometimes required to connect when the Crystal operation.

# RESET OPERATION

All of the internal circuits are initialized by inputting the low level signal to the RESET terminal.

A circuit example for Power On Reset Operation with a resistor, a capacitor, and a diode is shown in below. Power On Reset Operation requires to keep the low level of the input signal to RESET terminal until the stabilized oscillation of the internal oscillator. Therefore the constants on the reset circuit must be decided in accordance with the characteristics of the clock generator circuit.

#### [An example of Power On Reset circuit]



R\*:A resistor as RESET terminal protector. It is required depending on the condition of an application.

### PRESCALER

The **NJU3502** prepares a built-in Prescaler consisted of 12-bit binary counter which counts the machine cycle period  $clock(1/f_{OSC} \times 6)$  from 2 to 4096 times. The Prescaler can supply the clock to Timer, Serial Input Output, and the external application through the "SCK/CKOUT" terminal. A frequency of the clock can be selected from 12 kinds shown in follows.

1/2, 1/4, 1/8, 1/16, 1/32, 1/64, 1/128, 1/256, 1/512, 1/1024, 1/2048, 1/4096

When the bit2(b2) of Timer/Prescaler control register(PHY3) is set to "1", the Prescaler operation is stopped, but the output clock is also stopped to Timer, Serial Input Output, and the external application through the "SCK/CKOUT" terminal. When the b2 of PHY3 is set to "0", the Prescaler operation is started to count from "0".



[AROUND THE PRESCALER BLOCK DIAGRAM]

EX.)The output frequency of Prescaler at  $f_{OSC} = 4MHz (\Phi = 4MHz/6)$ 

| Presca | ler Divider | Output Frequency |
|--------|-------------|------------------|
| Ф/2    |             | ·· 333.33kHz     |
| Φ/4    | •••••       | ·· 166.67kHz     |
| Φ/8    |             | ·· 83.33kHz      |
| Ф/16   |             | ·· 41.67kHz      |
| Ф/32   | •••••       | ·· 20.83kHz      |
| Ф/64   | •••••       | ·· 10.42kHz      |
| Φ/128  |             | ·· 5.21kHz       |
| Φ/256  | •••••       | ·· 2.60kHz       |
| Φ/512  | •••••       | ·· 1.30kHz       |
| Ф/1024 |             | ·· 651kHz        |
| Ф/2048 | •••••       | 326kHz           |
| Ф/4096 |             | ·· 163kHz        |

# ■ ABSOLUTE MAXIMUM RATINGS

|                       |                  |                              | (Ta=25°C) |
|-----------------------|------------------|------------------------------|-----------|
| PARAMETER             | SYMBOL           | RATINGS                      | UNIT      |
| Supply Voltage        | V <sub>DD</sub>  | -0.3 - +7.0                  | V         |
| Input Voltage         | V <sub>IN</sub>  | -0.3 – V <sub>DD</sub> + 0.3 | V         |
| Output Voltage        | V <sub>OUT</sub> | -0.3 – V <sub>DD</sub> + 0.3 | V         |
| Operating Temperature | T <sub>opr</sub> | -20 – +75                    | °C        |
| Storage Temperature   | T <sub>stg</sub> | -55 – +125                   | °C        |

■ ELECTRICAL CHARACTERISTICS DC CHARACTERISTICS 1

|                              |                  |                                                                                                                                                     | (V <sub>DD</sub> =4.5 | – 5.5V, V | / <sub>ss</sub> =0V, Ta | =-20 – | 75°C)    |
|------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------|-------------------------|--------|----------|
| PARAMETER                    | SYM<br>BOL       | CONDITIONS                                                                                                                                          | MIN                   | TYP       | MAX                     | UNIT   | NOT<br>E |
| Supply Voltage               | $V_{DD}$         | V <sub>DD</sub>                                                                                                                                     | 3.6                   |           | 5.5                     | V      |          |
|                              | I <sub>DD1</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =5V, f <sub>OSC</sub> =2MHz<br>X'tal Oscillation in Reset                                                        |                       | 2.0       | 4.0                     | mA     | *3       |
| Supply Current               | I <sub>DD2</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =5V, f <sub>OSC</sub> =2MHz<br>Ceramic Oscillation in Reset                                                      |                       | 2.0       | 4.0                     | mA     | *3       |
|                              | I <sub>DD3</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =5V, f <sub>OSC</sub> =2MHz<br>CR Oscillation in Reset                                                           |                       | 1.9       | 3.8                     | mA     | *3       |
|                              | I <sub>DD4</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =5V, STANDBY Mode                                                                                                |                       |           | 4.0                     | μA     | *3       |
| High-Level                   | $V_{\rm IH1}$    | PA0–PA3, PB0–PB3, PC0–PC3,<br>SDI(O)/PF1, SCK/CKOUT                                                                                                 | $0.7V_{DD}$           |           | $V_{DD}$                | V      | *1       |
| Input Voltage                | V <sub>IH2</sub> | PD0, PD1, EXTI/PE0, RESET                                                                                                                           | 0.8V <sub>DD</sub>    |           | V <sub>DD</sub>         | V      | *1       |
|                              | V <sub>IH3</sub> | OSC1                                                                                                                                                | V <sub>DD</sub> -1.0  |           | V <sub>DD</sub>         | V      |          |
| Low-level                    | V <sub>IL1</sub> | PA0–PA3, PB0–PB3, PC0–PC3,<br>SDI(O)/PF1, SCK/CKOUT                                                                                                 | 0                     |           | 0.3V <sub>DD</sub>      | V      | *1       |
| Input Voltage                | V <sub>IL2</sub> | PD0, PD1, EXTI/PE0, RESET                                                                                                                           | 0                     |           | $0.2V_{DD}$             | V      | *1       |
| 1 0                          | V <sub>IL3</sub> | OSC1                                                                                                                                                | 0                     |           | 1.0                     | V      | -        |
| High-Level<br>Input Current  | I <sub>IH</sub>  | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =5.5V<br>PA0–PA3, PB0–PB3, PC0–PC3,<br>PD0, PD1, EXTI/PE0, SDI(O)/PF1,<br>RESET, SCK/CKOUT                   |                       |           | 10                      | μΑ     | *1       |
| Low-Level                    | I <sub>IL1</sub> | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =0V<br>Without pull-up resistance<br>PA0–PA3, PB0–PB3, PC0–PC3,<br>PD0, PD1, EXTI/PE0, SDI(O)/PF1,<br>RESET  |                       |           | -10                     | μΑ     | *1       |
| Input Current                | I <sub>IL2</sub> | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =0V<br>With pull-up resistance<br>PA0–PA3, PB0–PB3, PC0–PC3,<br>PD0, PD1, EXTI/PE0, SDI(O)/PF1,<br>SCK/CKOUT |                       |           | -100                    | μΑ     | *1       |
| High-Level<br>Output Voltage | V <sub>OH</sub>  | I <sub>OH</sub> =-100μA<br>PA0–PA3, PC0–PC3, PD0, PD1,<br>SDO/PF0, SDI(O)/PF1, SCK/CKOUT                                                            | V <sub>DD</sub> -0.5  |           |                         | V      | *2       |
| Low-Level<br>Output Voltage  | V <sub>OL1</sub> | I <sub>OL1</sub> =400μA<br>PA0–PA3, PC0–PC3, PD0, PD1,<br>SDO/PF0, SDI(O)/PF1, SCK/CKOUT                                                            |                       |           | 0.5                     | V      | *2       |
| Output voltage               | $V_{OL2}$        | I <sub>OL2</sub> =15mA<br>PB0–PB3                                                                                                                   |                       |           | 2.0                     | V      | *2       |
| Output<br>Leakage<br>Current | I <sub>OD</sub>  | V <sub>DD</sub> =5.5V, V <sub>OH</sub> =5.5V<br>PB0–PB3                                                                                             |                       |           | 10                      | μA     | *2       |
| Input Capacitance            | C <sub>IN</sub>  | Except $V_{DD}$ , $V_{SS}$ terminals $f_{OSC}$ =1MHz Other terminals : 0V                                                                           |                       | 10        | 20                      | pF     |          |

\*1 Input/output port is set as an Input terminal.

\*2 Input/output port is set as an Output terminal. \*3 Except the current through Pull-up resister.

# ■ ELECTRICAL CHARACTERISTICS DC CHARACTERISTICS 2

 $(V_{DD}=2.4 - 3.6V, V_{SS}=0V, Ta=-20 - 75^{\circ}C)$ 

|                              |                  |                                                                                                                                                     | $(v_{DD}=2.$         | 4 – 3.0%, | V <sub>SS</sub> =0V, Ta | 1 <u></u> 20 - | <i>,</i> |
|------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------|-------------------------|----------------|----------|
| PARAMETER                    | SYM<br>BOL       | CONDITIONS                                                                                                                                          | MIN                  | TYP       | MAX                     | UNIT           | NOT<br>E |
| Supply Voltage               | $V_{DD}$         | V <sub>DD</sub>                                                                                                                                     | 2.4                  |           | 3.6                     | V              |          |
|                              | I <sub>DD1</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =3V, f <sub>OSC</sub> =1MHz<br>X'tal Oscillation in Reset                                                        |                      | 1.0       | 2.0                     | mA             | *3       |
| Supply Current               | I <sub>DD2</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =3V, f <sub>OSC</sub> =1MHz<br>Ceramic Oscillation in Reset                                                      |                      | 1.0       | 2.0                     | mA             | *3       |
|                              | I <sub>DD3</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =3V, f <sub>OSC</sub> =1MHz<br>CR Oscillation in Reset                                                           |                      | 0.9       | 1.8                     | mA             | *3       |
|                              | I <sub>DD4</sub> | V <sub>DD</sub><br>V <sub>DD</sub> =3V, STANDBY Mode                                                                                                |                      |           | 2.0                     | μΑ             | *3       |
| High-Level                   | V <sub>IH1</sub> | PA0–PA3, PB0–PB3, PC0–PC1,<br>SDI(O)/PL1, SCK/CKOUT                                                                                                 | $0.8V_{DD}$          |           | V <sub>DD</sub>         | V              | *1       |
| Input Voltage                | V <sub>IH2</sub> | PD0, PD1, EXTI/PE0, RESET                                                                                                                           | $0.85V_{DD}$         |           | V <sub>DD</sub>         | V              | *1       |
|                              | V <sub>IH3</sub> | OSC1                                                                                                                                                | V <sub>DD</sub> -0.3 |           | V <sub>DD</sub>         | V              |          |
| Low-level                    | $V_{IL1}$        | PA0–PA3, PB0–PB3, PC0–PC3,<br>SDI(O)/PF1, SCK/CKOUT                                                                                                 | 0                    |           | $0.2V_{DD}$             | V              | *1       |
| Input Voltage                | $V_{IL2}$        | PD0, PD1, EXTI/PE0, RESET                                                                                                                           | 0                    |           | 0.15V <sub>DD</sub>     | V              | *1       |
|                              | V <sub>IL3</sub> | OSC1                                                                                                                                                | 0                    |           | 0.3                     | V              |          |
| High-Level<br>Input Current  | I <sub>IH</sub>  | V <sub>DD</sub> =3.6V, V <sub>IN</sub> =3.6V<br>PA0–PA3, PB0–PB3, PC0–PC3,<br>PD0, PD1, EXTI/PE0, SDI(O)/PF1,<br>RESET, SCK/CKOUT                   |                      |           | 10                      | μΑ             | *1       |
| Low-Level                    | I <sub>IL1</sub> | V <sub>DD</sub> =3.6V, V <sub>IN</sub> =0V<br>Without pull-up resistance<br>PA0–PA3, PB0–PB3, PC0–PC3,<br>PD0, PD1, EXTI/PE0, SDI(O)/PF1,<br>RESET  |                      |           | -10                     | μΑ             | *1       |
| Input Current                | I <sub>IL2</sub> | V <sub>DD</sub> =3.6V, V <sub>IN</sub> =0V<br>With pull-up resistance<br>PA0–PA3, PB0–PB3, PC0–PC3,<br>PD0, PD1, EXTI/PE0, SDI(O)/PF1,<br>SCK/CKOUT |                      |           | -100                    | μΑ             | *1       |
| High-Level<br>Output Voltage | V <sub>OH</sub>  | I <sub>OH</sub> =-80μA<br>PA0–PA3, PC0–PC3, PD0, PD1,<br>SDO/PF0, SDI(O)/PF1, SCK/CKOUT                                                             | V <sub>DD</sub> -0.5 |           |                         | V              | *2       |
| Low-Level                    | V <sub>OL1</sub> | I <sub>OL1</sub> =350μA<br>PA0–PA3, PC0–PC3, PD0, PD1,<br>SDO/PF0, SDI(O)/PF1, SCK/CKOUT                                                            |                      |           | 0.5                     | V              | *2       |
| Output Voltage               | $V_{OL2}$        | I <sub>OL2</sub> =5mA<br>PB0–PB3                                                                                                                    |                      |           | 1.0                     | V              | *2       |
| Output<br>Leakage<br>Current | I <sub>OD</sub>  | V <sub>DD</sub> =3.6V, V <sub>OH</sub> =3.6V<br>PB0–PB3                                                                                             |                      |           | 10                      | μA             | *2       |
| Input Capacitance            | C <sub>IN</sub>  | Except V <sub>DD</sub> , V <sub>SS</sub> terminals<br>f <sub>OSC</sub> =1MHz<br>Other terminals : 0V                                                |                      | 10        | 20                      | pF             |          |

\*1 Input/output port is set as an Input terminal.

\*2 Input/output port is set as an Output terminal.

\*3 Except the current through Pull-up resister.

# ■ ELECTRICAL CHARACTERISTICS AC CHARACTERISTICS 1

|                                                 |                                      |                           |                                      |                    | (V <sub>SS</sub> =0V, | Ta= -20 –  | -75°C)  |
|-------------------------------------------------|--------------------------------------|---------------------------|--------------------------------------|--------------------|-----------------------|------------|---------|
| PARAMETER                                       | SYM<br>BOL                           | CON                       | DITIONS                              | MIN                | TYP                   | MAX        | UNIT    |
|                                                 |                                      |                           | X'tal Resonator<br>Ceramic Resonator | 0.03<br>0.03       |                       | 2.0<br>2.0 | -       |
|                                                 |                                      | V <sub>DD</sub> =2.4-3.6V | External Resistor<br>Oscillation     | 0.03               |                       | 1.0        | -       |
| Operating                                       | f                                    |                           | External Clock                       | 0.03               |                       | 2.0        | MHz     |
| Frequency                                       | f <sub>OSC</sub>                     |                           | X'tal Resonator                      | 0.03               |                       | 4.0        | 1011 12 |
|                                                 |                                      |                           | Ceramic Resonator                    | 0.03               |                       | 4.0        |         |
|                                                 |                                      | V <sub>DD</sub> =3.6-5.5V | External Resistor<br>Oscillation     | 0.03               |                       | 2.0        |         |
|                                                 |                                      |                           | External Clock                       | 0.03               |                       | 4.0        |         |
| Instruction Cycle<br>Time                       | t <sub>C</sub>                       |                           |                                      |                    | 6/f <sub>OSC</sub>    |            | s       |
| External Clock                                  | t <sub>CPH</sub>                     | V <sub>DD</sub> =2.4-3.6V |                                      | 250                |                       | 16600      | 20      |
| Pulse Width                                     | t <sub>CPL</sub>                     | V <sub>DD</sub> =3.6-5.5V |                                      | 125                |                       | 16600      | ns      |
| External Clock<br>Rise Time<br>Fall Time        | t <sub>CPR</sub><br>t <sub>CPF</sub> | V <sub>DD</sub> =2.4-5.5V |                                      |                    |                       | 20         | ns      |
| RESET Low-Level<br>Width                        | t <sub>RST</sub>                     | V <sub>DD</sub> =2.4-5.5V |                                      | 4/f <sub>osc</sub> |                       |            | s       |
| RESET Rise Time                                 | t <sub>RSR</sub>                     | V <sub>DD</sub> =2.4-5.5V |                                      |                    |                       | 20         | ms      |
| Port Input Level<br>Width                       | t <sub>PIN</sub>                     | V <sub>DD</sub> =2.4-5.5V |                                      | 6/f <sub>OSC</sub> |                       |            | s       |
| Edge Detection (PD1)<br>Rise Time<br>Fall Time  | t <sub>EDR</sub><br>t <sub>EDF</sub> | V <sub>DD</sub> =2.4-5.5V |                                      |                    |                       | 200        | ns      |
| Restart Signal (PD0)<br>Rise Time               | t <sub>STR</sub>                     | V <sub>DD</sub> =2.4-5.5V |                                      |                    |                       | 200        | ns      |
| External interrupt<br>input (EXTI)<br>Rise Time | t <sub>EXR</sub>                     | V <sub>DD</sub> =2.4-5.5V |                                      |                    |                       | 200        | ns      |

# ■ AC CHARACTERISTICS 1 TIMING CHART



# ■ ELECTRICAL CHARACTERISTICS AC CHARACTERISTICS 2 SERIAL INTERFACE

|                                       |                  |                |                                                      | (V <sub>SS</sub> =0V, V <sub>E</sub> | <sub>DD</sub> =2.4 - 5.5 | /, Ta= -20 –              | 75°C)    |
|---------------------------------------|------------------|----------------|------------------------------------------------------|--------------------------------------|--------------------------|---------------------------|----------|
| PARAMETER                             | SYM<br>BOL       | CONDI          | TIONS                                                | MIN                                  | TYP                      | MAX                       | UNI<br>T |
| Serial Operating                      | f <sub>sc</sub>  | Internal Clock |                                                      |                                      |                          | (1/12)×f <sub>OSC</sub> * | Hz       |
| Frequency                             | ISC              | External Clock |                                                      |                                      |                          | 500k                      | I IZ     |
| Clock Pulse Width                     |                  | Internal Clock | V <sub>DD</sub> =2.7–3.6V<br>f <sub>OSC</sub> =2MHz  | 3.0                                  |                          |                           |          |
| Low-Level                             | t <sub>SCL</sub> | Internal Clock | V <sub>DD</sub> =3.6–5.5V<br>f <sub>OSC</sub> =4MHz  | 1.5                                  |                          |                           | μs       |
|                                       |                  | External Clock |                                                      | 1.0                                  |                          |                           |          |
| Clock Pulse Width                     |                  | Internal Clock | V <sub>DD</sub> =2.7–3.6V<br>f <sub>OSC</sub> =2MHz  | 3.0                                  |                          |                           |          |
| High-Level                            | t <sub>SCH</sub> |                | V <sub>DD</sub> =3.6 –5.5V<br>f <sub>OSC</sub> =4MHz | 1.5                                  |                          |                           | μs       |
|                                       |                  | External Clock |                                                      | 1.0                                  |                          |                           |          |
| SDI setup Time<br>To SCK ↑            | t <sub>DS</sub>  |                |                                                      | 0.5                                  |                          |                           | μs       |
| SDI Hold time<br>To SCK ↑             | t <sub>DH</sub>  |                |                                                      | 0.5                                  |                          |                           | μs       |
| SDO Data Fix Time To SCK $\downarrow$ | t <sub>DCD</sub> |                |                                                      |                                      |                          | 0.5                       | μs       |

\* The dividing ratio of the internal clock is 1/2.

# ■ AC CHARACTERISTICS 2 SERIAL INTERFACE TIMING CHART



# OPTION as same as mask version

1) INPUT OUTPUT Terminal Selection

All of input-output terminals select a terminal type for each port from the following table1 and table2 by the mask option.

# [ CIRCUIT TYPE TABLE 1 ]

|        |                              |                |                                | TERMINAL TYPES         |  |  |  |
|--------|------------------------------|----------------|--------------------------------|------------------------|--|--|--|
|        | Input / Output<br>Terminal*1 |                |                                |                        |  |  |  |
| SYMBOL | Port of Input                | Port of Output | Programmable<br>Input / Output | EXTRA FUNCTION REMARKS |  |  |  |
| PA0    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PA1    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PA2    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PA3    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PB0    |                              |                | C<br>D                         |                        |  |  |  |
| PB1    |                              |                | C<br>D                         |                        |  |  |  |
| PB2    |                              |                | C<br>D                         |                        |  |  |  |
| PB3    |                              |                | C<br>D                         |                        |  |  |  |
| PC0    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PC1    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PC2    | IA<br>IC                     | OB             |                                |                        |  |  |  |
| PC3    | IA<br>IC                     | OB             |                                |                        |  |  |  |

Note) The symbol in the above table is the same as in mask option generator software.

\*1) The symbol and the detail circuits of INPUT OUTPUT TERMINAL are written in INPUT OUTPUT TERMINAL TYPE.

### [ CIRCUIT TYPE TABLE 2 ]

|                      |                              |                |                                | TERMIN                       | AL TYPES                                  |            |                                            |  |
|----------------------|------------------------------|----------------|--------------------------------|------------------------------|-------------------------------------------|------------|--------------------------------------------|--|
|                      | Input / Output<br>Terminal*1 |                |                                |                              |                                           |            |                                            |  |
| SYMBOL               | Port of Input                | Port of Output | Programmable<br>Input / Output | EXTRA FUNCTION REMARKS       |                                           |            | REMARKS                                    |  |
| PD0                  | IB<br>ID                     | OB             |                                |                              | Restart signal input                      |            |                                            |  |
| PD1                  | IB<br>ID                     | OB             |                                |                              | Edge detection                            | P<br>N     | Rise edge detection<br>Fall edge detection |  |
| EXTI / PE0<br>*2     | IB<br>ID                     |                |                                |                              | External interrupt input<br>(EXTI)        |            |                                            |  |
| SDO / PF0            |                              | OB             |                                | SO                           | Serial data output                        | MSB        | MSB first                                  |  |
| SDI(O) / PF1<br>*2   | IA<br>IC                     | OB             |                                | SD                           | Serial data input/output                  | LSB        | LSB first                                  |  |
| SCK / CKOUT<br>*2 *3 |                              |                |                                | SK Serial clock input/output |                                           | ,<br> <br> |                                            |  |
|                      |                              |                |                                | СКОИТ                        | CKOUT Output clock divide<br>by prescaler |            | <br> <br>                                  |  |

Note) The symbol in the above table is the same as in mask option generator software.

\*1) The symbol and the detail circuits of INPUT OUTPUT TERMINAL are written in INPUT OUTPUT TERMINAL TYPE.

\*2) The pull-up resistance is added to the terminal selected as the extra function.

\*3) When Serial INPUT-OUTPUT is selected, "SK" is selected automatically. When it is not selected, "CKOUT" is selected automatically.

2) PD1 terminal is added the "Edge detect function" by the mask option.



3) The data order (MSB, LSB) of the Serial Interface

The data order of the Serial Interface is selected select either MSB or LSB first by the mask option.

4) Dividing ration of the internal clock

Each dividing ration of the count clocks of Timer, the Internal shift clock of the Serial Interface and the output clock through the SCK/CKOUT terminal is selected among the following by the mask option. The frequency of each clock is determined by the dividing ration and the 1-instruction term (1/f<sub>OSC</sub>x6).

1/2, 1/4, 1/8, 1/16, 1/32, 1/64, 1/128, 1/256, 1/512, 1/1024, 1/2048, 1/4096

Note) As the shift clock of the serial interface, the external clock or the internal is selected by the program.



# ■ MNEMONIC LIST

|        | Mnemonic                | Operation code | Function                                     | Status | Cycle | Memo                                      |
|--------|-------------------------|----------------|----------------------------------------------|--------|-------|-------------------------------------------|
|        | TAY                     | 04             | Y←AC                                         | 1      | 1     | RPC=0                                     |
|        |                         |                | Y'←AC                                        | 1      | 1     | RPC=1                                     |
|        | TYA                     | 14             | AC←Y                                         | 1      | 1     | RPC=0                                     |
|        |                         |                | AC←Y'                                        | 1      | 1     | RPC=1                                     |
|        | ХАХ                     |                | AC↔X                                         | 1      |       | RPC=0                                     |
|        |                         |                | AC⇔X'                                        | 1      | 1     | RPC=1                                     |
|        | TAP                     |                | PH(Y')←AC                                    | 1      | 1     |                                           |
|        | TPA                     |                | AC←PH(Y')                                    | 1      | 1     |                                           |
|        | TAPICY                  |                | PH(Y')←AC, Y←Y+1                             | *      | 1     |                                           |
| Ю      | TAPDCY                  |                | PH(Y')←AC, Y←Y-1                             | *      | 1     |                                           |
| ENCI   | TMA                     |                | $AC \leftarrow M(X,Y)$                       | 1      | 1     |                                           |
| R      | TAM                     |                | M(X,Y)←AC                                    | 1      | 1     |                                           |
| SFERI  | TAMICY                  |                | $M(X,Y) \leftarrow AC, Y \leftarrow Y+1$     | *      | 1     |                                           |
| SZ     |                         |                | $M(X,Y) \leftarrow AC, Y \leftarrow Y-1$     | *      | 1     |                                           |
| Z<br>Z | TAMDCY<br>TMY           |                | $Y \leftarrow M(X,Y)$                        | 1      | 1     | RPC=0                                     |
| Ë      |                         | 00             | $Y' \leftarrow M(X,Y)$                       | 1      | 1     | RPC=1                                     |
| ~      | YMA                     | 0B             | $AC \leftrightarrow M(X,Y)$                  | 1      | 1     |                                           |
| Ę      | XMA<br>TPMICY           |                | $M(X,Y) \leftarrow PH(Y'), Y \leftarrow Y+1$ | *      | 1     |                                           |
| ò      | TMPICY                  |                | $PH(Y') \leftarrow M(X,Y), Y \leftarrow Y+1$ | *      | 1     |                                           |
|        | TRM                     |                |                                              | 1      | 2     | Y = an even number : ROM of 4bit low-data |
|        |                         | 23             | M(X,Y)←ROM(PHY13,X',AC)                      | 1      | 2     | Y = an odd number : ROM of 4bit hi-data   |
|        |                         | 00             |                                              | 4      |       | Y = an odd number : ROM of 4bit ni-data   |
|        |                         |                |                                              | 1      | 1     | #/ 0.45                                   |
|        | LDI A,#K                |                | AC←#K                                        | 1      |       | #K=0-15                                   |
|        | LDI Y,#K                |                | Y←#K                                         | 1      |       | RPC=0, #K=0-15                            |
|        |                         |                | Y'←#K                                        | 1      |       | RPC=1, #K=0–15                            |
|        | LDI X,#K                |                | X←#K                                         | 1      |       | RPC=0, #K=0-15                            |
|        |                         |                | X'~#K                                        | 1      | 1     | RPC=1, #K=0–15                            |
|        | ADD A,M                 | 0E             | AC←AC+M(X,Y)                                 | *      | 1     |                                           |
|        | INC A                   |                | AC←AC+1                                      | *      | 1     |                                           |
|        | DEC A                   |                | AC←AC-1                                      | *      | 1     |                                           |
|        | ADD A,#K                |                | AC←AC+#K                                     | *      |       | #K=0–15                                   |
|        | AND A,M                 |                | AC←AC∧M(X,Y)                                 | *      | 1     |                                           |
|        | CMP A,M                 |                | AC < >M(X,Y)                                 | *      | 1     |                                           |
|        | CMP Y,#K                |                | Y< >#K                                       | *      |       | #K=0-15                                   |
| Z      | INC Y<br>DEC Y<br>INC M | 08             | Y←Y+1                                        | *      |       | RPC=0                                     |
| Ē      |                         |                | Y'←Y'+1                                      | *      |       | RPC=1                                     |
| Ţ      | DEC Y                   | 18             | Y←Y-1                                        | *      | 1     | RPC=0                                     |
| ر<br>ن |                         |                | Y'←Y'-1                                      | *      | 1     | RPC=1                                     |
| Ā      | INC M                   |                | AC←M(X,Y)+1                                  | *      | 1     |                                           |
| Ö      |                         |                | AC←M(X,Y)-1                                  | *      | 1     |                                           |
|        | YNEA                    |                | Y< >AC                                       | *      | 1     |                                           |
|        | OR A,M                  |                | AC←AC∨M(X,Y)                                 | *      | 1     |                                           |
|        | XOR A,M                 |                | AC←AC⊕M(X,Y)                                 | *      | 1     |                                           |
|        | NEG                     | 2D             | AC←0-AC                                      | 1      | 1     |                                           |
|        | SUB A,M                 | 1E             | AC←M(X,Y)-AC                                 | *      | 1     |                                           |
|        | AND A,#K                |                | AC←AC∧#K                                     | *      | 1     | #K=0–15                                   |
|        | OR A,#K                 | 50–5F          | AC←AC∨#K                                     | *      | 1     | #K=0–15                                   |

# NJU3502

|           | Mne                 | emonic | Operation code     | Function                                                                                                 | Status | Cycle | Memo                                                                     |
|-----------|---------------------|--------|--------------------|----------------------------------------------------------------------------------------------------------|--------|-------|--------------------------------------------------------------------------|
|           |                     | addr   |                    | ST=1:PC←addr, ST=0:No branch                                                                             | 1      | 2     | 2byte Mnemonic                                                           |
|           | JMP                 | addr   | C0–FF              | ST=1:PC←addr, ST=0:No branch                                                                             | 1      | 1     |                                                                          |
| НС        | CALL<br>RET<br>RETI | addr   | 60–67              | ST=1:(SP)←PC+2, SP←SP+1, PC←addr                                                                         | 1      | 2     | 2byte Mnemonic                                                           |
| N         | огт                 |        | 20                 | ST=0:No branch                                                                                           | 4      | 1     |                                                                          |
| R/        |                     |        | 2B<br>2C           | $PC \leftarrow (SP), SP \leftarrow SP-1$<br>$PC \leftarrow (SP), AC \leftarrow (SP), SP \leftarrow SP-1$ | 1      | 1     |                                                                          |
| ш         | 1                   |        | 20                 | $X \leftarrow (SP), X' \leftarrow (SP), Y \leftarrow (SP), Y' \leftarrow (SP)$                           |        | l '   |                                                                          |
|           |                     |        |                    | $RPC \leftarrow (SP), ST \leftarrow (SP)$                                                                |        |       |                                                                          |
|           | SBIT                | b      | 30–33              | M(X,Y)b←1                                                                                                | 1      | 1     | B=0-3                                                                    |
|           | RBIT                | b      |                    | M(X,Y)b←0                                                                                                | 1      | 1     | B=0-3                                                                    |
|           | TBIT                | b      | 38–3B              | ST←M(X,Y)b                                                                                               | *      | 1     | B=0-3                                                                    |
|           | TBA                 | b      | 3C–3F              | ST←(AC)b                                                                                                 | *      | 1     | B=0-3                                                                    |
|           | RAR                 |        | 21                 |                                                                                                          | *      | 1     |                                                                          |
|           |                     |        |                    | $ \hookrightarrow \boxed{CY} \rightarrow \boxed{b3} \boxed{b2} \boxed{b1} \boxed{b0} \dashv $            |        |       |                                                                          |
|           | RAL                 |        | 22                 |                                                                                                          | *      | 1     |                                                                          |
|           |                     |        |                    | $\Box$ CY $\leftarrow$ b3 b2 b1 b0 $\leftarrow$                                                          |        |       |                                                                          |
|           | RYR                 |        | 24                 | Y                                                                                                        | *      | 1     | RPC=0                                                                    |
|           |                     |        |                    | $\rightarrow$ CY $\rightarrow$ b3 b2 b1 b0 $\rightarrow$                                                 |        |       |                                                                          |
|           |                     |        |                    | Y'                                                                                                       | *      | 1     | RPC=1                                                                    |
| Z         |                     |        |                    | $\rightarrow$ CY $\rightarrow$ b3 b2 b1 b0 $\rightarrow$                                                 |        |       |                                                                          |
| ЦC        | RYL                 |        | 25                 |                                                                                                          | *      | 1     | RPC=0                                                                    |
| ZA.       |                     |        | 20                 | $CY \leftarrow b3 b2 b1 b0 \leftarrow$                                                                   |        | '     |                                                                          |
| OPERATION |                     |        |                    |                                                                                                          |        |       |                                                                          |
| 0         |                     |        |                    | $CY \leftarrow b3 b2 b1 b0 \leftarrow$                                                                   | *      | 1     | RPC=1                                                                    |
| ⊢         |                     |        |                    |                                                                                                          |        |       |                                                                          |
| B         | RXR                 |        | 28                 | $\rightarrow$ CY $\rightarrow$ b3 b2 b1 b0 $\rightarrow$                                                 | *      | 1     | RPC=0                                                                    |
|           |                     |        |                    |                                                                                                          |        |       |                                                                          |
|           |                     |        |                    |                                                                                                          | *      | 1     | RPC=1                                                                    |
|           |                     |        |                    |                                                                                                          |        |       |                                                                          |
|           | RXL                 |        | 29                 | X                                                                                                        | *      | 1     | RPC=0                                                                    |
|           |                     |        |                    | └──CY ← b3 b2 b1 b0 ←                                                                                    |        |       |                                                                          |
|           |                     |        |                    | X'                                                                                                       | *      | 1     | RPC=1                                                                    |
|           |                     |        |                    | $\Box CY \leftarrow b3 b2 b1 b0 \leftarrow$                                                              |        |       |                                                                          |
|           | SEC                 |        | 0C                 | CY←1                                                                                                     | 1      | 1     |                                                                          |
|           | CLC                 |        | 1C                 | CY←0                                                                                                     | 0      | 1     |                                                                          |
|           | SRPC                | ;      | 10                 | RPC←1                                                                                                    | 1      | 1     |                                                                          |
|           | RRPC                | )      | 20                 | RPC←0                                                                                                    | 1      | 1     |                                                                          |
| ٦۲        | NOP                 |        | 00                 | No Operation                                                                                             | 1      | 1     |                                                                          |
| SPECIAL   | HLT                 |        | 07                 | CPU Halted                                                                                               | 1      | 1     |                                                                          |
| R         | MDT                 |        | 06                 | Memory Dump Test                                                                                         | -      | -     |                                                                          |
|           | Note)               |        |                    |                                                                                                          |        |       |                                                                          |
|           |                     | ← :    | Transfer dired     |                                                                                                          |        |       | Stack pointer                                                            |
|           |                     |        | AND                | X :Xregister                                                                                             |        |       | RPC flag                                                                 |
|           |                     |        | OR<br>Exclusive OR | X' :X'register<br>Y :Yregister                                                                           |        |       | :Carry flag<br>:Status flag                                              |
|           |                     |        | Add                | Y' :Y'register                                                                                           |        |       | Immediate data                                                           |
|           |                     |        | Subtraction        | PH :Peripheral register                                                                                  |        |       | Blanch address                                                           |
|           |                     | <> :(  | Comparison         | M :Data memory<br>ROM :Program memory                                                                    | (      | ()    | A content of register or memory pointed by the address indicated in ( ). |
|           |                     |        |                    | PC :Program counter                                                                                      | I      | c c   | Bit position                                                             |

Status description)

0:After the command execution, ST-flag is always set to "0".

1:After the command execution, ST-flag is always set to "1".

\*:Status

[CAUTION] The specifications on this databook are only given for information , without any guarantee as regards either mistakes or omissions. The application circuits in this databook are described only to show representative usages of the product and not intended for the guarantee or permission of any right including the industrial rights.

New Japan Radio Co.,Ltd.