# 4-BIT SINGLE CHIP MICRO CONTROLLER #### **GENERAL DESCRIPTION** The NJU3505 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, Dual Timer/Counter, 8-bit Serial Interface, 8-bit A/D Converter, and Oscillator Circuit (CR or Ceramic or X'tal). It realizes the control for home appliances or toys by only few external components. The NJU3505 is suitable for battery operated appliances because of low operating current, wide operating voltage range, and STANDBY function (HALT mode). ## **PACKAGE OUTLINE** NJU3505FA1 NJU3505L #### **FEATURES** Internal Program ROM Internal Data RAM Input / Output Port 8.192 X 8 bits 256 X 4 bits 35 lines(MAX) / NJU3505FA1 33 lines(MAX) / NJU3505L 17 lines · Input / Output direction of each bit is selected by the mask option. 4 lines · · · Input / Output direction of the 4-bit lines' group can be changed by the program. Additional functions by the mask option. **External Interrupt Terminal** External Clock Input Terminal for Timer2 : CNTI/PK1 Serial Interface Terminals A/D Converter Interface Terminals : EXTI/PK0 : SDO/PL0, SDI(O)/PL1 : AIN0~3/PI0~3, VREF/PJ0, ADCK/PJ1 15mA at Voo=5V (PA0~PA3, PB0~PB3, PC0, PC1) 4 (external, timer1, timer2, serial Input / Output) High Output-Current terminal (10 lines) N-Channel FET Open Drain Type (IoL) Instruction Set 59 instructions 8 levels Subroutine Nesting Pulse Edge Detector The rising or falling edge of a pulse is selected by the mask option. Instruction Executing Time 6/fosc sec (1.5 µ sec at 4MHz) **Operating Frequency Range** Internal Oscillator 30kHz to 4MHz 2.4V to 5.5V CR, or Ceramic, or X'tal oscillation and External clock input STANDBY function (HALT mode) Wide operating voltage range 8-bit Serial Input / Output port Timer/Counter (Timer1: 8-bit re-load type timer, Timer2: 12-bit re-load type timer event counter) (Count clock: Timer1's clock is an internal one. Timer2's clock is an internal or external one.) Interrupt factor C-MOS technology Package outline 8-bit A/D converter (Multiplexed 8-channel input ) QFP44-A1 / SDIP42 3 # **■ TERMINAL DESCRIPTION 1** | N | 0. | | | | |-------|-------|--------|--------------|-------------------------------------------------------------------------| | NJU | NJU | SYMBOL | INPUT/OUTPUT | FUNCTIONS | | 3505F | 3505L | | | | | 44 | 5 | PF0 | INPUT/OUTPUT | 3-bit Input / Output PORTF. | | 1 | 6 | PF1 | INPUT/OUTPUT | Selects a terminal circuit for each port from follows by the | | 2 | 7 | PF2 | INPUT/OUTPUT | mask option. | | | | | | C-MOS Schmitt Trigger Input Terminal with Pull-up | | | | | | Resistance (ISP) | | | | | | C-MOS Schmitt Trigger Input Terminal (IS) | | | | | | OC-MOS Output Terminal (OC) | | 3 | Х | PG0 | INPUT/OUTPUT | 2-bit Input / Output PORTG. | | 4 | Х | PG1 | INPUT/OUTPUT | Selects a terminal circuit for each port from follows by the | | | | | | mask option. | | | | | | C-MOS Schmitt Trigger Input Terminal with Pull-up | | | | | | Resistance (ISP) | | | | | | C-MOS Schmitt Trigger Input Terminal (IS) | | | | | | OC-MOS Output Terminal (OC) | | 5 | 8 | PH0 | INPUT/OUTPUT | 2-bit Input / Output PORTH. | | 6 | 9 | PH1 | INPUT/OUTPUT | Selects a terminal circuit for each port from follows by the | | | | | | mask option. | | | | | | C-MOS Schmitt Trigger Input Terminal with Pull-up | | | | | | Resistance (ISP) | | | | | | C-MOS Schmitt Trigger Input Terminal (IS) | | | | | | OC-MOS Output Terminal (OC) | | | | | | When the ports are selected as the input terminal, PH0 | | | | | | operates also as RESTART signal input terminal to return | | | | | | from STANDBY mode, and PH1 operates also as the Edge Detector Terminal. | | 7 | 10 | | INPUT | RESET Terminal. | | 7 | 10 | RESET | INPUI | When the low level input-signal, the system is initialized. | | 8 | 11 | TEST | INPUT | Maker Testing Terminal with Pull-down Resistance | | | '' | 1201 | 1141 01 | The terminal is recommended to connect to GND. | | 9 | 12 | OSC1 | INPUT | Internal Oscillator Terminals. | | 10 | 13 | OSC2 | OUTPUT | Connects a device selected from the ceramic or the crystal | | 1 . | . | 0002 | | 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. | | 11 | 14 | Vss | _ | Power Source ( 0V ) | | 12 | 15 | AVss | _ | Analog Block Power Source ( 0V ) | | | | | | Connects to Vss terminal when A/D converter is not used. | Note ) INPUT/OUTPUT : Input or Output is selected by the mask option. INOUT : Input or Output is changed by the program. X : No terminals in the NJU3505L(SDIP package). # ■ TERMINAL DESCRIPTION 2 | N | 0. | | | | |-------|-------|--------------|------------------|----------------------------------------------------------------------------------------------------| | NJU | NJU | SYMBOL | INPUT/OUTPUT | FUNCTION | | 3505F | 3505L | OTTOBOL | 1111 0170011 01 | 1 3 11 3 11 | | 13 | 16 | AIN0 / PI0 | INPUT | 4-bit Input PORTI. | | | | | | Selects a function of either of 1) or 2) for PORTI by the | | 14 | 17 | AIN1 / PI1 | INPUT | mask option. | | 15 | 18 | AIN2 / PI2 | INPUT | 1) 4-bit Analog Input to A/D Converter. (AD) | | 16 | 19 | AIN3 / PI3 | INPUT | 2) 4-bit Input Terminals as PORTI. | | | | | | Selects a terminal circuit for each port from follows by the | | | | | | mask option. | | | | | | •C-MOS Input Terminal with Pull-up Resistance (ICP) | | | | | | C-MOS Input Terminal with un-up Resistance (ICI) C-MOS Input Terminal (IC) | | 10 | 21 | $AV_{DD}$ | | Analog Block Power source | | 18 | 21 | AVDD | _ | Connect to Vpp terminal when A/D converter is not used. | | 47 | | )/ / DIO | INDUT | | | 17 | 20 | VREF / PJO | INPUT | 2-bit Input PORTJ. | | 19 | 22 | ADCK / PJ1 | INPUT | Selects a function of either of 1) or 2) for PORTJ by the | | | | | | mask option. | | | | | | 1) Input terminal for A/D Converter. | | | | | | Reference Voltage Input Terminal : V <sub>REF</sub> (AD) External Clock Input Terminal : ADCK (AD) | | | | | | 2) 2-bit Input Terminals as PORTJ. | | | | | | Selects a terminal circuit for each port from follows by the | | | | | | mask option. | | | | | | C-MOS Schmitt Trigger Input Terminal with Pull-up | | | | | | | | | | | | Resistance (ISP) | | | | EVEL / DIG | INDUT | C-MOS Schmitt Trigger Input Terminal (IS) A bit Input PORTIC | | 20 | 23 | EXTI / PK0 | INPUT | 2-bit Input PORTK. | | 21 | 24 | CNTI / PK1 | INPUT | Selects a function of either of 1) or 2) for PORTK by the | | | | | | mask option. 1) External Interrupt Input Terminal with Pull up | | | | | | resistance :EXTI (R/F) | | | | | | External Clock Input Terminal with Pull up resistance for | | | | | | Timer2 :CNTI (IIP,II) | | | | | | 2) 2-bit Input Terminals as PORTK. | | | | | | Selects a terminal circuit for each port from follows by | | | | | | the mask option. | | | | | | C-MOS Schmitt Trigger Input Terminal with Pull-up | | | | | | Resistance (ISP) | | | | | | C-MOS Schmitt Trigger Input Terminal (IS) | | 1 | | | | -3 m30 dominic ringgor input rominiai (10) | | 22 | 25 | SDO / PL0 | SDO :OUTPUT | 2-bit Input / Output PORTL. | | | | | PL0 :OUTPUT | Selects a function of either of 1) or 2) for PORTL by the | | 23 | 26 | SDI(O) / PL1 | SDI(O) :INOUT | mask option. | | | | _ = -(-) / | PL1 : | 1) Serial Interface Function | | | | | INPUT/OUTPUT | Serial Data Output Terminal : SDO (SO) | | | | | 11.11.01/0011.01 | Serial Data Input-Output Terminal with Pull-up | | | | | | Resistance : SDI(O) (SDP) | | | | | | 2) 2-bit Input / Output Terminals as PORTL. | | | | | | Selects a terminal circuit for each port from follows by the | | | | | | mask option. | | 1 | | | | C-MOS Input Terminal with Pull-up Resistance (ICP):PL1 | | 1 | | | | C-MOS Input Terminal (IC) : PL1 | | | | | | O-MOS Output Terminal (OC): PL0,PL1 | Note ) INPUT/OUTPUT : Input or Output is selected by the mask option. INOUT : Input or Output is changed by the program. # ■ TERMINAL DESCRIPTION 3 | N | 0. | | | | |-------|-------|-----------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NJU | NJU | SYMBOL | INPUT/OUTPUT | FUNCTION | | 3505F | 3505L | | | | | 24 | 27 | SCK /<br>CKOUT | SCK :INOUT<br>CKOUT :<br>OUTPUT | Selects a function of either of 1) or 2) by the mask option. 1) Serial Clock Input or Output Terminal with Pull-up Resistance. (SCP) 2) Clock Divided by Prescaler Output Terminal. Selects the dividing times of the clock in the prescaler by | | | | | | the mask option. | | 25 | 28 | AIN4/PA0 | PA0: INOUT | 4-bit Programmable Input / Output PORTA. | | 26 | 29 | AIN5/PA1 | AIN4: INPUT<br>PA1: INOUT | Selects a function of either of 1) or 2) for PORTA by the mask option. 1) 4-bit Analog Input to A/D Converter. (AD) | | 27 | 30 | AIN6/PA2 | AIN5: INPUT<br>PA2: INOUT<br>AIN6: INPUT | 2) 4-bit Input / Output Terminals as PORTA. These 4-bit terminals direction can be changed by the | | 28 | 31 | AIN7/PA3 | PA3: INOUT<br>AIN7: INPUT | program as 4-Input or 4-Output. Use of Pull-up resistance for a terminal is in accordance with the mask option. •as Input: C-MOS Input Terminals (IOP) •as Output: Nch-FET Open-Drain Output Terminals (IO) | | 29 | 32 | PB0 | INOUT | 4-bit Programmable Input / Output PORTB. | | 30 | 33 | PB1 | INCOT | These 4-bit terminals direction can be changed by the | | 31 | 34 | PB2 | | program as 4-Input or 4-Output. | | 32 | 35 | PB3 | | Use of Pull-up resistance for a terminal is in accordance | | | | - | | with the mask option. | | | | | | •as Input : C-MOS Input Terminals (IOP) | | | | | | •as Output: Nch-FET Open-Drain Output Terminals (IO) | | 33 | 36 | V <sub>DD</sub> | _ | Power Source (2.4V to 5.5V) | | 34 | 37 | PC0 | INPUT/OUTPUT | 2-bit Input / Output PORTC. | | 35 | 38 | PC1 | | Selects a terminal circuit for each port from follows by the mask option. | | | | | | C-MOS Input Terminal with Pull-up Resistance (ICP) | | | | | | •C-MOS Input Terminal (IC) | | | | | | Nch-FET Open-Drain Output Terminal with Pull-up | | | | | | Resistance (ONP) | | | | | | Nch-FET Open-Drain Output Terminal (ON) | | 36 | 39 | PD0 | INPUT/OUTPUT | 4-bit Input / Output PORTD. | | 37 | 40 | PD1 | | Selects a terminal circuit for each port from follows by the | | 38 | 41 | PD2 | | mask option. | | 39 | 42 | PD3 | | C-MOS Input Terminal with Pull-up Resistance (ICP) C MOS Input Terminal (IC) | | | | | | C-MOS Input Terminal (IC) C MOS Output Terminal (OC) | | 40 | 1 | PE0 | INPUT/OUTPUT | O-MOS Output Terminal (OC) 4-bit Input / Output PORTE. | | 41 | 2 | PE0<br>PE1 | INFUI/OUIFUI | Selects a terminal circuit for each port from follows by the | | 42 | 3 | PE2 | | mask option. | | 43 | 4 | PE3 | | C-MOS Input Terminal with Pull-up Resistance (ICP) | | 1 | | 0 | | C-MOS Input Terminal (IC) | | | | | | C-MOS Output Terminal (OC) | Note ) INPUT/OUTPUT : Input or Output is selected by the mask option. INOUT : Input or Output is changed by the program. "IOP,IO,AD,ICP,ONP,ON,OC,ISP,IS,AD,R,F,IIP,II,SO,SCP" are symbols using on MASK OPTION GENERATOR(MOG). #### ■ INTERNAL SYSTEM DESCRIPTION The NJU3505 is a C-MOS 4-Bit Single Chip Micro Controller consisted of Original CPU Core, Selectable Input-Output(I/O) Ports(MAX. 35 lines), Program ROM(8,192 bytes), Data RAM(256 nibbles), 8-Bit A/D Converter, 8-bit Serial Interface, Dual Timer/Counter(8-bit and 12-bit), Interrupt Control Circuit and Oscillator Circuit. The CPU block in the **NJU3505** 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, Program Counter indicating 8192 addresses sequentially, and Timing generator. The NJU3505 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 operates 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 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 CARRY flag(CY) 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. New Japan Radio Co., Ltd. #### 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 4 banks, a bank consists of 32 pages, and a page consists of 64 bytes memory capacity. Therefore the NJU3505 prepares the 8192-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 13-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 b10 on the PC indicate the page in a bank, and data figures limited from b11 to b12 on PC indicates a bank in ROM. Although the ROM address can be indicated 8192 addresses continuously, the target address of JMP instruction is restricted by Paging structure in ROM. The target address of JPL or CALL instruction is restricted by Banking 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 consist of two bytes(16 bits) length including the 11 bits of PC. But JPL and CALL instructions can not branch between the banks in ROM. The memory bank register (PHY15) on the peripheral register table0 selects a bank in ROM. When the branch target address is not found in the bank, the memory bank register requires to change the bank number. #### STACK STACK consists of three types of registers which are the 8 by 13 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(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 underflowed(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 NJU3505 prepares 256 words(1024 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-reg and Y-reg. ### [ RAM ADDRESS MAP ] #### PERIPHERAL REGISTERs(PH) PERIPHERAL REGISTERs(PH) controlling I/O Ports or the ROM address are selected by the data in Y'-reg. Two Peripheral Register tables called as table0 and table1 in the NJU3505 consist of 32 registers totally. 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, it sometimes takes the incorrect data of the Output Port. ### 《Peripheral Register Table Change》 When LSB(b0) of the peripheral register table change register(PHY0) is written "0", the table0 is selected. When LSB of PHY0 is written "1", the table1 is selected. The table0 is selected on "RESET" operation. [ Reading from the Peripheral Register Table Change Register (PHY0) ] [ Writing to the Peripheral Register Table Change Register (PHY0) ] # [ PERIPHERAL REGISTER TABLEO ] | Y'-register | Register No. | Peripheral Register Name | | Write or<br>Read ※1 | Data in<br>Reset | |----------------|--------------|----------------------------------------------|---|---------------------|------------------| | 0H | PHY0 (00H) | Peripheral Register Table Change<br>Register | 1 | WR | 0 | | 1H | PHY1 (01H) | Serial Input/Output Control Register | 3 | WR | 0 %3 | | 2H | PHY2 (02H) | Serial Input/Output Shift Register | 8 | WR | 0 %3 | | 3H | PHY3 (03H) | Timer1/Prescaler Control Register | 3 | WR | 0 | | 4H | PHY4 (04H) | Initial Value Register1 / Timer Counter1 | 8 | WR | 0 | | 5 <del>1</del> | PHY5 (05H) | Timer2 Control Register | 4 | WR | 0 %6 | | 6H | PHY6 (06H) | Initial Value Register2 / Timer Counter2 | 8 | WR | 0 | | 7H | PHY7 (07H) | A/D Converter Control Register1 | 4 | WR | 0 %4 | | 8H | PHY8 (08H) | A/D Converter Output Register | 8 | R | 0 | | 9H | PHY9 (09H) | Interrupt Control Register | 4 | WR | 0 | | AH | PHY10 (0AH) | A/D Coverter Control Register2 | 1 | WR | 0 ※4 | | BH | PHY11 (0BH) | Initial Value Register2 / Timer Counter2 | 4 | WR | 0 | | CH | PHY12 (0CH) | | | | | | | PHY13 (0DH) | ROM Addressing Register L | 4 | WR | unknown | | | PHY14 (0EH) | ROM Addressing Register H | 1 | WR | unknown | | FH | PHY15 (0FH) | Memory Bank Register | 2 | WR | 0 ※2 | # [PERIPHERAL REGISTER TABLE1] | Y'-register | Register No. | Peripheral Register Name | | Write or<br>Read ※1 | Data in<br>Reset | |-------------|--------------|-------------------------------------------------|-----|---------------------|------------------| | ОН | PHY0 (00H) | Peripheral Register Table Change<br>Register | 1 | WR | 0 | | 1H | PHY17 (11H) | PORTA Output or PORTA Input | 4 | WR | 0 ※4 | | 2H | PHY18 (12H) | PORTB Output or PORTB Input | 4 | WR | 0 | | 3H | PHY19 (13H) | PORTC Output or PORTC Input | 2 | W/R | 0 | | 4H | PHY20 (14H) | PORTD Output or PORTD Input | 4 | W/R | 0 | | 5H | PHY21 (15H) | PORTE Output or PORTE Input | 4 | W/R | 0 | | 6H | PHY22 (16H) | PORTF Output or PORTF Input | 3 | W/R | 0 | | 7H | PHY23 (17H) | PORTG Output or PORTG Input | 2 | W/R | 0 | | 8H | PHY24 (18H) | PORTH Output or PORTH Input | 2/3 | W/R | 0 | | 9H | PHY25 (19H) | PORTI Input | 4 | R | <b>※4</b> | | AH | PHY26 (1AH) | PORTJ Input | 2 | R | <b>※</b> 5 | | BH | PHY27 (1BH) | PORTK Input | 2 | R | <b>※</b> 6 | | CH | PHY28 (1CH) | PORTL Output or PORTL Input | 2/1 | W/R | 0 %3 | | DH | PHY29 (1DH) | Programmable Input/Output Port Control Register | 2 | WR | 0 | | EH | PHY30 (1EH) | | | | | | FH | PHY31 (1FH) | | | | | %1 W : Write only R : Read only WR : Read and Write W / R : Fixed as Read or Write by the mask option \*2 Memory Bank Register(PHY15) selects the Bank0 in ROM when lower 2-bit of PHY15 is written "00". and selects the Bank1 when lower 2-bit of PHY15 is written "01", and selects the Bank2 when lower 2-bit of PHY15 is written "10", and selects the Bank3 when lower 2-bit of PHY15 is written "11". The Bank0 is selected on "RESET" operation. ### [ Reading from the Memory Bank Register (PHY15) ] 01:bank1 10:bank2 11:bank3 # [ Writing to Memory Bank Register (PHY15) ] / 00:bank0 01:bank1 10:bank2 11:bank3 Bank0 Address: 0000H to 07FFH. Note) > Bank1 Address: 0800H to 0FFFH Bank2 Address: 1000H to 17FFH Bank3 Address: 1800H to 1FFFH ## **%3** Wiring of terminals The mask option selects a terminal type from SDO/PL0, SDI(O)/PL1 or SCK/CKOUT as shown in right. # **¾4** Wiring of terminals The mask option selects a terminal type from AINO/PIO, AIN1/PI1, AIN2/PI2, AIN3/PI3, AIN4/PA0, AIN5/PA1, AIN6/PA2, AIN7/PA3 as shown in right. AINO/PIO AIN1/PI1 AIN2/PI2 AIN3/PI3 AIN4/PA0 AIN5/PA1AIN6/PA2AIN7/PA3 ## **%5** Wiring of terminals The mask option selects a terminal type from VREF/PJ0, or ADCK/PJ1 as shown in right. ### **%6** Wiring of terminals The mask option selects a terminal type from EXTI/PK0, or CNTI/PK1 as shown in right. ## ● ROM ADDRESSING REGISTER(PHY13, PHY14) ROM ADDRESSING REGISTER (PHY13. PHY14) indicates the address of ROM with Accumulator and X'-reg for the data transference operation (TRM) from ROM to RAM. The PHY13 and PHY14 condition are unknown on "RESET" operation. The lower a bit(b0) in PHY14 is used as the ROM ADDRESSING and higher 3 bits(b1,b2,b3) are not used, ## [ ROM ADDRESSING ] | | no used | | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 | |----|---------|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----| | b3 | b2 | b1 | b0 | b3 | b2 | b1 | b0 | b3 | b2 | b1 | b0 | b3 | b2 | b1 | b0 | | | PH) | /14 | | | PHY | ′13 | | | Х | 1 | | | AC | ) | | #### **■ INPUT OUTPUT PORT** The **NJU3505** prepares 21 Input-Output lines and 14 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 FUNCTION TABLE ] | | FUNCTION | NOUTOUT | |----------------|-------------------------------------|-----------------------------------------------------| | PORT NAME | FUNCTION | INPUT/OUTPUT | | PORTA | Input / Output port or AIN4 to AIN7 | Programmable Input / Output PORT(4-bit). | | PORTB | Input / Output port | Programmable Input / Output PORT(4-bit). | | PORTC to PORTH | Input / Output port | Input / Output selectable ports by the mask option. | | PORTI | Input port or AIN0 to AIN3 | Input | | PORTJ(PJ0) | Input port or VREF | Input | | PORTJ(PJ1) | Input port or ADCK | Input | | PORTK(PK0) | Input port or EXTI | Input | | PORTK(PK1) | Input port or CNTI | Input | | PORTL(PL0) | Output Port or SDO | output | | PORTL(PL1) | Input / Output port or SDI(O) | Input / Output selectable ports by the mask option. | Note1) PORTG is not prepared on the NJU3505L(SDIP package). Note2) Pull-up resistance is selected by the mask option.(refer ■INPUT OUTPUT TERMINAL TYPE) # (1) INPUT OUTPUT PORT ### ● PORTA(PA0 to PA3) PORTA is a 4-bit programmable input-output PORT. It operates also as the multiplexed 4-channel analog signal input terminals (AIN4 to AIN7) to the internal A/D converter by the mask option. It is set as the output when LSB of the programmable input/output control register (PHY29) is set to "1", and is set as the input when LSB of PHY29 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 PORTA (PHY17). PHY17 as the output register should be written the output data before the PORTA is set as the output by PHY29, because the conditions of the output terminals are unknown while the output data is not written in PHY17. When this PORT is set as the input, the 4-bit external signals are gotten directly through the input terminals by reading data from PHY17. PHY17 can be written or read independent of the state of PHY29 as the input or output. PORTA is set as the input in accordance with the state of PHY29 set to "0" on the "RESET" operation. Though the output circuit is Nch open drain type, the C-MOS input buffer is connected to the same terminal. Therefore, the operating current of the chip by the short circuit current when the middle level voltage between V<sub>DD</sub> and V<sub>SS</sub> is input to this terminal. ## [ READING PORTA INPUT DATA (PHY17) ] ### [ WRITING PORTA OUTPUT DATA (PHY17) ] #### PORTB(PB0 to PB3) PORTB is a 4-bit programmable input-output PORT. It is set as the output when the second bit (b1) of the programmable input/output control register (PHY29) is set to "1", and is set as the input when "b1" of PHY29 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 (PHY18). PHY18 as the output register should be written the output data before the PORTB is set as the output by PHY29, because the conditions of the output terminals are unknown while the output data is not written in PHY18. When this PORT is set as the input, the 4-bit external signals are gotten directly through the input terminals by reading data from PHY18. PHY18 can be written or read independent of the state of PHY29 as the input or output. PORTB is set as the input in accordance with the state of PHY29 set to "0" on the "RESET" operation. ### [ WRITING PORTB OUTPUT DATA (PHY18) ] #### ●PORTC(PC0, PC1) PORTC 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 PORTC register(PHY19). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY19. ## [ READING PORTC INPUT DATA (PHY19) ] #### [ WRITING PORTC OUTPUT DATA (PHY19) ] #### ● PORTD(PD0 to PD3) PORTD 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 PORTD register (PHY20). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY20. #### [ READING PORTD INPUT DATA (PHY20) ] # [ WRITING PORTD OUTPUT DATA (PHY20) ] #### ● PORTE(PE0 to PE3) PORTE 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 PORTE register (PHY21). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY21. # [ READING PORTE INPUT DATA (PHY21) ] ### [ WRITING PORTE OUTPUT DATA (PHY21) ] #### ● PORTF(PF0 to PF2) PORTF is a 3-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 PORTF register (PHY22). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY22. ## [ READING PORTF INPUT DATA (PHY22) ] # [ WRITING PORTF OUTPUT DATA (PHY22) ] #### ●PORTG(PG0, PG1) PORTG is a 2-bit input-output PORT. The input or 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 PORTG register (PHY23). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY23. ## [ READING PORTG INPUT DATA (PHY23) ] ### [ WRITING PORTG OUTPUT DATA (PHY23) ] Note) PORTG is not prepared on the NJU3505L(SDIP package). #### ●PORTH(PH0, PH1) PORTH 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 PORTH register (PHY24). When the port is set as the input, the external signal is gotten directly through the input terminal by reading data from PHY24. When this PORTH is set as the input, these two ports perform the extra functions as follows: #### a. PH0 TERMINAL PH0 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 PH0 terminal in mode of "STANDBY", the "STANDBY" mode is released and the CPU starts the execution again from the suspended address of the program. (refer STANDBY FUNCTION) #### b. PH1 TERMINAL PH1 terminal performs the extra function as the edge detector terminal. When the PH1 terminal detects the edge of the signal from the external circuit, the third bit(b2) condition of PHY24 is set to "1". The "b2" of PHY24 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 PHY24. The polarity as low to high or high to low of the input signal edge can be selected by the mask option. ## [ READING PORTH INPUT DATA (PHY24) ] #### [ WRITING PORTH OUTPUT DATA (PHY24) ] #### ● PORTI(PI0 to PI3) PORTI is a 4-bit input PORT. It operates also as the multiplexed 4-channel analog signal input terminals (AIN0 to AIN3) to the internal A/D converter by the mask option. When the PORTI is set as the input PORT, the four external signals are gotten directly though the input terminals by reading data from PHY25. # [ READING PORTI INPUT DATA (PHY25) ] New Japan Radio Co., Ltd. #### ●PORTJ(PJ0, PJ1) PORTJ is a 2-bit input PORT. It operates also as V<sub>REF</sub> and ADCK terminals of the internal A/D converter by the mask option. When the PORTJ is set as the input PORT, the two external signals are gotten directly through the input terminals by reading data from PHY26. #### [ READING PORTJ INPUT DATA (PHY26) ] ### ●PORTK(PK0, PK1) PORTK is a 2-bit input PORT. It operates also as EXTI input terminal for the external interrupt input and CNTI terminal for the event counter external clock input by the mask option. When the PORTK is set as the input PORT, the two external signals are gotten directly from the input terminals by reading data from PHY27. ### [ READING PORTK INPUT DATA (PHY27) ] #### ●PORTL(PL0, PL1) PORTL 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 PORTL is selected as the input-output PORT, PL0 is fixed as the output and PL1 can be selected as the input or the output by the mask option. When the PORTL is selected as the output, the two signals are output through the output terminals to the external circuit by writing data to the PORTL register(PHY28). When PL1 is selected as the input, the external signal is gotten directly through the input terminal by reading data from PHY28. #### [ READING PORTL INPUT DATA (PHY28) ] When PLO is output, its output condition can be monitored. # [ WRITING PORTL OUTPUT DATA (PHY28) ] ### ● PROGRAMMABLE INPUT/OUTPUT PORT CONTROL REGISTER(PHY29) Programmable Input / Output Port Control Register(PHY29) is a peripheral register to set the programmable input/output PORTs(PORTA and PORTB) as either the input or the output. All bits in PORTA are set as the output when LSB(b0) of PHY29 is set to "1". All bits in PORTA are set as the input when "b0" of PHY29 is set to "0". All bits in PORTB are set as the output when b1 of PHY29 is set to "1". All bits in PORTB are set as the input when "b1" of PHY29 is set to "0". PORTA and PORTB are set as the input in accordance with the state of PHY29 which is set to "0" on the "RESET" operation. [ READING Programmable Input / Output Port Control Register(PHY29) ] [ WRITING Programmable Input / Output Port Control Register(PHY29) ] ## (2) PROGRAMMABLE INPUT/OUTPUT PORT OPERATION a. The output operation example PB0 and PB1 of PORTB output "H", and PB2 and PB3 of PORTB output "L". | | : | | | |------|---------|----------------------------------------------|---------------------| | SRPC | | | | | LDI | Y,0 | Peripheral table is | | | LDI | A,%0001 | set as the table1 | | | TAP | | ; ) ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' | | | LDI | Y,2 | ;PHY18 is pointed | | | LDI | A,%0011 | ;"0011" is stored into Accumulator | | | TAP | | ;Data in Accumulator is transmitted to PHY18 | | | | | ; (PORTB output register) | | | LDI | Y,13 | ;PHY29 is pointed | ) PORTB is | | LDI | A,%0001 | ;"0001" is stored into Accumulator | set as the output | | TAP | | ;Data in Accumulator is transmitted to PHY29 | ) cor as the output | # b. The input operation example Accumulator gets the input data from PORTB. | | : | | | |------------|---------|------------------------------------------------|------------------------------------------| | SRPC | | | | | LDI | Y,0 | Peripheral table is | | | LDI<br>TAP | A,%0001 | Peripheral table is set as the table1 | en e | | LDI | Y,13 | ;PHY29 is pointed | PORTB is | | LDI | A,%0000 | ;"0000" is stored into Accumulator | set as the input | | TAP | | ;Data in Accumulator is transferred to PHY29 | ) soc as the input | | LÐI | Y,2 | ;PHY18 is pointed | | | TPA | | ;The input data from PHY18 is transferred to A | ccumulator | | | • | | | 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, F, G, H, I, J, K, and L can select a terminal type from the follows by the mask option which is the same mask of the program coding into ROM and the others. But PORTI, J, and K select only the input terminal type. PL0 of PORTL select only the output terminal type. | | | INPUT OUTPUT TER | MINAL TYPES | | |------------------------------------|-------------------------------------------------------------------|------------------|-----------------|----------------------------------------------------------------------------------------------------| | | Types | With Pull-up | Without Pull-up | Terminals | | AINAL | C-MOS | Type ICP | Type IC —— —— | PC0, PC1,<br>PD0~PD3,<br>PE0~PE3,<br>AIN0/PI0~<br>AIN3/PI3,<br>SDI(O)/PL1 | | INPUT TERMINAL | SCHMITT<br>TRIGGER | Type ISP | Type IS | PF0~PF2,<br>PG0, PG1,<br>PH0, PH1,<br>V <sub>REF</sub> /PJ0,<br>ADCK/PJ1,<br>EXTI/PK0,<br>CNTI/PK1 | | TERMINAL | C-MOS | | Type OC | PD0~PD3,<br>PE0~PE3,<br>PF0~PF2,<br>PG0, PG1,<br>PH0, PH1,<br>SDO/PL0,<br>SDI(O)/PL1 | | OUTPUT TE | N-channel<br>(Nch)<br>OPEN<br>DRAIN | Type ONP | Type ON | PC0, PC1 | | PROGRAMMABLE INPUT OUTPUT TERMINAL | C-MOS<br>INPUT<br>/<br>N-channel<br>(Nch)<br>OPEN DRAIN<br>OUTPUT | Type IOP | Type IO | AIN4/PA0~<br>AIN7/PA3,<br>PB0~PB3 | #### TIMER The NJU3505 prepares a couple of Programmable Timer / Counter(Timer1, Timer2) consisted of the 8-bit and 12-bit binary counter. [Structure of Timer / Counter] Timer1 counts only the internal clock and Timer2 counts either of the internal clock or the external clock in accordance with the condition of bit2(b2) of the Timer2 Control Register(PHY5). The initial value of the counter can be set the optional value by the program which instructs to write the data(a value of the time-interval or the event-count) into the Initial Value Register(Timer1 or Timer2 is set the each value independently). In enabling the timer1 interrupt, when the Timer1 counter counts from "FF" to "00" (overflow), the timer1 interrupt request occurs and the internal interrupt process starts the own operation. In enabling the timer2 interrupt, when the Timer2 counter counts from "FFF" to "000" (overflow), the timer2 interrupt request occurs and the internal interrupt process starts the own operation. In the repeat mode of the Timer operation, when the counter overflows, the initial value is loaded into the counter automatically and the counter 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 counter 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 the Timer1 or Timer2 Control Register must be set to "1". The latest initial value is set into the counter and the counter starts the count. In enabling the interrupt operation, when the counter overflows, the Timer / Counter overflow flag is set to "1" and the internal interrupt process starts to the own operation. In disabling the timer interrupt, the Timer / Counter overflow flag is not set. The Timer / Counter 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 When the bit2(b2) of the Timer1 / Prescaler Control Register is set to "1", the prescaler generating the internal count clock is stopped the operation. As the result, Timer / Counter stops the count operation. In the external clock operation of Timer2, the external clock must be input to CNTI terminal. The 24 Timer2 Control Register selects either the internal clock operation or the external clock operation. [ 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") <sup>\*</sup> The difference between Timer1 and Timer2 counters is bit-number of counter. Timer1 is 8bits. Timer2 is 12bits. ●Timer1 / Prescaler Control Register { PHY3 ; (Y'=3, Peripheral register table 0) } [ Writing to the Timer1 / 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 pointed. LDI A,%0000;"0000"(BIN) is stored to accumulator TAP ;Data is transferred from accumulator to PHY3 LDI A,%0001;"0001"(BIN) is stored to accumulator 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, CKOUT terminal and A/D converter controller, 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 the Timer1 / Prescaler Control Register ] EX.) An example of the overflow in the single mode and the internal clock operation.(The data of the Timer1 / Prescaler Control Register is "0001"(BIN).) SRPC ; LDI Y,3 ;PHY3(Timer1/Prescaler Control Register) is pointed. TPA ;"0001"(BIN) of PHY3 is transferred to accumulator. Timer2 Control Register { PHY5 ; (Y'=5, Peripheral register table 0) } [ Writing to the Timer2 Control Register ] EX.) An example of the start procedure for the repeat mode, the external clock operation and releasing the count clock mask. ``` SRPC LDI Y,5 ;PHY5(Timer2 Control Register) is pointed. LDI A,%1110;"1110"(BIN) is stored to accumulator TAP ;Data is transferred from accumulator TAP ;Data is transferred from accumulator TAP ;Data is transferred from accumulator to PHY5 The count is started. ``` Remarks) In the Timer2 operation, when the count clock mask bit(b3) of the Timer2 Control Register is set to "0", the Timer2 is stopped to count and it holds the latest data of the 8-bit counter2. When the b3 is set to "0", the Timer2 starts to count from the hold data of the 8-bit counter2. [ Reading from the Timer2 Control Register ] EX.)An example of the Timer2 starting information as the Single mode, the internal clock operation and the released clock mask. (The data of Timer2 Control Register is "1001"(BIN).) SRPC ; LDI Y,5 ;PHY5(Timer2 Control Register) is pointed TPA ;Data is transferred "1001"(BIN) of PHY5 to accumulator Initial Value Register1 / Timer Counter1 Initial Value Register1 / Timer Counter1 { PHY4; (Y'=4, Peripheral register table 0) } The Initial Value Register1 consisted of a 8-bit register sets the initial value to the counter, or gets the counted value from the counter. #### [ Writing to the Initial Value Register1 ] When a data in RAM or Accumulator is transferred to the Initial Value Register1, the data is loaded into the higher 4-bit(b7 - b4) or lower(b3 - b0) of the Initial Value Register1 in accordance with the condition of LSB of Y-register. #### [ Reading from the Timer Counter1 ] When a current data in the Timer Counter1 is transferred into RAM or Accumulator, the data is gotten from higher 4-bit(b7 - b4) or lower(b3 - b0) of the Timer Counter1 or Timer Counter2 in accordance with the condition of LSB of Y-register. ### [ Reading data from 8-bit Timer Counter1 to RAM ] Though the data of the Timer and Counter 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 Timer Counter1 to RAM ] There are some other cases to read the incorrect data from the 8-bit counter during the count operation depending on the relation with the external clock speed and the system execution speed. Initial Value Register2 / Timer Counter2 Initial Value Register2 / Timer Counter2 {PHY6, PHY11; (Y'=6, Y'=11 Peripheral register table 0)} The Initial Value Register2 consisted of a 12-bit register sets the initial value to the counter, or gets the counted value from the counter. #### [ Writing to the Initial Value Register2 ] When a data in RAM or Accumulator is transferred to the Initial Value Register2, the data is loaded into the middle 4-bit(b7 - b4) or lower4-bit(b3 - b0) is accordance with the condition of LSB of Y-register. But the higher 4-bit(b11 - b8) can load the data without any conditions. ### [ Reading from the Timer Counter 2 ] When a current data in the Timer Counter2 is transferred into RAM or Accumulator, the data is gotten from the middle 4-bit(b7 - b4) or lower 4-bit(b3 - b0) of the Timer Counter2 in accordance with the condition of LSB of Y-register. But the higher 4-bit(b11 - b8) can output the data without any conditions. # [ Reading data from 12-bit Timer Counter2 to RAM ] Though the data of the Timer and Counter 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 12-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 "110h" when the lower 4-bit data is gotten, it is "10Fh" when the higher 4-bit data is gotten. Therefore the final data becomes to be "11Fh". [ An example of data reading from 12-bit Timer Counter2 to RAM ] There are some other cases to read the incorrect data from the 12-bit counter during the count operation depending on the relation with the external clock speed and the system execution speed. #### SERIAL INPUT OUTPUT SERIAL INPUT OUTPUT consists of the sift registers to convert from 8-bit parallel data to serial data, the 3-bit 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 terminal. #### <<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) terminals. #### [ The 3-wire transmission timing chart (MSB first) ] ## <<The 2-wire method>> 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. 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 the NJU3505 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_{\rm 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 - Remarks 1) When the bit2(b2) of Timer1 / 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. - Remarks 2) 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. | SRPC | • | •<br>• | | |------|---------|--------------------------------------------------|-----------------| | LDI | Y,1 | ;PHY1(Serial Input / Output control register) is | | | LDI | A,%0010 | ;"0010"(BIN) is stored to accumulator | External clock, | | TAP | | ;Data is transferred from accumulator to PHY1, | Input mode | | LDI | A,%0011 | ;"0011"(BIN) is stored to accumulator | Transmission | | TAP | | ;Data is transferred from accumulator to PHY1, | Starts. | Remarks 3) 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 ] Remarks 4) 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 | :<br>unt proces | ·• | | |--------------|-----------------------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SINT | ORG<br>SRPC | \$40 | ;Interrupt vector address of FULL or EMPTY | | Olivi . | LDI<br>TPA | Y,1 | ;The Serial Input / Output control register is set | | : | TBA<br>JMP<br>JMP | 0<br>SIO_OK<br>SINT_E | The end flag of transmission is tested | | ,<br>SIO_OK | LDI<br>RRPC | Y,2 | ;The Serial Input / Output shift register is set | | • | LDI | X,SIO_DAT.X | ;RAM to store the serial input data is pointed<br>;RAM address, X=0 | | | LDI<br>TPMICY | Y,SIO_DAT.Y | ;RAM address, Y=0<br>;The serial input data is transferred to RAM(lower | | | TPMICY | | ; 4-bit) and Y-register is incremented<br>;The serial input data is transferred to RAM(higher<br>; 4-bit) and Y-register is incremented | | j | | | | | SINT_E | RETI | | ; End of the interrupt process | | ;<br>; Seria | | outting process | ; End of the interrupt process | | ; - | al data inp | outting process | ; End of the interrupt process ; The peripheral register table is set | | ;<br>; Seria | al data inp<br>SRPC<br>LDI<br>CLA | - • | | | ;<br>; Seria | al data inp<br>SRPC<br>LDI<br>CLA<br>TAP<br>LDI<br>LDI<br>TAP<br>LDI | Y,0<br>Y,1 | ; ;The peripheral register table is set ; ;The Serial Input / Output control register is set ;The internal clock operation is set and the SDI(O) | | ;<br>; Seria | al data inp<br>SRPC<br>LDI<br>CLA<br>TAP<br>LDI<br>LDI | Y,0<br>Y,1<br>A,%0000 | ;The peripheral register table is set ;The Serial Input / Output control register is set ;The internal clock operation is set and the SDI(O) ; terminal is set as the input | | ;<br>; Seria | al data ing<br>SRPC<br>LDI<br>CLA<br>TAP<br>LDI<br>LDI<br>TAP<br>LDI<br>TAP | Y,0<br>Y,1<br>A,%0000 | ;The peripheral register table is set ;The Serial Input / Output control register is set ;The internal clock operation is set and the SDI(O) ; terminal is set as the input | 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. | . Into- | : | | | |---------------------|----------------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ; Intern | | | Unterment vector address of CULL or CMDTV | | SINT | ORG<br>SRPC | \$40 | ;Interrupt vector address of FULL or EMPTY<br>; | | • | LDI<br>TPA | Y,1 | ;The Serial Input / Output control register is set | | | TBA<br>JMP<br>JMP | 0<br>SIO_OK<br>SINT_E | The end flag of transmission is tested | | ;<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 | | ; Serial<br>SIO_OUT | data trans | smitting process | | | _ | LDI<br>CLA<br>TAP | Y,0 | The peripheral register table is set | | • | LDI | Y,2 | ;The Serial Input / Output shift register is set | | | RRPC<br>LDI<br>LDI<br>TMPICY | X,SIO_DAT.X<br>Y,SIO_DAT.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)<br>; and Y-register is incremented | | | TMPICY | • | ;The data in RAM is transferred to the Serial Input / ; Output shift register(higher 4-bit) ; & Increments Y | | , | SRPC<br>LDI<br>LDI | Y,1<br>A,%1000 | ; ;The Serial Input / Output control register is set ;The internal clock operation and the transmission ; mode are set | | : | TAP<br>LDI<br>TAP | A,%1001 | ;<br>;The serial data transmitting operation is started<br>; | | • | : | | | | SIO_DAT<br>SIO_FLG | WSEG<br>DS<br>DS | 2 | ;The RAM area<br>;The area to store the serial output data<br>;The end flag of transmission | | | | | | #### **■ INTERRUPT** The NJU3505 prepares four 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, the third is (3)Internal interrupt-2, and the fourth is (4)Internal interrupt-3 as shown in bellow. When the interrupt request flag is set by the own factor, the interrupt enabled by the interrupt control register (PHY9) stores the data of Program Counter, Accumulator, X-reg, X'-reg, Y'-reg, PPC, 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 FOUR INTERRUPTS ] | Order | Interrupt | • | Vector Address(H:HEX) | |-------|----------------------|----------------------------------|-----------------------| | (1) | External interrupt-1 | | 10H | | (2) | Internal interrupt-1 | Timer/Counter-1 Overflow | 20H | | (3) | Internal interrupt-2 | Timer/Counter-2 Overflow | 30H | | (4) | Internal interrupt-3 | Serial shift register Full/Empty | 40H | The External interrupt-1 enabled by PHY9 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 re-set 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 PHY9 is started the interrupt process when the internal interrupt request flag is set. The Timer1 and the Timer2 interrupt request flags are independent of the overflow flag, and they are 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 PHY9. And the flag is reset by the "RETI" instruction or the RESET signal from the external circuit. #### ●INTERRUPT CONTROL REGISTER { PHY9 : (Y'=9) } [ Writing to the Interrupt Control Register ] #### [Reading from the Interrupt Control Register] #### [ Enabled all factors (b0 to b3 of PHY9 were set to "1") ] [ From the all factors disabled to the enabled (b0 to b3 of PHY9 are changed from "0" to "1") ] [ From the all factors enabled to the disabled (b0 to b3 of PHY9 are changed from "1" to "0") ] 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. #### ■ A/D CONVERTER The A/D converter operates with the following specification. ·A/D Conversion : Successive Approximation method •Minimum conversion Time : 40 $\mu$ sec (VDD=5V, VREF=5V, fADCK=225kHz) ·Resolution : 8 bit (256 step) ·Absolute Accuracy :±2 LSB (VDD=5V, VREF=5V) Reference Voltage : 2.4V~AVDD Analog Input Voltage : AVss~VREF ·Channel : Multiplexed 8-channel Input The A/D converter block diagram and the timing chart are shown in bellow. The lower 2 bits of the A/D converter control register(PHY7) or the lower 1 bit of the A/D control converter (PHY10) are the switches to select an analog input channel from four multiplexed inputs(AIN0 – AIN7). The analog input signal to the analog input port selected by the A/D converter control register is converted to the digital data, and then the digital data is stored into the A/D converter output register(PHY8). The A/D control clock can selected either the external clock or the internal by the mask option. In the external clock operation, the input clock from the "ADCK" terminal operates as the A/D control clock. In the internal clock operation, the clock divided in the internal Prescaler operates as the A/D control clock. The frequency of the clock from the internal Prescaler can be selected by the mask option from follows which are dividing numbers based on the inverse of one instruction execution time(1/fosc X 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 #### [ A/D CONVERTER BLOCK DIAGRAM ] Remarks) The A/D control clock can be selected either the external clock from the ADCK terminal or the internal clock from the Prescaler by the mask option. The Prescaler supplies clocks to Timer/Counter, Serial Input Output, and A/D converter. The maximum frequency of the A/D control clock is 225KHz in the both of the internal and the external clock operation. #### [ A/D CONVERTER OPERATION TIMING CHART ] #### ● A/D CONTROL REGISTER { PHY7; (Y'=7), PHY10; (Y'=10) } [ Writing to the A/D Control Register { PHY7; (Y'=7), PHY10; (Y'=10) } ] EX.) An example of A/D converter start procedure for selecting AIN1 as the input and releasing the A/D hold mode. | | • | | | |------|---------|------------------------------------------|------------------------------------------| | SRPC | | | | | LDI | Y,10 | ; PHY10(A/D control register) is pointed | <b>)</b> | | LDI | A,%0000 | ; "0000"(BIN) is stored to AC | 7 11 N 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | TAP | | ;Data transferred from AC to PHY10 | AIN1 as the input, | | LDI | Y,7 | ;PHY7(A/D control register) is pointed | Releasing Hold mode | | LDI | A,%0001 | ;"0001"(BIN) is stored to AC | | | TAP | | ;Data transferred from AC to PHY7 | | | LDI | A,%1001 | ;"1001"(BIN) is stored to AC | Start of conversion | | TAP | • | ;Data transferred from AC to PHY7 | | | | | | | Remarks) In the external clock operation, the external clock must be input to the ADCK terminal before the start of A/D conversion. ### [Reading from the A/D Control Register] ### ● A/D OUTPUT REGISTER { PHY8; (Y'=8) } The 8-bit data converted by the A/D converter can be transferred to RAM or Accumulator. Either the higher 4-bit data or the lower is gotten in accordance with the condition of LSB of Y-register. ### [Reading from the A/D Output Register] ### [Analog input voltage vs Output digital data] An example of A/D conversion operation) AlN2 terminal is selected and the result of the A/D conversion is transferred to RAM. | | : | | | | |--------------|------------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | ADC_EXE | SRPC<br>LDI<br>CLA<br>TAP | Y,0 | ;<br>;Peripheral register table 0<br>; | | | ; | LDI<br>LDI<br>TAP<br>LDI<br>LDI<br>TAP<br>LDI<br>TAP | Y,10<br>A,%0000<br>Y,7<br>A,%0010<br>A,%1010 | ;A/D control register<br>;AIN2 as the input<br>;<br>;<br>;Start of A/D conversion<br>; & AIN2 terminal | | | ;<br>LP_ADC | TPA<br>TBA<br>JMP<br>JMP | 3<br>ADC_END<br>LP_ADC | End of conversion? | | | ;<br>ADC_END | LDI | Y,8 | ;A/D conversion register | | | <b>;</b> | RRPC<br>LDI<br>LDI<br>TPMICY<br>TPMICY | X,ADC_DAT.X<br>Y,ADC_DAT.Y | ;RAM to store the result of A/D conversio<br>;RAM address X=0<br>;RAM address Y=0<br>;The A/D converted data to RAM<br>; lower 4-bit at YLSB=0<br>;The A/D converted data to RAM<br>; higher 4-bit at YLSB=1 | n | | ADC_DAT | WSEG<br>DS | 2 | ;RAM area<br>;Are for the result of A/D conversion | | #### **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 circuit, 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 re-start operation that when the re-start signal is input to PH0 terminal, the operation starts from the kept Program Counter location which is the program address after the final operation. In case of the re-start signal operation, if the rising signal, low to high, is input to PH0 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 NJU3505 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 re-start signal is input to PH0 terminal to release the STANDBY mode, PORTH must be selected as the input by the mask option. #### [STANDBY MODE TIMING CHART] #### **■ CLOCK GENERATION** The system clock is generated in the internal oscillator circuit with the external crystal or ceramic resonator, or the resistor connected to OSC1 and OSC2 terminals. Furthermore, the NJU3505 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. 2 CR oscillation ### [ OSCILLATOR APPLICATION EXAMPLES ] 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 bellow. 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 is RESET terminal protector. It is required depending on the condition of an application. #### ■ PRESCALER The NJU3505 prepares a built-in Prescaler consisted of 12-bit binary counter which counts the machine cycle period clock(1/fosc x 6) from 2 to 4096 times. The Prescaler can supply the clock to Timer1 and 2, Serial Input Output, A/D converter, 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 Timer1/Prescaler control register(PHY3) is set to "1", the Prescaler operation is stopped, but the output clock is also stopped to Timer1 and 2, Serial Input Output, A/D converter 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 fosc = 4MHz (Φ=4MHz/6) | Prescaler | Di | vic | tei | ٠. | | | C | ut | put 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) | | | | (14-200 | |--------------------------|-------------------|---------------|---------| | PARAMETER | ARAMETER SYMBOL R | | UNIT | | Supply Voltage | <b>V</b> DD | -0.3~+7.0 | V | | Input Voltage | Vin | -0.3~Vpp+0.3 | V | | Output Voltage | Vоит | -0.3~Vpp+0.3 | V | | Analog Supply Voltage | AVDD | -0.3~Vpp+0.3 | V | | Analog Reference Voltage | VREF | -0.3~AVpp+0.3 | V | | Analog Input Voitage | AIN0~AIN7 | -0.3~AVpp+0.3 | V | | Operating Temperature | Topr | -20~+75 | °C | | Storage Temperature | Tstg | -55~+125 | °C | 49 ### **■ ELECTRICAL CHARACTERISTICS** DC CHARACTERISTICS 1-1 $(V_{DD}=3.6\sim5.5V, V_{SS}=0V, Ta=-20\sim75^{\circ}C)$ | | LING FICS | | V <sub>DD</sub> -3.0 | | | _ | | |----------------|------------------|----------------------------------------------------|----------------------|-----|------------------------------------------|----------|------| | PARAMETER | SYMBOL | | MIN | TYP | MAX | UNIT | NOTE | | Supply Voltage | V <sub>DD</sub> | V <sub>DD</sub> | 3.6 | | 5.5 | ٧ | • | | Supply Current | I <sub>DD1</sub> | V <sub>DD</sub> | | 0.8 | 1.2 | mA | *3 | | | | V <sub>DD</sub> =5V,fosc=2MHz | | | | | | | | | X'tal Oscillation In Reset | <u> </u> | | | | | | | I <sub>DD2</sub> | V <sub>DD</sub> | | 0.8 | 1.2 | mA | *3 | | | | V <sub>DD</sub> =5V,fosc <b>=2MHz</b> | | | | | | | | | Ceramic Oscillation In Reset | | | | | | | | I <sub>DD3</sub> | $V_{DD}$ | | 1.1 | 1.6 | mA | *3 | | | | V <sub>DD</sub> =5V,fosc=2MHz | | | | | | | | | CR Oscillation In Reset | | | | | | | | I <sub>DD4</sub> | $V_{DD}$ | | 2.6 | 4.0 | mA | *3 | | , | | V <sub>DD</sub> =5V,fosc=4MHz | | | 1 | | | | | | Operating (Except ADC) | | | | | | | | DD5 | V <sub>DD</sub> | | | 4.0 | μΑ | *3 | | | | V <sub>DD</sub> =5V,STANDBY Mode | | | | | | | | I <sub>ADD</sub> | $AV_{DD}$ | | 3.0 | 5.0 | mA | *3 | | | : | AV <sub>DD</sub> =V <sub>DD</sub> =5V, ADCK=225kHz | | | | | | | High-Level | V <sub>IH1</sub> | AIN4/PA0~AIN7/PA3, | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | <b>V</b> | *1 | | Input Voltage | | PB0~PB3, PC0, PC1, | | | | | | | | | PD0~PD3, PE0~PE3, | | | | | | | | | AIN0/PI0~AIN3/PI3, | | | | | | | | - 17 | SDI(O)/PL1 | 0.01/ | | | | | | | V <sub>IH2</sub> | PF0~PF2,<br>PG0, PG1, PH0, PH1, | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | *1 | | | | VREF/PJO. ADCK/PJ1. | | | | | | | • | | EXTI/PK0, CNTI/PK1, | | | | | | | | | RESET | | | | | | | | V <sub>IH3</sub> | OSC1 | V <sub>DD</sub> -1.0 | | V <sub>DD</sub> | V | | | Low-Level | V <sub>IL1</sub> | AIN4/PA0~AIN7/PA3, | 0 | | 0.3V <sub>DD</sub> | V | *1 | | Input Voltage | * IL1 | PB0~PB3, PC0, PC1, | | | J. J | * | • | | 1 | | PD0~PD3, PE0~PE3, | | | | | | | | | AIN0/PI0~AIN3/PI3, | • | | | | • | | | | SDI(O)/PL1 | | • | | | | | | V <sub>iL2</sub> | PF0~PF2, | 0 | | 0.2V <sub>DD</sub> | V | *1 | | | | PG0, PG1, PH0, PH1, | | | | | | | | | VREF/PJ0, ADCK/PJ1, | | | | | | | | | EXTI/PK0, CNTI/PK1, | | | | | | | | | RESET | | | | | | | | V <sub>IL3</sub> | OSC1 | 0 | | 1.0 | V | | <sup>\*1</sup> Input/output port is set as an Input terminal. <sup>\*2</sup> Input/output port is set as an Output terminal. <sup>\*3</sup> Excludes the current drawn though internal pull-up resistors. # ■ ELECTRICAL CHARACTERISTICS DC CHARACTERISTICS 1-2 $(V_{DD}=3.6\sim5.5V, V_{SS}=0V, Ta=-20\sim75^{\circ}C)$ | DC CHARACTE | KIS HUS | , | <sub>0</sub> =3.6~5. | 5V, V | <sub>SS</sub> =UV, I | a= -20 | ~ (50) | |-------------------|------------------|----------------------------------------------------|----------------------|-------|----------------------|----------|--------| | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNIT | NOTE | | High-Level | l <sub>iH1</sub> | V <sub>DD</sub> =5.5V,V <sub>IN</sub> =5.5V | | | 10 | μА | *1 | | Input Current | | AIN4/PA0~AIN7/PA3, | ļ. | | | · | | | | | PB0~PB3, | | | | | | | | • | PC0,PC1, PD0~PD3, | | | | | | | · | • | PE0~PE3, PF0~PF2, | | | | | | | | | PG0,PG1, PH0,PH1, | | | | | | | | | AINO/PIO~AIN3/PI3, | ļ . | | | | | | | | VREF/PJ0, ADCK/PJ1, | | | | | | | | | EXTI/PK0, CNTI/PK1, | | | | | | | : | | SDI(O)/PL1, SCK/CKOUT, | | | | | | | Low-Level | ÎIL1 | V <sub>DD</sub> =5.5V,V <sub>IN</sub> =0V | | | -10 | μА | *1 | | Input Current | | Without Pull-up Resistance | | | | ~ | · | | | | AIN4/PA0~AIN7/PA3, PB0~P | | | | | | | | | B3,PC0, PC1, PD0~PD3, | | | | · . | | | | · | PE0~PE3, PF0~PF2, | | | | | | | | | PG0,PG1, PH0,PH1, | | | | | | | | | AIN0/PI0~AIN3/PI3, | | | | | | | | | VREF/PJ0, ADCK/PJ1, | | | | | · | | | | EXTI/PK0, CNTI/PK1, | | | | | | | | | SDI(O)/PL1,SCK/CKUT, | | i . | | | | | | | RESET | | | | | | | · | I <sub>IL2</sub> | V <sub>DD</sub> =5.5V,V <sub>IN</sub> =0V | | | -100 | μΑ | *1 | | | | With Pull-up Resistance | · . | | | ] | | | | | AIN4/PA0~AIN7/PA3, | ŀ | | | | | | | | PB0~PB3, PC0, PC1, | | | | · | | | | | PD0~PD3, PE0~PE3, | | | | | | | | | PF0~PF2,PG0,PG1,PH0,PH1, | | | 1000 | | | | | | AINO/PIO~AIN3/PI3. | | | | | | | · · | | VREF/PJ0, ADCK/PJ1, | | | | | | | | | EXTI/PK0, CNTI/PK1, | | | | | | | | | SDI(O)/PL1,SCK/CKUT | | | | | | | High-Level | V <sub>OH</sub> | I <sub>OH</sub> =-100 μ A | V <sub>DD</sub> -0.5 | | | V | *2 | | Output Voltage | <b>▼</b> OH | PD0~PD3, PE0~PE3, | V <sub>DD</sub> -0.5 | | | ' | - | | Output Voltage | | PF0~PF2, PG0,PG1, | , | | | | | | | | PH0, PH1, | | | | | | | · · | | SDO/PL0, SDI(O)/PL1, | | | | | | | | | SCK/CKUT | | | | | | | Low-Level | V <sub>OL1</sub> | I <sub>OL1</sub> =400 μ A | | | 0.5 | V | *2 | | Output Voltage | VOL1 | PD0~PD3, PE0~PE3, | | | 0.5 | , v | - 4 | | Output Voltage | | PF0~PF2, PG0,PG1, | | | | | | | | | PH0,PH1, | | | | | | | | | SDO/PL0, SDI(O)/PL1 | | | | | | | | | SCK/CKUT | | | | | | | | V <sub>OL2</sub> | I <sub>OL2</sub> =15mA | | | 2.0 | V | *2 | | | V ULZ | AIN4/PA0~AIN7/PA3, PB0~P | | | 2.0 | " | _ | | | | B3, PC0, PC1 | | | | | | | Output I palence | l | | | | 10 | | *2 | | Output Leakage | lop | V <sub>DD</sub> =5.5V, V <sub>OH</sub> =5.5V | | | 10 | μΑ | | | Current | | AIN4/PA0~AIN7PA3, PB0~P | | | | | | | | | B3, PC0, PC1 | ļ | | | L | | | Input | CIN | Except V <sub>DD</sub> , V <sub>ss</sub> terminals | | 10 | 20 | pF | | | Capacitance | | F <sub>osc</sub> =1MHz | <u> </u> | | | <u> </u> | | | *1 input/output p | ort is set | as an Input terminal. | | | | | | <sup>\*1</sup> input/output port is set as an input terminal. 51 <sup>\*2</sup> Input/output port is set as an Output terminal. # **ELECTRICAL CHARACTERISTICS** DC CHARACTERISTICS 2-1 $(V_{DD}=2.4\sim3.6V, V_{SS}=0V, Ta= -20\sim75^{\circ}C)$ | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNIT | NOTE | |-----------------------------|------------------|-------------------------------------------------------|----------------------|-----|---------------------|------|------| | Supply Voltage | $V_{DD}$ | V <sub>DD</sub> | 2.4 | | 3.6 | V | | | Supply Current | I <sub>DD1</sub> | $V_{DD}$ | | 0.3 | 0.5 | mΑ | *3 | | | | V <sub>DD</sub> =3V,fosc=1MHz | | | | | | | | | X'tal Oscillation In Reset | | | | | | | | I <sub>DD2</sub> | $V_{DD}$ | | 0.3 | 0.5 | mΑ | *3 | | | | V <sub>DD</sub> =3V,fosc=1MHz | | | | | | | | | Ceramic Oscillation In Reset | | | | | | | | I <sub>DD3</sub> | $V_{DD}$ | | 0.4 | 0.6 | mA | *3 | | | | V <sub>DD</sub> =3V,fosc=1MHz | | | | | | | | | CR Oscillation In Reset | | | | | | | | I <sub>DD4</sub> | V <sub>DD</sub> | | 0.6 | 1.0 | mΑ | *3 | | | | V <sub>DD</sub> =3V,fosc=2MHz | | | | | | | | | Operating (Except ADC) | | | | | | | | I <sub>DD5</sub> | V <sub>DD</sub> | | | 2.0 | μΑ | *3 | | | | V <sub>DD</sub> =3V, STANDBY Mode | | 0.5 | 0.5 | ^ | *0 | | | I <sub>ADD</sub> | AV <sub>DD</sub> | | 2.5 | 3.5 | mA | *3 | | High Lovel | \/ | $AV_{DD}=V_{DD}=3V,ADCK=225kHz$<br>AIN4/PA0~AIN7/PA3, | 0.8V <sub>DD</sub> | | $V_{DD}$ | V | *1 | | High-Level<br>Input Voltage | V <sub>IH1</sub> | PB0~PB3, PC0, PC1, | U.OV <sub>DD</sub> | | V <sub>DD</sub> | V | I | | input voitage | | PD0~PD3, PE0~PE3, | | | | | | | | | AIN0/PI0~AIN3/PI3, | | | | | | | | | SDI(O)/PL1 | | | | | | | | $V_{IH2}$ | PF0~PF2, | $0.85V_{DD}$ | | $V_{DD}$ | V | *1 | | | | PG0, PG1, PH0, PH1, | | | | | | | | | VREF/PJ0, ADCK/PJ1, | | | | | | | | | EXTI/PK0, CNTI/PK1, | | | | | | | | | RESET | | | | | | | ļ | V <sub>IH3</sub> | OSC1 | V <sub>DD</sub> -0.3 | | V <sub>DD</sub> | V | | | Low-Level | $V_{IL1}$ | AIN4/PA0~AIN7/PA3, | 0 | | $0.2V_{DD}$ | V | *1 | | Input Voltage | | PB0~PB3, PC0, PC1,<br>PD0~PD3, PE0~PE3, | | | | | | | | | AIN0/PI0~AIN3/PI3, | | | | | | | | | SDI(O)/PL1 | | | | | | | | V <sub>IL2</sub> | PF0~PF2, | 0 | | 0.15V <sub>DD</sub> | V | *1 | | | V IL∠ | PG0, PG1, PH0, PH1, | | | J. 10 V DD | v | ' | | | | VREF/PJ0, ADCK/PJ1, | | | | | | | | | EXTI/PK0, CNTI/PK1, | | | | | | | | | RESET | | | | | | | | $V_{IL3}$ | OSC1 | 0 | | 0.3 | V | | <sup>\*1</sup> Input/output port is set as an Input terminal. <sup>\*2</sup> Input/output port is set as an Output terminal. \*3 Excludes the current drawn though internal pull-up resistors. ## **ELECTRICAL CHARACTERISTICS** DC CHARACTERISTICS 2-2 (V<sub>DD</sub>=2.4~3.6V, V<sub>SS</sub>=0V, Ta=-20~75°C) | DC CHARAC | | | .4~3.6V | , - 00 | | | | |----------------|------------------|---------------------------------------------------|----------------------|--------|------|--------------------------------------------------|------| | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNIT | NOTE | | High-Level | I <sub>IH</sub> | V <sub>DD</sub> =3.6V,V <sub>IN</sub> =3.6V | | | 10 | μΑ | *1 | | Input Current | | AIN4/PA0~AIN7/PA3, | | | | , | | | | | PB0~PB3, PC0,PC1, | | | | | | | | | PD0~PD3, PE0~PE3, | | | | | | | | | PF0~PF2, PG0,PG1, PH0, | | | | | | | | | PH1, AIN0/PI0~AIN3/PI3, | | | , | | | | | | VREF/PJ0, ADCK/PJ1, | ] | | | | | | , i | | EXTI/PK0, CNTI/PK1, | | | | | | | | | SDI(O)/PL1,SCK/CKOUT, | | | | - | | | | ĺ | RESET | | | | | | | Low-Level | I <sub>IL1</sub> | V <sub>DD</sub> =3.6V,V <sub>IN</sub> =0V | | | -10 | μА | *1 | | Input Current | | Without Pull-up Resistance | | | | ~ | - | | | | AIN4/PA0~AIN7/PA3. | | | | | | | | | PB0~PB3, PC0,PC1. | | , | | | · | | | İ | PD0~PD3, PE0~PE3, | 1 | | | | | | | | PF0~PF2, PG0,PG1,PH0,PH1, | | | | | | | | | AINO/PIO~AIN3/PI3, | | | | | | | | į | VREF/PJ0, ADCK/PJ1, | | | | ļ | | | | i I | EXTI/PK0, CNTI/PK1, | | | | | | | | | SDI(O)/PL1,SCK/CKOUT | | | | | | | | į | RESET | | | | | | | | I <sub>IL2</sub> | V <sub>DD</sub> =3.6V,V <sub>IN</sub> =0V | | | -100 | μА | *1 | | | 1,1,2 | With Pull-up Resistance | | | | ~ ′ ` | | | | į į | AIN4/PA0~AIN7/PA3, | | | | - | | | | | PB0~PB3, PC0,PC1, | | | | | | | | | PD0~PD3, PE0~PE3, | | | | | | | | | PF0~PF2, PG0,PG1,PH0,PH1, | | | | | | | | | AIN0/PI0~AIN3/PI3, | | | | | | | | [ | VREF/PJ0, ADCK/PJ1, | | | | ļ | | | | | EXTI/PK0, CNTI/PK1, | | | | | | | | ļ | SDI(O)/PL1,SCK/CKOUT | | | | | | | High-Level | V <sub>OH</sub> | I <sub>OH</sub> =-80 μ A | V <sub>DD</sub> -0.5 | | | V | *2 | | Output Voltage | | PD0~PD3, PE0~PE3, | | | •. | 7 | | | | | PF0~PF2, PG0,PG1,PH0,PH1, | | | | | | | | | SDO/PL0, SDI(O)/PL1, | | | | | | | | | SCK/CKOUT | | | | | ** | | Low-Level | V <sub>OL1</sub> | Ι <sub>ΟL1</sub> =350 μ Α | | | 0.5 | V | *2 | | Output Voltage | 7 OL 1 | PD0~PD3, PE0~PE3, | | | 0.0 | • | _ | | Output Voltage | | PF0~PF2, PG0,PG1,PH0,PH1, | | | | | | | | | SDO/PL0, SDI(O)/PL1, | | | | | | | | | SCK/CKOUT | . : | | | | | | | V <sub>OL2</sub> | I <sub>OL2</sub> =5mA | | | 1.0 | V | *2 | | | ♥ OL2 | AUNIA/DAG AUNIZ/DAG DDG D | ' | | 1.0 | , v | | | | | AIN4/PAU~AIN7/PA3, PBU~P | | | | | | | L | | B3, PC0, PC1 | | | 40 | <del> </del> | ** | | Output Leakag | I <sub>OD</sub> | V <sub>DD</sub> =3.6V, V <sub>OH</sub> =3.6V | | | 10 | μΑ | *2 | | e Voltage | | AIN4/PA0~AIN7/PA3, PB0~P | | | | | | | | | B3, PC0, PC1 | | | | <u> </u> | | | Input | CIN | Except V <sub>DD</sub> ,V <sub>SS</sub> terminals | | 10 | 20 | pF | | | Capacitance | | F <sub>osc</sub> =1MHz | | | | L | | | | | | | | | | - | <sup>\*1</sup> Input/output port is set as an Input terminal. \*2 Input/output port is set as an Output terminal. # ■ ELECTRICAL CHARACTERISTICS AC CHARACTERISTICS 1 | AC CHARAC | | S 1 | | | (V <sub>ss</sub> =0V | , Ta=-20 | )~75°C) | |------------------|------------------|----------------------------|----------------------|--------|----------------------|----------|---------| | PARAMETER | SYMBOL | COND | ITIONS | MIN | TYP | MAX | UNIT | | Operating | fosc | V <sub>DD</sub> =2.4~3.6V | X'tal | 0.03 | | 2.0 | MHz | | Frequency | | | Resonator | | | | | | | | | Ceramic | 0.03 | | 2.0 | | | | | | Resonator | | | | | | | | | External | 0.03 | | 1.0 | | | | | | Resistor | | ' | | | | | | | Oscillation | | · | | | | | | <u> </u> | External Clock | 0.03 | | 2.0 | | | - | | V <sub>DD</sub> =3.6∼5.5V | X'tal | 0.03 | 1 | 4.0 | | | | | | Resonator | | <del> </del> | | | | | | | Ceramic | 0.03 | | 4.0 | | | | | | Resonator | 0.00 | <u> </u> | | | | | | | External<br>Resistor | 0.03 | | 2.0 | | | | | | Oscillation | | | | | | | <i>!</i> | | External Clock | 0.03 | | 4.0 | | | Instruction | t <sub>c</sub> | | L'Atemai Clock | 0.03 | 6/f <sub>osc</sub> | 4.0 | s | | Cycle Time | , C | | • | | Orlosc | | 9 | | External Clock | t <sub>CPH</sub> | V <sub>DD</sub> =2.4~3.6V | | 250 | <u> </u> | 16600 | ns | | Pulse Width | t <sub>CPL</sub> | V <sub>DD</sub> =3.6~5.5V | | 125 | | 16600 | 113 | | External Clock | 4CPL | V <sub>DD</sub> =2.4~5.5V | | 120 | <b></b> | 20 | nS | | Rise Time | t <sub>CPR</sub> | V <sub>DD</sub> -2.4 3.3 V | | - | | 20 | 110 | | Fall Time | t <sub>CPF</sub> | | | | | | | | RESET Low- | t <sub>RST</sub> | V <sub>DD</sub> =2.4~5.5V | | 4/fosc | 1 | | s | | Level Width | | 100 = 11 | | 1000 | | | , - | | RESET | t <sub>RSR</sub> | V <sub>DD</sub> =2.4~5.5V | | | | 20 | ms | | Rise Time | | | | - | | | | | Port Input | t <sub>PIN</sub> | V <sub>DD</sub> =2.4~5.5V | | 6/fosc | | | s | | Level Width | | | | | | | | | Edge Detection | . ; | V <sub>DD</sub> =2.4~5.5V | | | | 200 | ns | | Rise Time | t <sub>EDR</sub> | PH1 terminal | | | | | | | Fall Time | t <sub>EDF</sub> | | | | ļ | | | | Restart Signal | t <sub>STR</sub> | V <sub>DD</sub> =2.4~5.5V | | | | 200 | ns | | Rise Time | | PH0 terminal | | | | | | | External | t <sub>EXR</sub> | V <sub>DD</sub> =2.4~5.5V | | | | 200 | ns | | Interrupt Signal | | EXTI/PK0 terr | minal | | | | | | Rise Time | | | | | ļ | | | | CNTI Clock | f <sub>CT</sub> | V <sub>DD</sub> =2.4~5.5V | | | | fosc/64 | Hz | | Frequency | | CNTI/PK1 ten | minal | | | | | | CNTI High | t <sub>cr</sub> | V <sub>DD</sub> =2.4∼5.5V | | 6/fosc | | | s | | Level Width | <del> </del> | CNTI/PK1 ten | minal | | <u> </u> | | | | CNTI | | V <sub>DD</sub> =2.4∼5.5V | | | | 200 | ns | | Rise Time | t <sub>CTR</sub> | CNTI/PK1 ten | minal | | | | | | Fall Time | t <sub>ctf</sub> | | | | | | | ### ■ AC CHARACTERISTICS 1 TIMING CHART #### **■ ELECTRICAL CHARACTERISTICS** AC CHARACTERISTICS 2 SERIAL INTERFACE (VDD=2.4~5.5V, Vss=0V, Ta=-20~75°C) | | | | | | , | S 00, 14 L | | |-------------------|------------------|----------------|------------------------|-----|-----|-------------|------| | PARAMETER | SYMBOL | CONDI | TIONS | MIN | TYP | MAX | UNIT | | Serial Operating | fsc | Internal Clock | | | | (1/12)fosc* | kHz | | Frequency | | External Clock | | | | 500 | | | Clock Pulse Width | t <sub>scl</sub> | Internal Clock | VDD=2.4~3.6V | 3.0 | | | μS | | Low-Level | | | fosc=2MHz | | | | | | | | | VDD=3.6~5.5V | 1.5 | | | | | • | | | fosc=4MHz | | | | | | | | External Clock | | 1.0 | | | | | Clock Pulse Width | t <sub>sch</sub> | Internal Clock | VDD=2.4~3.6V | 3.0 | | | μS | | High-Level | | | f <sub>osc</sub> =2MHz | | | | | | | | | VDD=3.6~5.5V | 1.5 | | | | | * | | | f <sub>osc</sub> =4MHz | | | | | | | | External Clock | | 1.0 | | | | | SDI setup Time | t <sub>os</sub> | · | | 0.5 | | | μS | | To SCK ↑ | | | | | | | | | SDI Hold time | t <sub>DH</sub> | · | | 0.5 | | | μS | | To SCK ↑ | | | | | | | | | SDO Data Fix | t <sub>DCD</sub> | | | | | 0.5 | μS | | Time To SCK ↓ | | | | | | | | <sup>\*</sup> The maximum frequency of the internal serial clock fsc is selected the one-divided out put of the prescaler by the mask option. ### ■ AC CHARACTERISTICS 2 SERIAL INTERFACE TIMING CHART # ■ ELECTRICAL CHARACTERISTICS A/D CONVERTER CHARACTERISTICS $(V_{DD}=AV_{DD}=2.4\sim5.5V, V_{SS}=AV_{SS}=0V, Ta=25^{\circ}C, fosc=4MHz)$ | | | | | | <del> </del> | | |----------------------|-------------------|---------------------------------------------------------------|------|-----|------------------|------| | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNIT | | Resolution | _ | | _ | 8 | - | bits | | Absolute Accuracy | _ | V <sub>DD</sub> =5V,AV <sub>DD</sub> =5V,V <sub>REF</sub> =5V | | | ±2 | LSB | | Conversion time | t <sub>conv</sub> | V <sub>DD</sub> =5V,AV <sub>DD</sub> =5V,V <sub>REF</sub> =5V | 40 | | | μs | | Reference Voltage | V <sub>REF</sub> | | 2.4 | | AVDD | V | | Analog Input Voltage | V <sub>IA</sub> | | AVss | | V <sub>REF</sub> | ٠V | | ADCK frequency | fadck | | | | 225 | kHz | ### **■ MASK OPTION** The **NJU3505** can set or select the following options by the mask option using the same mask of p rogram coding in ROM. 1) INPUT OUTPUT Terminal Selection All of input-output terminals can select a type for each port from the following table1 to table2 by the mask option. [ CIRCUIT TYPE TABLE 1 ] | | | | TE | | | | | | | |------------|-------------------------------|----------------|--------------------------------|----|---------------------|--|---------|--|--| | | Input / Output<br>Terminal *1 | | | | | | | | | | SYMBOL | Port of Input | Port of Output | Programmable<br>Input / Output | | EXTRA FUNCTION | | REMARKS | | | | AIN4 / PA0 | | | IOP<br>IO | AD | Analog input (AIN4) | | | | | | AIN5 / PA1 | | | IOP<br>IO | AD | Analog input (AIN5) | | | | | | AIN6 / PA2 | | | IOP<br>IO | AD | Analog input (AIN6) | | | | | | AIN7 / PA3 | | | IOP<br>IO | AD | Analog input (AIN7) | | | | | | PB0 | | | IOP<br>IO | | | | | | | | PB1 | | | IOP<br>IO | | | | | | | | PB2 | | | IOP<br>IO | | | | | | | | PB3 | | | IOP<br>IO | | | | | | | | PC0 | ICP<br>IC | ONP<br>ON | | | | | | | | | PC1 | ICP<br>IC | ONP<br>ON | | | | | | | | | PD0 | ICP<br>IC | ОС | | | | | | | | | PD1 | ICP<br>IC | OC | | | | | | | | | PD2 | ICP<br>IC | ОС | | | | | | | | | PD3 | ICP<br>IC | OC | | | | | | | | | PE0 | ICP<br>IC | ОС | | | | | | | | | PE1 | ICP<br>IC | ОС | | | | | | | | | PE2 | ICP<br>IC | OC | | | | | | | | | PE3 | ICP<br>IC | ОС | | | | | | | | Note) "IOP,IO,AD,ICP,IC,ONP,ON,OC" are symbols using on MASK OPTION GENERATOR(MOG). <sup>\*1)</sup> The symbol and the detail circuits of INPUT OUTPUT TERMINAL are written in INPUT OUTPUT TERMINAL TYPE. ### [ CIRCUIT TYPE TABLE 2 ] | | | | | TERM | INAL TYPES | | | | |------------------------|-------------------------------|----------------|--------------------------------|-----------|-----------------------------------|-------------|--------------------------------------------------------------|--| | | Input / Output<br>Terminal *1 | | | | | | | | | SYMBOL | Port of Input | Port of Output | Programmable<br>Input / Output | | EXTRA FUNCTION | REMARKS | | | | PF0 | ISP<br>IS | ОС | | | | | | | | PF1 | ISP<br>IS | ОС | | | | | | | | PF2 | ISP<br>IS | ОС | | | | | | | | PG0 | ISP<br>IS | OC | | | | | | | | PG1 | ISP<br>IS | ОС | | | | | | | | PH0 | ISP<br>IS | ОС | | | Restart signal input | E<br>D | Restart signal input<br>Not Restart | | | PH1 | ISP<br>IS | OC | | | Edge detector | R<br>F<br>D | Rising edge detector Falling edge detector Not edge detector | | | AIN0 / PI0 | ICP<br>IC | | | AD | Analog input (AIN0) | | | | | AIN1 / PI1 | ICP<br>IC | | | AD | Analog input (AIN1) | | | | | AIN2 / PI2 | ICP<br>IC | | | AD | Analog input (AIN2) | | | | | AIN3 / PI3 | ICP<br>IC | | | AD | Analog input (AIN3) | | | | | V <sub>REF</sub> / PJ0 | ISP<br>IS | | | AD | Reference input | | | | | ADCK / PJ1 *2 | ISP<br>IS | | | AD | External clock input | | | | | EXTI / PK0<br>*2 | ISP<br>IS | | | IIP<br>II | External Interrupt input | R<br>F | Rising edge<br>Falling edge | | | CNTI / PK1<br>*2 | ISP<br>IS | | | IIP<br>II | External clock to Timer2 input | | | | | SDO / PL0 | | OC | | SO | Serial data output | | MSB first | | | SDI(O) / PL1<br>*2 | ICP<br>IC | ОС | | SDP<br>SD | Serial data input / output | LSB | LSB first | | | SCK / CKOUT<br>*2 *3 | | | | SCP<br>SC | Serial clock input-output | | | | | | | | 105 1 | - | Output clock divide by prescaler | 105 : 3 | | | Note) "ISP,IS,OC,ICP,IC,AD,ACP,AC,IIP,II,SO,SDP,SD,SCP,SC,E,D,R,F,MSB,LSB" are symbols using on MASK OPTION GENERATOR(MOG). <sup>\*1)</sup> The symbol and the detail circuits of INPUT OUTPUT TERMINAL are written in INPUT OUTPUT TERMINAL TYPE. <sup>\*2)</sup> The pull-up resistance is added to the terminal selected as the extra function. <sup>\*3)</sup> When Serial INPUT-OUTPUT is selected, "SCK" is selected automatically. When it is not selected, "CKOUT" is selected automatically. INPUT OUTPUT TERMINAL TYPES **Types** With Pull-up Without Pull-up **Terminals** PC0, PC1, Type ICP Type IC PD0~PD3, PE0~PE3, C-MOS AINO/PIO~ AIN3/PI3, SDI(O)/PL1 TERMINAL PF0~PF2, PG0, PG1, PH0, PH1, Type ISP Type IS **SCHMITT TRIGGER** V<sub>REF</sub>/PJ0, ADCK/PJ1, EXTI/PK0; CNTI/PK1 PD0~PD3. Type OC PE0~PE3 PF0~PF2, C-MOS PG0, PG1, PH0, PH1, TERMINAL SDO/PL0. SDI(O)/PL1 PC0, PC1 OUTPUT N-channel Type ONP Type ON (Nch) **OPEN DRAIN** PROGRAMMABLE INPUT OUTPUT TERMINAL AIN4/PA0~ Type IOP Type IO AIN7/PA3, PB0~PB3 C-MOS **INPUT** N-channel (Nch) **OPEN DRAIN** OUTPUT 2 Re-start signal Input Selection PH0 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 PH0 terminal in mode of "STANDBY", the "STANDBY" mode is released and the CPU starts the execution again from the suspended address of the program. 3 Edge Detector Selection PH1 terminal performs the extra function as the edge detector terminal. When the PH1 terminal detects the edge of the signal from the external circuit, the third bit(b2) condition of PHY24 is set to "1". The "b2" of PHY24 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 PHY24. The polarity as low to high or high to low of the input signal edge can be selected by the mask option. 4 External Interrupt of the edge Selection When PK0 terminal operates as EXTI Input terminal for the external interrupt, the polarity of the edge, rising as "low to high" or falling as "high to low", is selected by the mask option. - (5) The data order(MSB, LSB) of the Serial Interface - The data order of the Serial Interface can select either MSB or LSB first by the mask option. - 6 A/D Control Clock A/D Control Clock can select either the external clock from ADCK terminal or the internal clock from the Prescaler by the mask option. Teach Internal Clock The count clocks of Timer1 and Timer2, the Internal shift clock of the Serial Interface, the clock of the A/D control clock and the output clock through the SCK/CKOUT terminal are clocks divided in the internal prescaler, and the frequency of this 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 Note) Count clock of Timer2 can select the internal or external clock by the program. The shift clock of the serial interface can select the internal or external clock 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 | | | XAX | 1B | AC↔X | 1 | 1 | RPC=0 | | | | | AC↔X' | 1 1 | 1 | RPC=1 | | | TAP | 26 | PH(Y')←AC | 1 . 1 | 1 | | | Ш | TPA | 16 | AC←PH(Y') | 1 | 1 | · | | ပ | TAPICY | 17 | PH(Y')←AC,Y←Y+1 | | 1 | | | Z | TAPDCY | 27 | PH(Y')AC,YY-1 | | l i | | | 四日 | TMA | 0D | AC←M(X,Y) | Ιı | | | | Ш | TAM | 1D | M(X,Y)—AC | 1 | | | | ᄩ | | OA | 1 ' ' | ; | Ιi | | | S | TAMICY | • | M(X,Y)←AC,Y←Y+1 | ١. | 1 | · | | z | TAMDCY | 1A | M(X,Y)←AC,Y←Y-1 | | 1 1 | | | ₹ | TMY | 05 | Y←M(X,Y) | 1 1 | 1 | RPC=0 | | ~ | | | Y ← M(X,Y) | 1 | 1 | RPC=1 | | <u> </u> | XMA- | ОВ | AC <sup>↔</sup> M(X,Y) | 1 | 1 | • • | | | TPMICY | 03 | M(X,Y)←PH(Y'),Y←Y+1 | * | 1 | | | ∢ | TMPICY | 13 | PH(Y')←M(X,Y),Y←Y+1 | 1 * | 1 | A | | · 🔓 | TRM | 23 | M(X,Y)←ROM(PHY13,X',AC) | 1 | 2 | Y=an odd number:ROM of 4bit hi-data | | | | | | | | Y=an even number:ROM of 4bit low-data | | | CLA | 80 | AC←0 | 1 | 1 | 7. | | | LDI A,#K | 80~8F | AC←#K | 1 | 1 | #K=0~15 | | | LDI Y,#K | 90∼9F | Y←#K | 1 | 1 | RPC=0,#K=0~15 | | | | | Y#K | 1 | 1 | RPC=1,#K=0~15 | | | LDI X,#K | A0~AF | X←#K | 1 | 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 | 71 | AC←AC+1 | ٠ ا | 1 | | | | DEC A | 7F · | AC←AC-1 | • | 1 | • | | | ADD A,#K | 70~7F | AC←AC+#K | | 1 | #K=0~15 | | | AND A,M | OF | AC←AC∧M(X,Y) | ١ ٠ | . 1 | | | O | CMP A,M | 2E | AC< >M(X,Y) | | 1 | | | z | CMP Y,#K | B0∼BF | Y< >#K | * | 1 | #K=0~15 | | _ | INC Y | . 08 | Y←Y+1 | | 1 | RPC=0 | | ⊢ | | | Y'Y'+1 | | 1 | RPC=1 | | 4 | DEC Y | 18 | Y←Y-1 | | 1 | RPC=0 | | _ | | · · · · | YY'-1 | | 1 | RPC=1 | | $\supset$ | INC M | 09 | AC←M(X,Y)+1 | | 1 | | | | DEC M | 19 | AC←M(X,Y)-1 | | 1 | <b>i</b> ' | | - ≺ | YNEA | 01 | Y< >AC | | 1 | 1 | | Ö | | | AC←AC∨M(X,Y) | | 1 | | | - | OR AM | 1F | | ] . | | | | | XOR A,M | 2F | AC-AC⊕M(X,Y) | | 1 1 | · · · · · · · · · · · · · · · · · · · | | | NEG | 2D | AC-0-AC | 1 | 1 1 | * | | | SUB A,M | 1E | AC←M(X,Y)-AC | ] | 1 1 | l <sub>me 0 45</sub> | | | AND A,#K | 40~4F | AC←AC∧#K | • | 1 | #K=0~15 | | | OR A,#K | 50∼5F | ACACV#K | * | 1 | #K=0~15 | | | Mnemonic | Operation code | Function | Status | Cycle | Memo | | |----------|---------------------|----------------|----------------------------------|----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | JPL addr | 68~6F | ST=1:PC←addr,ST=0:No branch | 1 | 2 | 2byte Mnemonic | | | I | JMP addr | C0~FF | ST=1:PC←addr,ST=0:No branch | 1 | 1 | | | | O | CALL addr | 60~67 | ST=1:(SP)-PC+2,SP-SP+1,PC-addr | 1 | l 2 | 2byte Mnemonic | | | z | | | ST=0:No branch | | | [ · | | | ~ | RET | 2B | PC←(SP),SP←SP-1 | 1 | 1 | | | | . œ | RETI | 2C | PC←(SP),AC←(SP),SP←SP-1 | | 1 | 4.70 | | | 8 | | | X-(SP), X'-(SP), Y-(SP), Y'-(SP) | ŀ | ` | | | | 1.4.3 | | _ | RPC←(SP),ST←(SP) | l . | | | | | | SBIT b | 30~33 | M(X,Y)b←1 | 1 | 1 | b=0~3 | | | | RBIT b | 34~37 | M(X,Y)b←0 | 1 | 1 | b=0~3 | | | | TBIT b | 38~3B | ST←M(X,Y)b | ; | 1 | b=0~3 | | | | ТВА Ь | 3C~3F | ST—(AC)b | | 1 | b=0~3 | | | | RAR | 21 | AC | | 1 | | | | | KAK | 21 | >CY -> b3 b2 b1 b0 | | ' | | | | | | | | | | | | | | DAL . | ·22 | AC | ١. | | l · . | | | | RAL | - 22 | CY ← 63 62 61 60 ← | . " | 1 | · · | | | | | | Y | | | # 15 | | | | | | >CY > b3 b2 b1 b0 | | | | | | Z | RYR | 24 | Y | | 1 | RPC=0 | | | 0 | | | >CY → b3 b2 b1 b0 | | | | | | <u> </u> | | | | * | 1 | RPC=1 | | | . ≺ | | | —CY ← b3 b2 b1 b0 ← | | | | | | œ | RYL | 25 | Y' | | 1 | RPC=0 | | | ш | | • | —CY ← b3 b2 b1 b0 ← | | | | | | <u> </u> | RXR | | X | * | 1 | RPC=1 | | | 0 | | | >CY → b3 b2 b1 b0 | | | | | | U | | 28 | X' | * | 1 1 | RPC=0 | | | | | | >CY → b3 b2 b1 b0 | | | | | | - | | | X | * | 1 | RPC=1 | | | _<br>_ | | , | CY ← b3 b2 b1 b0 ← | | | · | | | ш | RXL | 29 | X' | * | 1 | RPC=0 | | | | | | CY ← b3 b2 b1 b0 ← | | | and the second s | | | | | | CY←1 | * | 1 | RPC=1 | | | | | | CY←0 | | | • | | | | SEC | oc | RPC←1 | 1 | 1 | | | | | CLC | 1C | RPC←0 | 0 | 1 | | | | | SRPC | 10 | | 1 | 1 | | | | | RRPC | 20 | | 1 | 1 | | | | - | NOP | 00 | No Operation | 1 | 1 | | | | SPECIAL | HLT | 07 | CPU Halted | 1 | 1 | | | | SPE | MDT | 06 | Memory Dump Test | <u>'</u> | ' | | | | | | 00 | Memory Dump Test | - | <u> </u> | | | | | <b>※</b><br>∵Trono | for direction | A.C. Acquired deter | 60 | .01 | nak naintar | | | | | fer direction | AC :Accumulator | SP | | tack pointer | | | | Λ :AND | | X :Xregister | | RPC :RPC flag | | | | | V :OR | | X' :X'register | CY | | arry flag | | | | | sive OR | Y :Yregister | ST | | atus flag | | | | + :Add | | Y' :Y'register | #K | | nmediate data | | | | - :Subtr | | PH :Peripheral register | add | | anch address | | | | < > :Comparison | | M :Data memory | () | | content of register or memory | | | | | | ROM :Program memory | | p | ointed by the address indicated in ( ). | | | | | | PC :Program counter | b | :Bi | t position | | | | <b>%Status</b> desc | cription | | | | | | #### Status description <sup>0:</sup>After the command execution, ST-flag is always set to "0". <sup>1:</sup>After the command execution, ST-flag is always set to "1". <sup>\*:</sup>Status # NJU3505 # **MEMO** [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.