**TOSHIBA TC9308AF** TOSHIBA CMOS DIGITAL INTEGRATED CIRCUIT SILICON MONOLITHIC # T C 9 3 0 8 A F ## DTS MICRO CONTROLLER CONTAINING PLL-LCD DRIVER (DTS-11) TC9308AF is a 4bit CMOS microcontroller for digital tuning system capable of making 3V low voltage operation, and containing PLL circuit, LCD driver. CPU has 4bit parallel addition and substruction (AI/SI instructions, etc.), logical operation (OR and AN instructions, etc.), plural bit judge, comparison instructions (TM, SL instructions, etc.) and time base function. The package is 60-pin mini-flat type, and has abundant I /O ports and exclusive key-input ports controlled by the powerful input/output instructions (IO, KEY instructions), besides containing PLL circuit. By combining with the prescaler TD6134AF, it permits the configuration of DTS that receives FM/AM and TV (VHF) bands. Weight: 0.85g (Typ.) #### **FEATURES** - 4bit micro controller for digital tuning system use - It is operated with 3V single power supply. $(V_{DD} = 1.8 \sim 3.6V)$ - Back-up of data memory (RAM) and each port are easily made. (by INH terminal) - Built-in LCD driver (1/2 duty, 1/2 bias driving, driving frequency: 50Hz), and boosting circuit for display - Program memory (ROM): 16 bits x 2048 steps - Data memory (RAM) : 4 bits × 128 words - Powerful instruction set of 65 kinds (all single word instruction) - Instruction executing time $80 \mu s$ (75kHz crystal connection) - Abundant addition and substraction instructions (addition instructions 12 kinds, substraction instructions 12 kinds) - Powerful compound judge instructions (TMTR, TMFR, TMT, TMF, TMTN, TMFN instructions) - TOSHIBA is continually working to improve the quality and the reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to observe standards of safety, and to avoid situations in which a malfunction or failure of a TOSHIBA product could cause loss of human life, bodily injury or damage to property. In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent products specifications. Also, please keep in mind the precautions and conditions set forth in the TOSHIBA Semiconductor Reliability Handbook. The products described in this document are subject to the foreign exchange and foreign trade laws. The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA CORPORATION for any infringements of intellectual property or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any intellectual property or other rights of TOSHIBA CORPORATION or others. The information contained herein is subject to change without notice. - Data transfer in same low address is possible. - Indirect transfer of register is possible. (MVRD, MVRS, MVGD, MVGS instructions) - 16 powerful general registers (arranged in RAM) - Stack level : 1 level - Program memory (ROM) has no conception of page, field, and JUMP and CAL instruction can be freely made among 2048 steps. - At the FM or TV band, swallow counter is composed by combining with prescaler TD6134AF, and is able to receive TV VHF band. - It is possible to freely refer to the content, 16 bits, of optional address within 1024 steps in program memory (ROM). (DAL instruction) - Independent frequency input terminal at FM and AM (FM<sub>IN</sub>, AM<sub>IN</sub>), and two phase-Comparator outputs. (DO1, DO2) - 7 kinds of reference frequency can be selected with program. - Powerful input/output instructions. (IO, KEY instructions) - Exclusive input port (K0~K3) for key input use and abundant 22 exclusive LCD driving terminals. - Abundant 10 I/O ports (ports for which input and output can be assigned for each bit : 4, exclusive input ports : 4, exclusive output ports : 2) - 3 kinds of back-up mode (only CPU operating, Crystal oscillation and Clock stop) are possible by instructions. - 2Hz timer F/F and 10Hz interval pulse output are contained. (Internal port for time base use) - Locked condition of PLL can be detected. - Universal-type IF counter is built in. #### PIN CONNECTION 1999-03-19 2/46 #### **BLOCK DIAGRAM** ## PIN FUNCTION | PIN No. | SYMBOL | PIN NAME | EXPLANATION OF FUNCTION AND OPERATION | REMARKS | |----------------|----------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------| | 58 | COM1 | LCD Common | This is a common signal output terminal to LCD. Indication of maximum 40 segments is possible with matrix made with \$1~\$20. | V <sub>DD</sub> V <sub>EE</sub> | | 19 | COM2 | Output | To this terminal, three value levels of V <sub>DD</sub> , V <sub>EE</sub> , V <sub>LCD</sub> are output with 5ms interval and 50Hz cycle. | ☑ v <sub>LCD</sub> | | 59, 60<br>1~18 | S1~S20 | LCD Segment<br>Output | This is a segment signal output terminal to LCD. Indication of maximum 40 segments is possible with matrix made with COM1 and COM2. The data for these terminals are output by the execution of SEG instruction (COM1 system) and MARK instruction (COM2 system). | V <sub>DD</sub><br>V <sub>LCD</sub> | | 20~22<br>24 | K0~K3 | Key Input Port | This is a 4bit input port for key matrix input. 16 (=4×4) key data can be input with matrix made with T0~T3 Key Return Timing Output Port. All these terminals are built in pull-down resistances. | R <sub>IN1</sub> | | 25~28 | T0~T3 | Key Return Timing<br>Output Port | This is a 4bit output port for Key Return Timing Output. Usually, it is output the timing signal for key matrix. For making the matrix, it is built in load resistance at N-ch FET side, useless the diode. | RON | | 29~32 | 100~103 | I/O Port | This is a 4bit general purpose I/O port. It is possible to assign input and output for each bit by program. | OUT | | 33~36 | IN0~IN3 | Input Port | This is a 4bit general purpose input port. The input data is read into the RAM at 4bit unit. | <b>→</b> | | 37 | BUZR | Buzzer Pulse<br>Output Port | This is the beep sound pulse output port. It is output 3 kinds of beep sound pulse signal by program. | | | 38 | MUTE | Muting Output<br>Port | This is a 1bit output port. This is usually used as muting control signal output. | 7 | | 39, 40 | OT0, OT1 | Output Port | This is a 2bit general purpose output port. Output form is N-ch FET open-drain structure, output breakdown voltage is 12V. | | | PIN No. | SYMBOL | PIN NAME | EXPLANATION OF FUNCTION AND OPERATION | REMARKS | |---------|------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | 41 | IF <sub>IN</sub> | IF Counter Input<br>Port | This is a IF signal input terminal of 16bit general purpose IF counter. This terminal has built-in amplifiers, and operates with C-connection and small amplitude. | Built-in Input<br>Amplifier | | 42, 43 | DO1, DO2 | Phase Comparator<br>Output | This is a Phase comparator output terminal of PLL. DO1 and DO2 are parallel outputs. Therefore, optimum filter constant can be set for each band of FM/AM. | VDD VDD | | 44 | AMIN | AM Programable<br>Counter Input | This is a programmable counter input terminal at 12bit direct frequency-divider mode. Usually the local oscillator signal at AM band is input to this terminal. This terminal has built-in amplifiers, and operates with C-connection and small amplitude. | Built-in Input<br>Amplifier | | 45 | PSC | Prescaler Control<br>Output | This is an output terminal which controls 1/15 or 1/16 frequency-dividing mode of two modulus prescaler. This output signal controls two frequency-dividing mode of external prescaler as using programmable counter for pulse-swallow counter. 1/15: "L", 1/16: "H" | ≪- | | 46 | FMIN | FM Programable<br>Counter Input | This is an input terminal of programmable counter at 16bit swallow-counter mode. This terminal is input the divided frequency output signal of external prescaler, and has built-in input amplifiers and operates with C-connection and small amplitude. | Built-in Input<br>Amplifier | | 48 | ĪNH | Inhibit Input | This is a signal input terminal for selecting radio mode. "H": radio ON "L": radio OFF | <b>─</b> > | | 49 | TEST | Test Input | This is an input terminal for controlling test mode control. At "H" level, test mode is made, and at "L" level, normal operation is carried out. In the test mode, the device operates as evaluator chip, and program evaluation is made possible on EPROM base through combination with external simulation board. This terminal is built in a pull-down resistance. | R <sub>IN2</sub> | | PIN No. | SYMBOL | PIN NAME | EXPLANATION OF FUNCTION AND OPERATION | REMARKS | |---------|------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------| | 50 | $\overline{x_T}$ | Crystal Oscillation | This is a connecting terminal of crystal resonator. Reference crystal of 75kHz is connected. | Built-in | | 51 | x <sub>T</sub> | Terminal | During the execution of CKSTP instruction, oscillation is automatically stopped. | Oscillator | | 52 | ĪNT | Initializing Input | This is a system reset signal input terminal of the device. During INT is at "L" level, reset is applied, and when it becomes "H" level, it is normal operation mode. | | | 54 | V <sub>LCD</sub> | | These are voltage double boosting terminal | | | 55 | C1 | Voltage Double<br>Boosting Terminal | for driving LCD. Boosting capacitors are connected to these | _ | | 56 | C2 | boosting reminar | terminals. (Typ. $0.1 \sim 3.3 \mu$ F) | | | 57 | C3 | Reference Voltage<br>Stabilizing<br>Capacitor<br>Connecting<br>Terminal | The stabilizing capacitor of Reference Voltage is connected to this terminal for LCD driving. (Typ. $0.01 \sim 0.1 \mu F$ ) | _ | | 53 | $V_{DD}$ | Power Supply | Power supply voltage is applied. | | | 47 | GND | Terminal | $V_{DD} = 1.8 \sim 3.6 V \text{ (Typ. 3.0 V)}$ | | #### **EXPLANATION OF OPERATION** #### ○ CPU CPU is composed of program counter, stack register, ALU, program memory, data memory, Gregister, carry F/F and judging circuit. #### 1. Program counter (PC) Program counter is a bolck to designate the address of program memory (ROM), and is composed of 11 bits binary up counter. This is cleared by system reset, and the program starts from zero address. Usually, it's increment is made one by one everytime the one instruction is executed, but when JUMP instruction or CAL instruction is executed, the address designated at operand part of that instruction is loaded. Further, when the instruction (AIS, SLT, TMT, RNS instructions, etc.) having skip function is executed, two increments of program counter is made if the result is the condition to be skipped, and the succeeding instruction is skipped. #### 2. Stack register (STACK) This is a register composed of $1 \times 11$ bits during the execution of subroutine call instruction, the value obtained by adding +1 to the content of program counter, namely return address, is housed. The content of stack register is loaded on the program counter by the execution of return instruction. (RN, RNS instructions) This stack level is 1 level, and nesting is 1 level. ## 3. ALU ALU has binary 4 bits parallel addition and subtraction, logical operation, comparison and plural bit judge functions. This CPU has no accumulator, and all operations directly treat the contents of data memory. #### 4. Program memory (ROM) Program memory is composed of 16bit × 2048 steps and is the address of 000H~7FFH. Program memory has no concept of page or field, so JUMP instruction and CAL instruction can be freely used among 2048 steps. Further, it is possible to use optional address of program memory as data area, and its content, 16 bits, can be loaded to the data register by executing DAL instruction. (Note) Provide the data area at the address outside the program loop in the program memory. (Note) In DAL instruction, the address of program memory can be designated as the data area becomes 1024 steps of 000H~3FFH. #### 5. Data memory (RAM) Data memory is composed of 4bit x 128 words and used for storing data. This 128 words are expressed with row address (3bit) and column address (4 bits). 64 words (row address = 4H~7H) among the data memory are indirect addressing by Gregister. For this reason, when carrying out data processing within this territory, it is necessary to designate row address by G-register beforehand Area of 00H~0FH address in data memory is called general register, and can be used only by designating column address (4 bits). These 16 general registers can be used for operation and transfer between data memories. Further, it can also be used as ordinary data memory. (Note) The column address (4 bits) to designate general register becomes register number of the general register. (Note) It is also possible to indirectly designate all of row address (=0H~7H) by G-register. #### 6. G-register (G-REG.) G-register is a 3 bits register for addressing row address ( $D_R = 4H \sim 7H$ ) of 64 words in data memory. Content of this register is effective during executing MVGD instruction, MVGS instruction, and is not related with the execution of other instructions. This register is treated as one of the port, and its content is set by the execution of IO instruction among input and output instructions. (refer to register port item 1 page 37) #### 7. Data register (DATA REG.) This is a register composed of $1 \times 16$ bits. In this register, 16 bits data of optional address among the program memory is loaded during executing of DAL instruction. This register is treated as one of the port, and when KEY instruction among input and output instruction is executed, it's content is read in the data memory in 4 bits unit. (refer to register port item 2 page 37) #### 8. Carry F/F (C·F/F) This is set when carry or borrow is produced as a result of executing operational instruction, and is reset when it is not produced. Content of carry F/F changes only when addition and subtraction instruction is executed, and does not change during the execution of other instructions. ## 9. Judging circuit (J) When a instruction with skip function is executed, this circuit judges it's skip condition. When skip condition is satisfied, this circuit makes two increments of program counter, and skips the succeeding instruction. It is provided with 31 kinds of instructions having abundant skip function. (refer to Item 11, explanation list of function and operation of instructions, $\times$ marked instruction page 11~17) #### 10.List of instruction set 65 kinds of instruction set are included, all of which consisting of one word instruction. These instructions are expressed with 6 bits instruction code. | HIGHER F | RANK<br>BITS | 00 | 01 | 10 | 11 | |-------------|--------------|------------------------|-----------|--------------------------------------|---------------------------| | RANK 4 BITS | / | 0 | 1 | 2 | 3 | | 0000 | 0 | Al M, I | AD r, M | LD r, M | SLTI M, I | | 0001 | 1 | AIS M, I | ADS r, M | ST M, r | SGEI M, I | | 0010 | 2 | AIN M, I | ADN r, M | MVRD r, M | SEQI M, I | | 0011 | 3 | SI M, I | SU r, M | MVRS M, r | SNEI M, I | | 0100 | 4 | SIS M, I | SUS r, M | MVSR M <sub>1</sub> , M <sub>2</sub> | SLT r, M | | 0101 | 5 | SIN M, I | SUN r, M | MVIM M, I | SGE r, M | | 0110 | 6 | CAL ADDR1 | ORR r, M | MVGD r, M | SEQ r, M | | 0111 | 7 | CAL ADDR <sub>1</sub> | ANDR r, M | MVGS M, r | SNE r, M | | 1000 | 8 | AIC M, I | AC r, M | PLL M, C | TMTR r, M | | 1001 | 9 | AICS M, I | ACS r, M | SEG M, C | TMFR r, M | | 1010 | Α | AICN M, I | ACN r, M | MARK M, C | TMT M, N | | 1011 | В | SIB M, I | SB r, M | IO M, C | TMF M, N | | 1100 | С | SIBS M, I | SBS r, M | KEY M, C | TMTN M, N | | 1101 | D | SIBN M, I | SBN r, M | WAIT P | TMFN M, N | | 1110 | E | IIIMD ADDD | ORIM M, I | XORIM M, I | DAL ADDR <sub>2</sub> , r | | 1111 | F | JUMP ADDR <sub>1</sub> | ANIM M, I | XORR r, M | RN, RNS, CKSTP, NOOP | 11. Explanation list of function and operation of instructions (Explanation of symbols) M : Data memory address Normally, one of 00H~3FH address of data memory. r : General register One of 00H~0FH address of data memory. PC : Program counter (11 bits) STACK : Stack register (11 bits) G : G-register (3 bits) DATA : Data register (16 bits) I : Immediate data (4 bits) N : Bit position (4 bits) - : All "0" C : Code No. of port (4bit) C<sub>N</sub>: Lower rank 3bit of port code No. R<sub>N</sub> : General register No. (4bit) ADDR<sub>1</sub>: Program memory address in page 0 or 1 (10bit) ADDR<sub>2</sub>: Higher rank 6bit of program memory address in page 0 Ca : Carry b : Borrow PLL : Port treated during the execution of PLL instruction SEG : Port treated during the execution of SEG instruction MARK : Port treated during the execution of MARK instruction IO : Port treated during the execution of IO instruction KEY : Port treated during the execution of KEY instruction ( ) : Register or data memory content [ ]<sub>C</sub> : Content of port indicated by code No. C (4bit) [ ] : Content of data memory indicated by the content of register or data memory [ ]p : Content of program memory (16bit) IC : Instruction code (6bit) : Instruction having skip function DC : Data memory column address (4bit) DR : Data memory row address (2bit) P : Wait condition select bit at WAIT instruction (Note) Address 000H~3FFH of program memory address: Page 0 area Address 400H~7FFH of program memory address: Page 1 area | <u>-</u> | GR S T<br>GR S T<br>T S NUEMONIC | | EXPLANATION OF | EXPLANATION OF | MACHINE LANGUAGE (16bit) | | | | |-------------|----------------------------------|---------------------|----------------------------------------------------------------------------|---------------------------------------|--------------------------|----------------|----------------|----------------| | INS<br>GR. | IVINEIVIONIC | SK I P<br>FUNCT I C | FUNCTION | OPERATION | IC<br>(6bit) | A<br>(2bit) | B<br>(4bit) | C<br>(4bit) | | | AI M, I | | Add immediate data to memory | M←(M) + I | 000000 | D <sub>R</sub> | DC | I | | | AIS M, I | * | Add immediate data to memory, then skip if carry | M←(M) + I<br>Skip if carry | 000001 | D <sub>R</sub> | D <sub>C</sub> | I | | | AIN M, I | * | Add immediate data to memory, then skip if not carry | M←(M) + I<br>Skip if not carry | 000010 | D <sub>R</sub> | D <sub>C</sub> | I | | | AIC M, I | | Add immediate data to memory with carry | M←(M) + I + ca | 001000 | D <sub>R</sub> | DC | I | | NOIL | AICS M, I | * | Add immediate data to memory with carry, then skip if carry | M←(M)+I+ca<br>Skip if carry | 001001 | D <sub>R</sub> | D <sub>C</sub> | I | | INSTRUCTION | AICN M, I | * | Add immediate data to memory with carry, then skip if not carry | M←(M)+I+ca<br>Skip if not carry | 001010 | D <sub>R</sub> | D <sub>C</sub> | ı | | | AD r, M | | Add memory to general register | r←(r) + (M) | 010000 | D <sub>R</sub> | DC | R <sub>N</sub> | | ADDITION | ADS r, M | * | Add memory to<br>general register, then<br>skip if carry | r←(r) + (M)<br>Skip if carry | 010001 | D <sub>R</sub> | DC | R <sub>N</sub> | | Ā | ADN r, M | * | Add memory to<br>general register, then<br>skip if not carry | r←(r) + (M)<br>Skip if not carry | 010010 | D <sub>R</sub> | D <sub>C</sub> | R <sub>N</sub> | | | AC r, M | | Add memory to general register with carry | r←(r) + (M) + ca | 011000 | D <sub>R</sub> | D <sub>C</sub> | R <sub>N</sub> | | | ACS r, M | * | Add memory to general register with carry, then skip if carry | r←(r) + (M) + ca<br>Skip if carry | 011001 | D <sub>R</sub> | DC | R <sub>N</sub> | | | ACN r, M | * | Add memory to<br>general register with<br>carry, then skip if not<br>carry | r←(r) + (M) + ca<br>Skip if not carry | 011010 | D <sub>R</sub> | DC | R <sub>N</sub> | | ⊢ | NANIENAGNUG | NOIL | EXPLANATION OF | EXPLANATION OF | MACHII | MACHINE LANGUAGE (16bit) | | | | |--------------|-------------|---------------------|-------------------------------------------------------------------------------------|---------------------------------------|--------------|--------------------------|-------------|----------------|--| | INST.<br>GR. | MNEMONIC | SK I P<br>FUNCT I ( | FUNCTION | OPERATION | IC<br>(6bit) | A<br>(2bit) | B<br>(4bit) | C<br>(4bit) | | | | SI M, I | | Subtract immediate data from memory | M←(M) – I | 000011 | D <sub>R</sub> | DC | I | | | | SIS M, I | * | Subtract immediate<br>data from memory,<br>then skip if borrow | M←(M) – I<br>Skip if borrow | 000100 | D <sub>R</sub> | DC | I | | | | SIN M, I | * | Subtract immediate data from memory, then skip if not borrow | M←(M) – I<br>Skip if not borrow | 000101 | D <sub>R</sub> | DC | I | | | z | SIB M, I | | Subtract immediate data from memory with borrow | M←(M) – I – b | 001011 | D <sub>R</sub> | DC | I | | | INSTRUCTION | SIBS M, I | * | Subtract immediate data from memory with borrow, then skip if borrow | M←(M) – I – b<br>Skip if borrow | 001100 | D <sub>R</sub> | DC | I | | | | SIBN M, I | * | Subtract immediate data from memory with borrow, then skip if not borrow | M←(M) – I – b<br>Skip if not borrow | 001101 | D <sub>R</sub> | DC | I | | | BTRACTION | SU r, M | | Subtract memory from general register | r←(r) – (M) | 010011 | D <sub>R</sub> | Dc | R <sub>N</sub> | | | SUBTR | SUS r, M | * | Subtract memory from<br>general register, then<br>skip if borrow | r←(r) – (M)<br>Skip if borrow | 010100 | D <sub>R</sub> | DC | R <sub>N</sub> | | | | SUN r, M | * | Subtract memory from<br>general register, then<br>skip if not borrow | r←(r) – (M)<br>Skip if not borrow | 010101 | D <sub>R</sub> | DC | R <sub>N</sub> | | | | SB r, M | | Subtract memory from general register with borrow | r←(r) – (M) – b | 011011 | D <sub>R</sub> | DC | R <sub>N</sub> | | | | SBS r, M | * | Subtract memory from<br>general register with<br>borrow, then skip if<br>borrow | r←(r) – (M) – b<br>Skip if borrow | 011100 | D <sub>R</sub> | DC | R <sub>N</sub> | | | | SBN r, M | * | Subtract memory from<br>general register with<br>borrow, then skip if<br>not borrow | r←(r) – (M) – b<br>Skip if not borrow | 011101 | D <sub>R</sub> | DC | R <sub>N</sub> | | | - | B 4815 B 4 | 01116 | NOIL | EXPLANATION OF | EXPLANATION OF | MACHI | NE LAN | GUAGE | (16bit) | |---------------|------------|-------|---------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------|----------------|----------------|----------------| | INST.<br>GR. | MNEM | ONIC | SK I P<br>FUNCT I ( | FUNCTION | OPERATION | IC<br>(6bit) | A<br>(2bit) | B<br>(4bit) | C<br>(4bit) | | | SLTI | М, І | * | Skip if memory is less than immediate data | Skip if (M) <i< td=""><td>110000</td><td>D<sub>R</sub></td><td>DC</td><td>I</td></i<> | 110000 | D <sub>R</sub> | DC | I | | | SGEI | M, I | * | Skip if memory is<br>greater than or equal<br>to immediate data | Skip if (M)≥I | 110001 | D <sub>R</sub> | D <sub>C</sub> | I | | NO I | SEQI | M, I | * | Skip if memory is equal to immediate data | Skip if (M) = I | 110010 | D <sub>R</sub> | DC | I | | NSTRUCTION | SNEI | M, I | * | Skip if memory is not equal to immediate data | Skip if (M)≠I | 110011 | D <sub>R</sub> | DC | Ι | | NO NOS | SLT | r, M | * | Skip if general register is less than memory | Skip if (r)<(M) | 110100 | D <sub>R</sub> | DC | R <sub>N</sub> | | COMPARI | SGE | r, M | * | Skip if general register is greater than or equal to memory | Skip if (r)≥(M) | 110101 | D <sub>R</sub> | DC | R <sub>N</sub> | | | SEQ | r, M | * | Skip if general register is equal to memory | Skip if (r) = (M) | 110110 | D <sub>R</sub> | DC | R <sub>N</sub> | | | SNE | r, M | * | Skip if general<br>register is not equal<br>to memory | Skip if (r)≠(M) | 110111 | D <sub>R</sub> | DC | R <sub>N</sub> | | Z | LD | r, M | | Load memory to general register | r←(M) | 100000 | D <sub>R</sub> | DC | R <sub>N</sub> | | JCT I | ST | M, r | | Store general register to memory | M←(r) | 100001 | $D_{R}$ | DC | R <sub>N</sub> | | ER INSTRUCTIO | MVRD | r, M | | Move memory to destination memory referring to general register in the same row | [D <sub>R</sub> , (r)]←(M) | 100010 | D <sub>R</sub> | DC | R <sub>N</sub> | | TRANSF | MVRS | M, r | | Move source memory<br>referring to general<br>register to memory in<br>the same row | M←[D <sub>R</sub> , (r)] | 100011 | D <sub>R</sub> | DC | R <sub>N</sub> | | <u> </u> | . MNEMONIC | | EXPLANATION OF | EXPLANATION OF | MACHII | NE LANG | GUAGE | (16 | bit) | |--------------|-------------|-------------------|-----------------------------------------------------------------------------------------|------------------------------------------|-------------------------|----------------|-----------------|-----|----------------| | INST.<br>GR. | MINEMONIC | SK I P<br>FUNCT I | FUNCTION | OPERATION | IC<br>(6bit) | A<br>(2bit) | B<br>(4bit) | (4 | C<br>lbit) | | INSTRUCTION | MVSR M1, M2 | | Move memory to memory in the same row | $(D_R, D_{C1}) \leftarrow (D_R, D_{C2})$ | 100100 | D <sub>R</sub> | D <sub>C1</sub> | С | PC2 | | -RUC | MVIM M, I | | Move immediate data to memory | M←I | 100101 | D <sub>R</sub> | DC | | I | | E.R. | MVGD r, M | | Move memory to<br>destination memory<br>referring to G-register<br>and general register | [(G), (r)]←(M) | 100110 | D <sub>R</sub> | DC | | R <sub>N</sub> | | TRANSF | MVGS M, r | | Move source memory<br>referring to G-register<br>and general register<br>to memory | M←[(G), (r)] | 100111 | D <sub>R</sub> | DC | | R <sub>N</sub> | | | PLL M, C | | Input PLL port data to memory | M←[PLL]C | 101000 | D <sub>R</sub> | DC | 0 | c <sub>N</sub> | | z | | 1 12 101, C | | Output contents of memory to PLL port | [PLL] <sub>C</sub> ←(M) | 101000 | D <sub>R</sub> | DC | 1 | | STRUCTION | SEG M, C | | Input SEG port data to memory | M←[SEG] <sub>C</sub> | 101001 | $D_{R}$ | DC | 0 | c <sub>N</sub> | | TRU | SEG M, C | | Output contents of memory to SEG port | [SEG] <sub>C</sub> ←(M) | 101001 | D <sub>R</sub> | DC | 1 | c <sub>N</sub> | | Z<br> - | | | Input MARK port data to memory | M←[MARK] <sub>C</sub> | | D <sub>R</sub> | DC | 0 | c <sub>N</sub> | | OUTPUT | MARK M, C | | Output contents of memory to MARK port | [MARK] <sub>C</sub> ←(M) | 101010 | D <sub>R</sub> | D <sub>C</sub> | 1 | c <sub>N</sub> | | AND 0 | IO M.C | | Input IO port data to memory | M←[IO] <sub>C</sub> | 101011 | D <sub>R</sub> | DC | 0 | c <sub>N</sub> | | PUT A | Ю М, С | | Output contents of memory to IO port | [IO] <sub>C</sub> ←(M) | 101011 | D <sub>R</sub> | DC | 1 | CN | | N - | KEY M.C | | Input KEY port data to memory | M←[KEY] <sub>C</sub> | | D <sub>R</sub> | DC | 0 | c <sub>N</sub> | | | KEY M, C | | Output contents of memory to KEY port | [KEY] <sub>C</sub> ←(M) | 101100 | D <sub>R</sub> | DC | 1 | C <sub>N</sub> | | - | NANIENAONIIC | NOIL | EXPLANATION OF | EXPLANATION OF | MACHINE LANGUAGE (16bit) | | | | |---------------|--------------|---------------------|-----------------------------------------------------------------------------------------------|--------------------------------|--------------------------|----------------|----------------|----------------| | INST.<br>GR. | MNEMONIC | SK I P<br>FUNCT I ( | FUNCTION | OPERATION | IC<br>(6bit) | A<br>(2bit) | B<br>(4bit) | C<br>(4bit) | | | ORR r, M | | Logical OR of general register and memory | r←(r)√(M) | 010110 | D <sub>R</sub> | DC | R <sub>N</sub> | | N 0 _ | ANDR r, M | | Logical AND of general register and memory | r←(r)∧(M) | 010111 | D <sub>R</sub> | DC | R <sub>N</sub> | | RAT | ORIM M, I | | Logical OR of memory and immediate data | M←(M)√I | 011110 | $D_{R}$ | DC | ı | | CAL OPERATION | ANIM M, I | | Logical AND of<br>memory and<br>immediate data | M←(M)∧I | 011111 | D <sub>R</sub> | DC | I | | LOGIC | XORIM M, I | | Logical exclusive OR of memory and immediate data | M <b>←</b> (M)⊕I | 101110 | D <sub>R</sub> | DC | - | | | XORR r, M | | Logical exclusive OR of general register and memory | r←(r)⊕(M) | 101111 | D <sub>R</sub> | DC | I | | | TMTR r, M | * | Test general register<br>bits by memory bits,<br>then skip if all bits<br>specified are true | Skip if r [N (M)]<br>= all "1" | 111000 | D <sub>R</sub> | DC | R <sub>N</sub> | | NSTRUCTION | TMFR r, M | * | Test general register<br>bits by memory bits,<br>then skip if all bits<br>specified are false | Skip if r [N (M)]<br>= all "0" | 111001 | D <sub>R</sub> | DC | R <sub>N</sub> | | INSTR | TMT M, N | * | Test memory bits,<br>then skip if all bits<br>specified are true | Skip if M (N) = all "1" | 111010 | D <sub>R</sub> | DC | N | | JUDGE | TMF M, N | * | Test memory bits,<br>then skip if all bits<br>specified are false | Skip if M (N) = all "0" | 111011 | D <sub>R</sub> | D <sub>C</sub> | N | | B I ⊥ | TMTN M, N | * | Test memory bits,<br>then not skip if all<br>bits specified are true | Skip if M (N)<br>= not all "1" | 111100 | D <sub>R</sub> | DC | N | | | TMFN M, N | * | Test memory bits,<br>then not skip if all<br>bits specified are false | Skip if M (N)<br>= not all "0" | 111101 | D <sub>R</sub> | DC | N | | - | | KIP<br>UNCTION | EXPLANATION OF | EXPLANATION OF | MACHINE LANGUAGE (16 bit) | | | | |-----------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------|---------------------------|----------------------------|-------------|----------------| | INST.<br>GR. | S . MNEMONIC | | FUNCTION | OPERATION | IC<br>(6bit) | A<br>(2bit) | B<br>(4bit) | C<br>(4bit) | | | SUBROUTINE INSTRUCTION NA TRUCTION NA TRUCTION NA TRUCTION NA TRUCTION NA TRUCTION | | Call subroutine in page 0 | STACK← (PC) + 1 and<br>PC←ADDR <sub>1</sub> in page 0 | 000110 | ۸۵۲ | NP. (10 | hi+\ | | T NE | | | Call subroutine in page 1 | or 1 | 000111 | ADDR <sub>1</sub> (10 bit) | | DIC) | | ROUT | RN | | Return to main routine | PC←(STACK) | 111111 | 00 | _ | _ | | SUB<br>INS | RNS | * | Return to main routine and skip unconditionally | PC←(STACK) and skip | 111111 | 01 | - | - | | 1₽<br>- | JUMP ADDR <sub>1</sub> | | Jump to the address specified in page 0 | PC←ADDR₁ in page 0 | 001110 | | | 1.43 | | JUMP<br>T S N I | | | Jump to the address specified in page 1 | or 1 | 001111 | ADDR <sub>1</sub> (10 bit) | | DIT) | | NO | WAIT P | | At P = "0"H, the condition is CPU waiting (Soft wait mode) | Weit of condition D | 101101 | P | _ | _ | | NSTRUCTION | WAII P | At P = "1"H, except for clock generator, all function is waiting (Hard wait mode) Wait at condition P | wait at condition P | 101101 | - | _ | _ | | | THER IN | DAL ADDR <sub>2,</sub> r | | Load program<br>memory in page 0 to<br>DATA register | DATA $\leftarrow$ [ADDR <sub>2</sub> + (r)]p in page 0 | 111110 | ADI<br>(6k | _ | R <sub>N</sub> | | 01 | CKSTP | | Clock generator stop | Stop clock generator if INH = "0" | 111111 | 10 | _ | _ | | | NOOP | | No operation | | 111111 | 11 | _ | _ | - (Note 1) During the execution of input and output instruction, control of input/output instruction is automatically carried out at the most significant bit in Code No. (C) of port. - MSB = "1" of Code No. (C) : Output instruction - MSB = "0" of Code No. (C) : Input instruction - (Note 2) In the TC9308AF, the input port treated by the execution of SEG, MARK instruction does not exist, so these input instruction can not be used. - (Note 3) Among 10 bits of the program memory address assigned by DAL instruction, the lower rank of 4 bits become indirect addressing based on the content of general register. DAL instruction executing time is $160 \mu s$ . ## O Connection of crystal resonator Connect 75kHz crystal resonator with the crystal oscillator terminals (XT, $\overline{X_T}$ terminal) of the device as shown below. This oscillation signal is supplied to clock generator and reference frequency divider, and produced each timing signal of CPU and reference frequency signal. Adjust the crystal oscillation frequency while monitoring LCD segment output terminal. (Note) Use crystal resonator of low CI value and satisfactory starting characteristics. #### O System reset System reset is applied to the device when "L" level is given to $\overline{\text{INT}}$ terminal, or when the voltage, $0V \rightarrow 1.8V \sim 3.6V$ is supplied to $V_{DD}$ terminal (power on reset). After the lapse of 100ms stand-by time succeeding to the system reset, program starts from zero address. As power on reset function is employed usually, INT terminal is fixed at "H" level. - (Note 1) During the system reset time and the succeeding stand-by time, LCD common output and segment output are fixed at "L" level. - (Note 2) After system reset, all of I/O ports are set at input mode, but initialization of output port and internal port (G-register, etc.) is not carried out. Especially, at the initial power on stage, content of these ports is indefinite, and therefore it is necessary to make initialization with program according to your use. ## O Back up mode If CKSTP instruction or WAIT instruction is executed when $\overline{\text{INH}}$ terminal is at "L" level, it can select for the three kinds of back up mode. #### 1. Clock stop mode If CKSTP instruction is executed when $\overline{\text{INH}}$ terminal is at "L" level, clock generator and CPU internal of the device stop operation completely, and memory back up state can be realized at low current consumption (1 $\mu$ A MAX. at V<sub>DD</sub> = 3V). At this time, LCD display driver terminals and output ports are all fixed at "L" level or off condition. During this clock stop mode, supply voltage can be reduced down to 1.2V and used for exchange of battery. So this mode is available when the battery is changed in the radio set. In clock stop mode, program stops at the execution address of CKSTP instruction. The clock stop mode is released at $\overline{INH} = "H"$ level or changing the input condition of I/O port (IO0~IO3) set at input mode, and the next address is executed after the lapse of standby time of 100ms. - (Note 1) In the clock stop mode, the condition of output terminal is all fixed at "L" level or off but output port holds on the data just before clock stop mode. - (Note 2) When CKSTP instruction is executed during $\overline{\text{INH}} = \text{"H"}$ level, the same operation as NOOP instruction is made (Clock stop mode is not entered). EXAMPLE OF THE MEMORY BACK UP CIRCUIT USING CAPACITOR AT CLOCK STOP MODE #### 2. Waiting mode If WAIT instruction is executed when $\overline{\text{INH}}$ terminal is at "L" level, it can select the hardware waiting mode or the software waiting mode. 1) Software waiting mode If WAIT instruction is executed at designated operand port [P=0H], only CPU internal of the device stop operation, and software waiting mode can be realized at low current consumption. Since the other part of clock generator and display circuit operate normally, at the time of using the program of clock function, the software waiting mode is effective to realize at low current consumption during the clock operation. #### 2) Hardware waiting mode If WAIT instruction is executed at designated operand part [P=1H], all the function without crystal oscillator are stopped and hardware waiting mode can be realized at lower current consumption than software waiting mode (under $100\mu$ A at $V_{DD}=3.0V$ ). At this time, CPU and display circuit stop operation, output terminal for LCD display is fixed at "L" level automatically. In these waiting mode, program stops at the execution address of WAIT instruction, and waiting is released in following condition, so next address is executed. - 3) Released condition of waiting mode - Changing to <del>INH</del> = "H" level - Key input terminal (K0~K3) is set at "H" level. - 2Hz timer F/F is set at "1". - Changing the input condition of I/O port (IO0~IO3) set at input mode - MUTE port is set at "1". - (Note) In waiting mode, each of output terminal is held on the condition just before waiting mode. | O (94) NEP (95) | - | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | O (φ4) N N N N N N N N N | TEST #0 | | O (94) Y2 Y4 Y8 Y1 Y2 Y4 Y8 Y1 Y2 Y4 Y8 Y1 Y1 Y2 Y4 Y8 Y1 Y1 Y2 Y4 Y8 Y1 Y1 Y2 Y4 Y8 Y1 Y1 Y2 Y4 Y8 Y1 Y1 Y1 Y2 Y4 Y8 Y1 Y1 Y1 Y1 Y1 Y1 Y1 | 0# | | O (04) Y1 | - | | NUTE INO | 1/1 | | NUTE INO | ] | | 2 2 2 | | | | | | Y8 | | | MARK (COM2) (φ3) (φ3) (γ2) (γ4) (γ3) (γ3) (γ3) (γ3) (γ3) (γ3) (γ3) (γ3 | | | (43) (43) (43) (43) (43) (43) (43) (43) | 1 | | V 1 1 2 13 2 13 2 13 2 13 2 13 2 13 2 13 | | | 88 S8 S | | | (2) (2) (3) (4) (4) (4) (4) (4) (4) (4) (4) (4) (4 | / I | | (φ2) (φ2) (φ2) (φ2) (φ3) (φ3) (φ3) (φ3) (φ3) (φ3) (φ3) (φ3 | | | 12 23 85 813 712 | | | Y8 F7 F7 F7 F7 F8 | | | FLL (61) Y2 Y4 Y2 Y4 Y2 Y4 Y4 Y2 Y4 Y4 | | | | | | # F12 | | | OUTPUT PORT (L) OUTPUT PORT (K) OUTPUT PORT (K) OUTPUT PORT (K) OUTPUT PORT (L) OUTPUT PORT (K) OUTPUT PORT (K) OUTPUT PORT (K) OUTPUT PORT (K) | $oxed{oxed}$ | 1999-03-19 21/46 ## ○ I/O map All ports in the device are expressed by matrix of five input and output instruction (PLL instruction, SEG instruction, MARK instruction, IO instruction, KEY instruction) and 4 bits of code No.C. Assignment of these ports is indicated previously as I/O map. In the I/O map, port names treated in the execution of each input and output instruction are assigned horizontally, while code No. of port are assigned vertically. G-register and data register are also treated as port. Basically, the data is treated at each port as 4 bits unit, and code No. (C) = 0H~7H are assigned to input port, while code No. (C) = 8H~FH are assigned to output port. - (Note 1) The port indicated with oblique line on I/O map is a port not existing in the device. In the execution of output instruction, when data is output to the non-existing output port, no effect is given to the content of other port or data memory. When non-existing input port is designated during the execution of input instruction, the content read into the data memory becomes indefinite. - (Note 2) Among the output ports on I/O map, \* marked port is unused port. The data outputted here becomes "don't care". - (Note 3) Regarding the content of port expressed in 4 bits, Y1 corresponds to the least significant of the data of data memory, and Y8 to the most significant bit. Data of each port is all treated with positive logic. - (Note 4) Each port assigned by five input and output instruction and code No. C is coded as follows: ## O Programmable counter Programmable counter block is composed of external two modulus prescaler TD6134AF, 4 bits + 12 bits programmable binary counter, and PLL output ports to control them. ## 1. PLL output port ( $\phi$ L10 $\sim$ $\phi$ L14) The exclusive PLL port is used to control the division number and the dividing mode and made access by PLL output instruction designated operand part $[C_N = 0 \sim 4]$ . #### 1) Structure of PLL port ## 2) Setting of dividing mode Pulse swallow mode or direct dividing mode are selected by FM port. In AM band, it selects the direct dividing mode. In FM or VHF band, it selects pulse swallow mode combined with external two modulus prescaler, TD6134AF. | FM | DIVIDING MODE | EXAMPLE OF RECEIVING BAND | OPERATING<br>FREQUENCY RANGE | INPUT<br>TERMINAL | DIVISION<br>NUMBER | PRESCALER | |----|----------------------|---------------------------|------------------------------|-------------------|--------------------|-----------| | 0 | Direct Dividing Mode | MW / LW | 0.5~2.5MHz | AMIN | n | | | | 1/4×(1/15 or 1/16) | FM | (Note 1) | FMIN | (Note 2) | | | , | Pulse swallow Mode | LIVI | 50~150MHz | Livil | 4·n | TD6134AF | | ' | 1/8×(1/15 or 1/16) | VHF | (Note 1) | EN/1 | 8∙n | ID0134AF | | | Pulse swallow Mode | V OF | 50~250MHz | FMIN | 0.11 | | (Note 1) This shows the input frequency range to TD6134AF. (Note 2) "n" shows the programmed division number. 3) Setting of frequency division number Division number of programmable counter is set on P0~P15 ports with binary. Pulse-swallow mode (16bit) - % Frequency division number setting range (pulse swallow mode) n = 210H~FFFFH (528~65535) - Direct dividing mode (12bit) - Frequency division number setting range (Direct dividing mode) n = 10H~FFFH (16~4095) - (Note 1) As the programmable counter is not provided with dividing offset, the programmabled number becomes the actual frequency division number. However, in the case of FM band, the actual frequency division number becomes four times of programmed value, and in VHF band, the actual frequency division number becomes eight times of programmed value in combination with prescaler TD6134AF. - (Note 2) In case of direct dividing mode, P0~P3 port ( $\phi$ L11) data becomes unrelated and P4 port becomes LSB. - (Note 3) Frequency division number is entirely renewed at the time of data setting of MSB port (φL14). So this prevents wrong influence from giving to the lock up time. For this reason, the data of MSB port (φL14) must be set at the end of division number. Even when the data setting is considered unnecessary (when the data is same as the previous one), the data setting of MSB port (φL41) must be executed. - 2. Circuit construction of external prescaler and programmable counter - 1) Circuit construction of pulse swallow dividing mode The circuit is composed of $(1/4 \text{ or } 1/8 \times 1/15, 1/16)$ 2-modulous prescaler TD6134AF and swallow counter of 4 bits and binary programmable counter of 12 bits. In the case of FM band, it selects 1/4 divider to the front stage of 2-modulous prescaler, and in VHF band, it selects 1/8 divider to the front stage of 2-modulous prescaler. The block diagram including prescaler is shown as follows. 2) Circuit construction of direct dividing mode In this case, it is unnecessary to use the external prescaler, 12 bits programmable counter is only used. (Note) Both ${\sf FM_{IN}}$ and ${\sf AM_{IN}}$ have built-in amplifiers, and the small amplitude operation is possible through the capacitor coupling. ## O Reference frequency divider This block divides oscillating frequency of external 75kHz crystal, and produces seven kinds of PLL reference signal, 1kHz, 3kHz, 3.125kHz, 5kHz, 6.25kHz, 12.5kHz, 25kHz. Selection of reference signal is carried out with the data of REF select port. The selected signal is supplied to the phase comparator as the reference frequency. ## 1. REF select port ( $\phi$ L10) This is an internal port to select seven kinds of reference frequency signal. Normally, this port is made access by PLL instruction designated the operand part $[C_N = 0]$ ( $\phi$ L10). ## O Phase comparator The phase comparator outputs the error amount comparing the phase difference between the reference frequency signal supplied from the reference frequency divider and the programmable counter dividing output. VCO is controlled through low-pass filter so that the frequencies and the phase-difference of these two signals may coincide. Since two tri-state buffer DO1 and DO2 terminals are parallel output from the phase comparator, the filter constant can be optimumly designed for each band of FM / VHF and AM. DO Output Timing Chart Example of Active LOW-PASS Filter Circuit (for reference) DO output timing chart and example of active low-pass filter circuit structured by darlington connection of FET and transistor are shown in the above figures. The filter circuit shown in the above figure is an example for reference, and the actual circuit should be investigated and designed conforming to the system band construction and the required characteristics. ## $\bigcirc$ Unlock detection bit ( $\phi$ LK16) This is the bit for detecting the locked state of PLL system. When PLL system is unlocked state, namely, in the state in which the reference signal and the dividing frequency of programmable counter do not coincide, the pulse is output from the phase comparator to the unlock F/F with the cycle of the reference frequency. By this pulse, the unlock F/F is set. At every time when the unlock-reset bit is set to "1" by PLL output instruction designated the operand part $[C_N = 6]$ , the unlock F/F is reset ( $\phi$ L16). After the unlock F/F is reset, the locked condition can be detected by access the unlock detection bit with PLL input instruction ( $\phi$ K16). Since the pulse is input with the cycle of the reference frequency, after the unlock F/F is reset, it is necessary to make access the unlock detection bit after the time exceeding the cycle of the reference frequency. If the time is shorter than the cycle, the correct locked condition can not be detected. So the test enable F/F is prepared. Every time when the unlock reset bit is set to "1", the test enable F/F is reset and set to "1" with the unlock detection timing. In short, it is able to detect the unlock condition correctly at "1" state of the test enable bit ( $\phi$ K16). #### O General IF counter 16 bits general IF counter is able to detect the auto-stop signal with counting intermediate frequency (IF) of FM or AM band at auto-tuning mode. The general IF counter is available for auto tuning function of IF counting type easily in combination with TA8132F, a AM/FM IF+MPX IC corresponding to DTS. IF counter block is composed of 16 bits binary counter and the port for IF counter control. 1. IF counter data port ( $\phi$ K11~ $\phi$ K15) This is the data input port for input the counted data of IF counter and operating condition. The data is read into data memory by PLL input instruction designated the operand part $[C_N = 1 \sim 5]$ . The counted data of IF counter is inputted with binary from the input port, F0~F15. This is the input port for detecting operation condition of IF counter ( $\phi$ K15). In case of using IF counter, the counted data (F0~F15) should be calculated after confirming "0" of BUSY bit (end of IF counting) and OVFLOW bit (not overflow condition). #### 2. IF counter control port ( $\phi$ L15) This is the data output port controlled for IF counter operation. This port is made access by PLL output instruction designated the operand part $[C_N = 5]$ . At the auto mode (MANUAL bit is set to "0"), the $STA/\overline{STP}$ bit is set to "1" every time, IF counter starts. IF counter counts during the gate time selected by #0, #1 bits, and it ends automatically. At manual mode, when the STA/STP bit is set to "1", IF counter counts continuously until the STA/STP bit is set to "0". (Note) At $\overline{INH} = "0"$ , IF counter is reset by compulsorily. ## 3. Circuit construction of IF counter IF counter is composed of input Amp., gate-time control circuit, 16 bits binary counter. At AM band AM IF signal is input to IF $_{\rm IN}$ (TC9308AF Pin 41) from TA8132AF directly, at FM/VHF band 1/8 divided output of FM/VHF IF signal is input to IF $_{\rm IN}$ . (Note) IF<sub>IN</sub> terminal has built-in amplifier, and the small amplitude operation is possible through the capacitor coupling. (Note) If it is used without TA8132AF, 1/8 divided IF signal should be input to IF<sub>IN</sub> (TC9308AF Pin 41) at FM/VHF band. At AM band, IF signal is input directly. ## O LCD driver The TC9308AF contains LCD driver of 1/2 duty and 1/2 bias driving (frame frequency = 100Hz). Two common terminals (COM1, COM2) output three potentials of voltage, $V_{DD}$ , $V_{EE}$ , $V_{LCD}$ level respectively with 1/4 phase difference. 40 segments can be displayed by the combination of these common outputs and 20 segment outputs (\$1~\$20). That is to say, both COM1 system segment and COM2 system segment can be displayed by one segment output, what is called dynamic display method. LCD driver does not contain segment decoder, so 40 segments can be freely used by program for 7-segment display or mark segment display. COM1 system segment output is controlled by execution of SEG instruction and COM2 system segment output is by execution of MARK instruction. #### 1. Timing chart of LCD driver Below are shown the timing chart of COM1, COM2 output wave form and four kinds of segment output wave form. (Note) During system reset and back up mode (CKSTP instruction executing), common output and segment output are all fixed at "L" lavel automatically. #### 2. COM1 system segment port (\$\phi\$L20\$\sigma\$\phi\$L24) This is a port group to output 20 segment data of COM1 system. It is made access by SEG output instruction. Segment data is treated with 4 bits unit, and COM1 system segment turns "ON" when data "1" is output, while COM1 system segment turns "OFF" when data "0" is output. 1999-03-19 31/46 #### 3. COM2 system segment port ( $\phi L30 \sim \phi 34$ ) This is a port group to output 20 segment data of COM2 system. It is made access by MARK output instruction. Segment data is treated with 4 bits unit, and COM2 system turns "ON" when data "1" is output, while COM2 system segment turns "OFF" when data "0" is output. #### DISP OFF bit (φL35) This bit controls turning on or off of LC display. When data "1" is set to this bit, common outputs and segment outputs are all fixed at "L" level, all display becomes turned off. When data "0" is set to this bit, display becomes normal action. And this bit is reset to "0" after system reset. - (Note) The name of each port of COM1 system and COM2 system corresponds to the name of segment output terminal, respectively. And as the content of each port don't accept DISP OFF bit's influence, even display off made by DISP OFF bit, it is able to output the data to each segment port normally. - (Note) Decoding of segment can be made by providing the segment decode pattern in the program memory and reading it into the data memory by using DAL instruction. Therefore LCD driver doesn't have built-in segment decoder especially. As DAL instruction refers to the data in the program memory with 16 bits unit, assignment of segment port appropriated to the made 7-segment display is continuously performed with 8 bits unit (7-segment + 1 mark) for example port \$1~\$4, port \$5~\$8 both COM1 system and COM2 system in common. #### 4. Voltage boosting circuit for LC display TC9308AF has built-in voltage boosting circuit for LC display, it is able to stabilize LC display driving at the low voltage operation. This circuit is composed with 1.5V reference voltage circuit (V<sub>EE</sub>) and voltage double boosting circuit (V<sub>LCD</sub>), be connected the boosting capacitor as follows. Be connected the register for improving the motive characteristics of voltage boosting circuit. - O Input and output port - 1. I/O port IO0~IO3 (φKL41) I/O port is 4 bits CMOS type, and is capable of making input and output setting with each bit. Input and output setting of I/O port is made by the content of I/O control internal port. Setting to input port can be made by setting "0" to the bit of I/O control port corresponding to I/O port, while setting to output port can be made by setting "1" in the same. In case of input port setting, the present data input I/O port is read into the data memory by the execution of IO input instruction designated the operand part [ $C_N = 1$ ] ( $\phi$ K41). At this time, input data is set to output latch of I/O port ( $\phi$ L41) in the same. In case of output port setting, output condition of I/O port is controlled execution of IO output instruction designated the operand part $[C_N = 1]$ . And the present output data of I/O port is read into the data memory by the execution of IO input instruction ( $\phi$ K41). - (Note) I/O control port is made access by KEY instruction designated the operand part $[C_N = 1]$ . After system reset, the content of this port is all reset to "0", and I/O port is all set up input mode. - (Note) During the clock stop mode (executing CKSTP instruction), output condition of I/O port set at output mode is all fixed at "L" level automatically, but each output latch holds on the data just before the clock stop mode. - (Note) At the time of changing input condition of I/O port set at input mode, it cancels the execution of WAIT and CKSTP instructions and makes the operation restart. In case of setting "1" to I/O-bit of MUTE control port, MUTE port is made to set to "1" compulsorily by the same condition. 2. General input port IN0~IN3 (φK43) IN0 $\sim$ IN3 is input port of 4 bits, CMOS type. By the execution of IO input instruction designated the operand part [C<sub>N</sub> = 3], input data is read into the data memory. The data is input with positive logic. | | Y1 | Y2 | Y4 | Y8 | |------|-----|-----|-----|-----| | φK43 | IN0 | IN1 | IN2 | IN3 | 3. General output port OT0, OT1 ( $\phi$ L42) OTO and OT1 are output port of 2 bits, N-ch FET open-drain structure. It is made access by the execution of IO output instruction designated the operand part $[C_N = 2]$ ( $\phi$ L42). When this port is set to "1", the N-ch transistor turns on, so output becomes "L" level. When this port is set to "0", the N-ch transistor turns off, output becomes high impedance. To make the output "H" level, be connected pull-up resistor. Then output can drive the voltage of 0~12V. (Note) During the clock stop mode (executing CKSTP instruction), OT0, OT1 output is off condition automatically, but the content of port is held on the previous data. | | Y1 | Y2 | Y4 | Y8 | |------|-----|-----|----|----| | φL42 | ОТ0 | OT1 | * | * | 4. Key timing output port T0 $\sim$ T3 ( $\phi$ L46) T0~T3 is exclusive output port of 4 bits, CMOS type. Normally, it is used as output of key return timing signal for key matrix. So, the resistor is built-in at Nch transistor side and sink current is decreased. Therefore, of using push key, the diode can be omitted on the key matrix. Output port is made access by IO output instruction designated the operand part [ $C_N = 6$ ] ( $\phi$ L46). In case of using for normal output port, take care to make the external circuit because of output impedance of "L" level increased. (Note) During the clock stop mode (executing CKSTP instruction), T0~T3 output is fixed at "L" level automatically, but the content of port is held on the previous data. ## 5. MUTE port ( $\phi$ KL40) This is a 1bit CMOS type exclusive output for muting control. Normally, it is made access by IO output instruction designated operand part $[C_N = 0]$ ( $\phi$ L40). Further, by the execution of IO input instruction designated operand part $[C_N = 0]$ , content of present output data is read into data memory ( $\phi$ K40). And according to the data of MUTE control port ( $\phi$ L50), MUTE port is controlled. #### • INH Bit In case of setting "1" to this bit, MUTE port is set to "1" compulsorily by changing of $\overline{\text{INH}}$ input level ("L" $\rightarrow$ "H" or "H" $\rightarrow$ "L"). #### • 1/0 Bit In case of setting "1" to this bit, MUTE port is set to "L" compulsorily by input level changing of I/O port set at input mode. #### • POL Bit The bit controls output polarity of MUTE port. In case of setting "0" to this bit, the data of MUTE port is output with positive logic. In case of setting "1" to the bit, the data of MUTE port is output with negative logic. (Note) After system reset, the content of INH, I/O, POL each bit is reset to "0". ## O Buzzer port Buzzer output is available as beep sound for confirmation of key operation, and as alarm sound. It uses as 1bit general output port. The buzzer output condition is controlled by buzzer control port ( $\phi$ L43) as follows. Buzzer control port is made access by IO output instruction designated the operand part [C<sub>N</sub> = 3]. Selection Bits of Buzzer Port Output Mode | #2 | #3 | BUZZER OUTPUT MO | DE | |-----------------|-------|-------------------------------------------------------|----------| | 0 | 0 | Single Output | (Mode A) | | 1 | 0 | Continuous Output | (Mode B) | | $\lceil \rceil$ | 1 | Continuous Output for 100ms (At intervals of 50ms) | Period | | l۳ | ' | (At intervals of 50ms) | (Mode C) | | 1 | 1 | Continuous Output for 100ms and At intervals of 500ms | Period | | ' | ' ' | and At intervals of 500ms | (Mode D) | Selection Bits of Buzzer Frequency | #0 | #1 | BUZZER FREQUENCY [kHz] | |----|----|------------------------| | 0 | 0 | Don't use | | 1 | 0 | 1 | | 0 | 1 | 1.5 | | 1 | 1 | 3 | (Note) In case of using buzzer port as general output port, the following data is set to buzzer control port. | #0 | #1 | #2 | #3 | OUTPUT CONDITION OF BUZZER PORT | |----|----|----|----|---------------------------------| | 0 | 0 | 0 | 0 | L | | 0 | 0 | 1 | 0 | Н | (Note) In case of setting all "0" to the buzzer control port and of executing CKSTP or WAIT (at P = 1H) instruction, buzzer output is reset. (Note) In case of using as general output port, output is fixed at "L" level by executing CKSTP instruction, but the content of this port is held on. Below are shown the timing chart of buzzer signal output and buzzer frequency wave form. ## O Register port G-register and data register stated in the explanation of CPU are also treated as one of internal ports. #### 1. G-register ( $\phi$ L44) This is a register to make addressing of low address ( $D_R = 4H \sim 7H$ ) of data memory during the execution of MVGD instruction and MVGS instruction. This register is made access by IO output instruction designated the operand part [ $C_N = 4$ ]. (Note) Content of this register is effective only during the execution of MVGD instruction and MVGS instruction, and gives no effect during the execution of other instructions. (NOTE) It is possible to indirectly designate all low address of data memory by setting data 0H $\sim$ 7H on G-register. (D<sub>R</sub> = 0H $\sim$ 7H) #### 2. Data register ( $\phi$ K54~ $\phi$ K57) This is 16bit register on which the data of program memory is loaded by the execution of DAL instruction. Content of this register is read into the data memory in 4bit unit by the execution of KEY input instruction designated the operand part $[C_N = 4 \sim 7]$ . This register is available for the decoding of LCD segment, or for the taking of band edge data of radio and coefficient data during binary to BCD conversion. ## O Key input Exclusive 4 bits key input terminal for key matrix data input is provided. Four terminals contain pulldown resistors. ## 1. Key input port ( $\phi$ K52) This is exclusive key input port of 4 bits, the data of key input terminal is read into the data memory by the execution of KEY input instruction designated part $[C_N = 2]$ . ## 2. Key status bit ( $\phi$ K45) Key status bit (KEY ON) is provided for purpose of knowing the outline of present key input status. Content of this bit is read into data memory by execution of IO instruction designated operand part $[C_N = 5]$ . #### KEY ON bit Logical OR of four input data of $K0\sim K3$ terminals is output. This is available for judging existance of key input. When KEY ON bit is "1" (In case of inputting "H" level to key input terminal $K0\sim K3$ ), it releases execution of WAIT instruction, the operation is removed. ## O Internal control port Internal control port is used for reading into data memory the inside condition of device which must be known in the execution of program, or for resetting the inside condition of device. ## 1. $\overline{\text{INH}}$ input port ( $\phi$ K44) This is an input port for inputting the data of $\overline{\text{INH}}$ input terminal. Content of this port is read into the data memory by IO instruction designated the operand part [C<sub>N</sub> = 4]. Data "1" and "0" represent radio "ON" mode and "OFF" mode, respectively. At radio off mode, it stops operating of PLL and IF counter block. When $\overline{\text{INH}}$ bit of MUTE control port is "1", MUTE port is set to "1" compulsorily by changing the data of $\overline{\text{INH}}$ input port. At $\overline{\text{INH}}$ input port is "1", it releases execution of CKSTP instruction and the operation is removed. By changing the condition of $\overline{\text{INH}}$ input port, execution of WAIT instruction is released. ## 2. 2Hz timer F/F ( $\phi$ K45) 2Hz timer F/F is set by 2Hz (500ms) signal. With the execution of IO output instruction designated the operand part [ $C_N = 5$ ] this timer is reset by setting data "1" to 2Hz F/F RESET bit. This F/F output is read into the data memory by execution of IO input instruction designated the operand part [ $C_N = 5$ ]. As 2Hz timer F/F is automatically set every 500ms, it is usually available for counting of clock. Since 2Hz timer F/F is reset only by 2Hz F/F RESET bit, count error takes place unless data "1" is set to 2Hz F/F RESET bit within 500ms period, and correct times is not obtainable. (Note) Condition of 2Hz timer F/F output becomes "0" at power on reset or after execution of CKSTP instruction. #### 3. 10Hz interval pulse ( $\phi$ K45) 10Hz interval pulse is output to 10Hz bit with 100ms period, duty 50% pulse. This is read into the data memory by the execution of IO input instruction designated the operand part $[C_N = 5]$ . This output has no flip flop and is available for mute time counting etc. ### 4. Other control bit ( $\phi$ L45) #### • CLOCK RESET bit Every time data "1" is set to this bit, clock of under 50Hz is reset (10Hz interval pulse is also reset). This bit is used for adjusting time of clock. Accuracy of clock at this time is -0, +0.02 second. #### 5. TEST port ( $\phi$ L57) This is an internal port for testing function of device. It is made access by KEY output instruction designated the operand part $[C_N = 7]$ . Never fail to set data "0" in ordinary program. ## O Application to evaluator chip When "H" level is supplied to TEST terminal (Test mode), device operates as evaluator chip, and functional evaluation of developing program can be made by utilizing external simulation board and EPROM. In the test mode, the device operates with the program written in EPROM, irrespective of the content of program memory in the device. As key timing output port (T0~T3) and output port (OT0, OT1) are transferred to the input and output terminal for control of simulation board at this time, actual T0~T3 and OT0, OT1 port signal are output from the simulation board side. Below is shown connection diagram of the device and simulation board in case that it is used as evaluator chip. - (Note) Supply $3V \pm 10\%$ voltage to the device and $5V \pm 10\%$ voltage to the simulation board even during back-up mode. - (Note) Each terminal of the device except that shown above can be used normally. - (Note) In case of back-up mode (execution of CKSTP instruction), operating monitor LED on the simulation board turns off. ## **MAXIMUM RATINGS** (Ta = $25^{\circ}$ C) | CHARACTERISTIC | SYMBOL | RATING | UNIT | |----------------------------------------|------------------|---------------------------|------| | Power Supply Voltage | $V_{DD}$ | -0.3~4.0 | V | | Input Voltage | VIN | -0.3~V <sub>DD</sub> +0.3 | ٧ | | Power Dissipation | PD | 100 | mW | | Operating Temperature | T <sub>opr</sub> | - 10~60 | °C | | Storage Temperature | T <sub>stg</sub> | <b>-</b> 55∼125 | °C | | Open Drain Output<br>Breakdown Voltage | V <sub>BDS</sub> | 12 | ٧ | # **ELECTRICAL CHARACTERISTICS** (Unless otherwise specified, Ta = 25°C, $V_{DD} = 3.0$ V) | CHARACTERISTIC | SYMBOL | TEST<br>CIR-<br>CUIT | TEST CONDITION | MIN. | TYP. | MAX. | UNIT | |-----------------------------------------|------------------|----------------------|--------------------------------------------------------|------|------|------|---------| | Operating Power Supply<br>Voltage Range | V <sub>DD</sub> | _ | * | 1.8 | 3.0 | 3.6 | ٧ | | Memory Holding Voltage<br>Range | V <sub>HD</sub> | _ | Crystal oscillation stops (Excuting CKSTP instruction) | 1.2 | ~ | 3.6 | V | | | l <sub>DD1</sub> | _ | Normal operation, output<br>No-load | _ | 0.7 | 2.0 | mA | | Operating Power Supply<br>Current | l <sub>DD2</sub> | _ | At only CPU operation (Radio off, lighting display) | _ | 75 | 150 | | | | l <sub>DD3</sub> | _ | At stand-by mode (Radio off, only crystal oscillation) | _ | 50 | 100 | $\mu$ A | | Memory Holding Power<br>Supply Current | IHD | _ | Crystal oscillation stop (Excuting CKSTP instruction) | _ | 0.1 | 1.0 | | | Crystal Oscillation<br>Frequency | fxT | _ | * | _ | 75 | _ | kHz | | Crystal Oscillation Starting<br>Time | t <sub>ST</sub> | _ | Crystal oscillation = 75kHz | _ | _ | 1.0 | s | #### VOLTAGE DOUBLE BOOSTING CIRCUIT | Voltage Double Reference<br>Voltage | V <sub>EE</sub> | _ | V <sub>DD</sub> reference | 1.2 | 1.5 | 1.8 | V | |-------------------------------------|-----------------|---|---------------------------|-----|-----|-----|---| | Voltage Double Boosting<br>Voltage | $V_{LCD}$ | _ | V <sub>DD</sub> reference | 2.4 | 3.0 | 3.6 | V | % Marked items are guaranteed by all conditions of $V_{DD} = 1.8 \sim 3.6 V$ , $T_0 = -10 \sim 60 ^{\circ} C$ | CHARAG | CTERISTIC | SYMBOL | TEST<br>CIR-<br>CUIT | TEST CONDITION | | MIN. | MIN. TYP. MAX. | | UNIT | |------------------------------------|-------------------------|------------------|----------------------|-------------------------------------------------------------------------------|---|-------|----------------|-----------------------|------------------| | PROGRAMM | IABLE COUNT | ER, IF CO | UNTEI | ₹ | | | | | | | Operating I | Frequency | fIN1 | _ | $V_{\text{IN}} = 0.3V_{\text{p-p}}$<br>(FM <sub>IN</sub> , AM <sub>IN</sub> ) | * | 0.5 | ~ | 25 | MHz | | Range | | f <sub>IN2</sub> | _ | $V_{IN} = 0.3V_{p-p}$<br>(IF <sub>IN</sub> ) | * | 0.35 | ~ | 20 | IVITIZ | | Operating Input<br>Amplitude Range | | V <sub>IN1</sub> | l | $f_{IN} = 0.5 \sim 2.5 MHz$<br>(FM <sub>IN</sub> , AM <sub>IN</sub> ) | * | 0.3 | ? | V <sub>DD</sub> – 0.3 | V | | | | V <sub>IN2</sub> | | f <sub>IN</sub> = 0.35~2.0MHz<br>(IF <sub>IN</sub> ) | * | 0.3 | ? | V <sub>DD</sub> – 0.3 | V <sub>p-p</sub> | | Delay Time | | | l | $V_{IN} = 0.3V_{p-p}$<br>$C_L = 15pF (FM_{IN})$ | * | l | l | 400 | ns | | PSC Maximodel<br>Capacity | SC Maximum Load apacity | | _ | (PSC) | * | - | - | 15 | pF | | LCD COMM | ON OUTPUT | | | | | | | | | | Output | "H" Level | <sup>1</sup> ОН1 | _ | $V_{LCD} = 0V, V_{OH} = 2.7V$ (COM1, 2) | | - 100 | - 200 | _ | ۸ | | Current | "L" Level | lOL1 | | $V_{LCD} = 0V, V_{OL} = 0.3V$ (COM1, 2) | | 100 | 200 | _ | μΑ | | LCD SEGME | NT OUTPUT | | | | | | | | | | Output | "H" Level | I <sub>OH2</sub> | _ | $V_{LCD} = 0V, V_{OH} = 2.7V$<br>(\$1~\$20) | | - 50 | - 100 | _ | 0 | | Current | "L" Level | lOL2 | _ | $V_{LCD} = 0V, V_{OL} = 0.3V$ (\$1~\$20) | | 50 | 100 | _ | $\mu$ A | | KEY RETURN | OUTPUT PO | RT | | | | | | | | | Output<br>Current | "H" Level | l <sub>ОН3</sub> | _ | V <sub>OH</sub> = 2.7V (T0∼T3) | | - 0.5 | - 1.0 | _ | mA | | N-ch FET Si<br>Resistance | de Load | RON | _ | V <sub>OL</sub> = 3.0V (T0~T3) | | 37 | 70 | 140 | kΩ | | MUTE, BUZF | R, PSC OUTPU | Т | | | | | | | | | Output | "H" Level | I <sub>OH4</sub> | _ | V <sub>OH</sub> = 2.7V | | - 300 | - 600 | _ | μΑ | | Current | "L" Level | l <sub>OL4</sub> | _ | V <sub>OL</sub> = 0.3V | | 300 | 600 | _ | μ <b>^</b> | | | JRPOSE OUTP | UT PORT | | | | | | | | | Output<br>Current | "L" Level | lOL4 | _ | V <sub>OL</sub> = 0.3V (OT0, OT1) | | 300 | 600 | _ | μΑ | | Output Off-<br>Current | -Leakage | I <sub>LDS</sub> | _ | V <sub>DS</sub> = 12V (OT0, OT1) | | _ | _ | 1.0 | $\mu$ | <sup>%</sup> Marked items are guaranteed by all conditions of $V_{DD} = 1.8 \sim 3.6 V$ , $T_{a} = -10 \sim 60 ^{\circ} C$ | CHARA | CTERISTIC | SYMBOL | TEST<br>CIR-<br>CUIT | TEST CONDITION | MIN. | TYP. | MAX. | UNIT | | |--------------------------------------------|--------------------------|--------------------------------------|----------------------|------------------------------------------------|-------|-------|-------|---------------|--| | DO1, 2 OUT | ГРИТ | | | | | | | | | | Output | "H" Level | IOH4 | _ | V <sub>OH</sub> = 2.7V | - 300 | - 600 | _ | | | | Current | "L" Level | lOL4 | _ | V <sub>OL</sub> = 0.3V | 300 | 600 | _ | $\mu$ A | | | Output Off<br>Current | f-Leakage | l <sub>TL</sub> | _ | V <sub>TLH</sub> = 3.0V, V <sub>TLL</sub> = 0V | _ | ı | ± 100 | nA | | | GENERAL PL | GENERAL PURPOSE I/O PORT | | | | | | | | | | Output | "H" Level | IOH4 | _ | V <sub>OH</sub> = 2.7V (IO0~IO3) | - 300 | - 600 | | | | | Current | "L" Level | lOL4 | _ | $V_{OL} = 0.3V (IO0 \sim IO3)$ | 300 | 600 | | $\mu$ A | | | Input Leaka | age Current | ILI | _ | $V_{IH} = 3.0V, V_{IL} = 0V$ | _ | | ± 1.0 | | | | Input | "H" Level | V <sub>IH1</sub> | _ | (IO0~IO3) | 2.4 | ~ | 3.0 | ٧ | | | Voltage | "L" Level | V <sub>IL1</sub> | _ | (IO0~IO3) | 0 | ~ | 0.6 | ٧ | | | | GENERAL PUR | POSE INPUT | PORT | - | | | | | | | Input Leaka | age Current | ILI | _ | $V_{IH} = 3.0V$ , $V_{IL} = 0V$ | _ | _ | ± 1.0 | $\mu$ A | | | Input | "H" Level | V <sub>IH2</sub> | _ | (INT, IN0~IN3) | 2.4 | ~ | 3.0 | V | | | Voltage | "L" Level | V <sub>IL2</sub> | _ | (INT, IN0~IN3) | 0 | ~ | 0.6 | V | | | KEY INPUT | PORT | | | | | | | | | | Input Pull-o<br>Resistance | down | R <sub>IN1</sub> | _ | (K0~K3) | 80 | 140 | 280 | $\mathbf{k}Ω$ | | | Input | "H" Level | V <sub>IH3</sub> | _ | (K0~K3) | 2.1 | ~ | 3.0 | V | | | Voltage | "L" Level | V <sub>IL3</sub> | _ | (K0~K3) | 0 | ~ | 0.6 | V | | | INH INPUT F | | | | | | | | | | | Input Look | age Current | ILI | _ | $V_{IH} = 3.0V, V_{IL} = 0V$ | | | ± 1.0 | $\mu$ A | | | прит сеака | | | | | | ~ | 2.0 | | | | Input | "H" Level | V <sub>IH4</sub> | _ | _ | 2.6 | ~ | 3.0 | W | | | | "H" Level | V <sub>IH4</sub><br>V <sub>IL4</sub> | _ | | 0 | ~ | 1.2 | ٧ | | | Input<br>Voltage<br>OTHERS | "L" Level | | _ | | | | | V | | | Input<br>Voltage | "L" Level | | | (TEST) | | | | V | | | Input<br>Voltage<br>OTHERS<br>Input Pull-o | "L" Level | V <sub>IL4</sub> | | $(TEST)$ $(X_T-\overline{X_T})$ | 0 | ~ | 1.2 | | | ## **EXAMPLE FOR CONNECT WITH PRESCALER TD6134AF** ## OUTLINE DRAWING QFP60-P-1414-0.80A Unit: mm Weight: 0.85g (Typ.)