# LOW VOLTAGE SINGLE-CHIP MICROCOMPUTER WITH BUILT-IN PRESCALER PLL FREQUENCY SYNTHESIZER AND LCD DRIVER #### DESCRIPTION The $\mu$ PD1715 is a 1-chip digital tuning 4-bit CMOS microcomputer that includes a prescaler operative up to 130 MHz, a PLL frequency synthesizer, and an LCD driver (1/3 duty, 1/2 bias). The CPU includes 4-bit parallel add and subtract functions (AD, SU, etc.), logical operations (EXL, etc.), a multi-bit test function (TMT, etc.), carry F/F set and reset functions (STC, etc.), and a timer function. The µPD1715 is manufactured in a 52-pin flat package provided with various ports. These ports include a 4-bit input/output (I/O) port controlled by input/output instructions (IN, OUT, etc.), a 1 kHz/3 kHz modulated signal output port for alarms, a variable duty port (VDP) available as a simplified D/A converter, an input port dedicated to key switch inputs, and others. #### **FEATURES** - · Digital tuning 4-bit microcomputer - Integrated prescaler (fixed 1/2 divider or 1/4 divider + two modulus prescaler: MAX. 130 MHz) - 2.0 to 3.6 V single power source (when PLL operation) - CMOS with low power requirement (maximum 30 μA when only CPU is resonator) - Easy data memory (RAM) backup (via CE pin) - Program memory (ROM): 16 bits x 1528 steps - · Data memory (RAM): 4 bits x 96 words - 76 powerful instructions (each occupying one word) - Instruction execution time of 40 us (when connected to 75 kHz crystal resonator) - Versatile add and subtract instructions (12 add and subtract instructions, respectively) - Strong composite judge instructions (TMT ← TMF, etc.) - Storage-to-storage data transfer possible in the same row address - Indirect register transfer (MVRD, MVRS, etc.) - 16 useful general registers (in the RAM space) - Stack level: 1 level - Integrated LCD driver (1/3 duty, 1/2 bias, driven with 3.1 V, frame frequency: 100 Hz) - Integrated Programmable Logic Array (PLA) to display LCD patterns. - Clock can be stopped with an instruction (CKSTP). - 14 powerful I/O ports (PA<sub>3</sub> to PA<sub>0</sub>; Available for bit-unit input/output; PB<sub>3</sub> to PB<sub>0</sub>, PC<sub>3</sub> to PC<sub>0</sub>, VDP, CGP: Dedicated to output) - Input ports K<sub>3</sub> to K<sub>0</sub> dedicated to key inputs - Output ports LCD<sub>9</sub> to LCD<sub>16</sub> dedicated to key source - 1 kHz or 3 kHz modulated signal output port (CGP) - Variable Duty Port (VDP) available as a simplified D/A converter - Powerful I/O instructions (IN and OUT instructions) - Input and output port states can be tested with TPT and TPF instructions. - Integrated timer F/F (to be set at 125 ms intervals. The timer function can be easily executed.) - Integrated interval pulse output (internal output): 200 Hz, duty 60 %, output at 5 ms intervals, can be tested with TIP instruction. - PLL lock state can be tested with TUL instruction. - Dividing factor, dividing method, and reference frequency data can be transferred to the PLL section with a PLL instruction. - The AM and FM frequency input pins are provided separately (maximum input frequencies: 40 MHz for VCOL pin in HF mode and 130 MHz for VCOH pin in VHF mode). - Pulse swallowing method and direct dividing method can be selected by the program (VHF, HF, and MF modes). - Two independent error outputs (EO<sub>1</sub> and EO<sub>2</sub> pins) - Six reference frequencies can be selected by the program (1, 3, 5, 6.25, 12.5, and 25 kHz). # ORDERING INFORMATION | Order Code | Package | |-----------------|-----------------------------------------| | μPD1715G-XXX-22 | 54-pin plastic QFP | | μPD1715G-XXX-21 | 54-pin plastic QFP (Straight lead type) | | μPD1715G-XXX-24 | 54-pin plastic QFP (Reverse bent type) | # PIN CONFIGURATION (Top View) This pin is internally connected to Pin 20. NC No connection. # PIN DESCRIPTION | PIN NO. | SYMBOL | NAME | DESCRIPTION | OUTPUT<br>TYPE | |----------------------|------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 14<br>15<br>16<br>17 | VSS3<br>CAP2<br>CAP1<br>VSS2 | Doubler<br>Capacitor<br>Connecting<br>Pin | Used to connect the capacitors for the doubler circuit to generate the LCD drive voltage (3.1 V TYP.). Connect them as follows: 0.1 \( \mu \times \cdot 2 \\ 0.01 \\ \mu \times \cdot \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ \times \cdot 0.01 \\ \mu \times \cdot 2 \\ | _ | | 18 | VDP | Variable Duty Port Output | Variable duty port or 1-bit output port (Port G <sub>2</sub> ). The port specification can be selected by the program. When used as the VDP, 1.12 kHz pulses are output successively. The pulse duty cycle can be changed: $64 \text{ steps as follows:}$ $\left(\text{duty} = \frac{26.7 \ \mu \text{s}}{893 \ \mu \text{s}} \text{ to } \frac{967 \ \mu \text{s}}{893 \ \mu \text{s}}\right)$ $= \frac{2}{67} \text{ to } \frac{5}{67}$ It can be used as a D/A converter by adding an integration circuit. | CMOS<br>Push-pull | | 19 | CGP | Clock<br>Generator<br>Output | Clock generator port or 1-bit output port {Port D3}. The port specification can be selected by the program. When used as the CGP, 1 kHz (duty 46.6 %) or 3 kHz (duty 60 %) pulses can be output successively. {See Note 2} | CMOS<br>Push-pull | | 20<br>46 | V <sub>DD</sub> | Power<br>Supply | Power source pin of the device for supplying 2.0 V to 3.5 V during PLL operation and for supplying 1.7 V to 3.6 V during CPU operation only. The voltage can be reduced up to 1.5 V for holding the internal data memory (IRAM) by executing a CKSTP instruction. When the potential of this pin is changed from 0 V to 1.7 V, the power-on reset circuit of the device is activated, thereby starting the program from address 0. Note: Since pins 20 and 46 are connected in the chip, the voltage need not be supplied to both pins. The device operates with only one of these pins supplied with voltage. Note that pin 46 is not connected (NC: No Connection) for the engineering sample product (ceramic package). | - | | 21 | м | Dividing Ratio Switching Control Signal Input | This pin is used to switch the dividing ratio of the dividing prescaler. When the VCOH pin is used, the dividing prescaler is used. When M pin is set to High level, then the frequency is divided by the 1/4 divider. Also, when M pin is set to low level, then the frequency is divided by the 1/2 divider. | Input | | PIN NO. | SYMBOL | NAME | | DESCRIPT | TION | | OUTPUT<br>TYPE | |----------|------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------| | 22 | vсон | VCO (High)<br>Signal<br>Input | This pin is used to input the 10 MHz to 130 MHz (M pin = High, 0.1 V <sub>D-D</sub> MIN.) or the 10 MHz to 100 MHz (M pin = Low, 0.1 V <sub>D-D</sub> MIN.) local oscillation output (VCO) and is internally connected to the programmable counter via the fixed 1/2 or 1/4 divider prescaler and 1/32 and 1/33 two-modulus prescaler. If an HF instruction is executed in the direct dividing or pulse swallowing method, or in other words, if the VCOL pin is selected, the VCOH pin is set to the pull-down state (GND). Since an AC amplifier is included, the pertinent component must be suppressed with a capacitor before the signal is input. | | | Input | | | | | | This pin is used to input ocal oscillation output this pin is selected when direct dividing or pulse. Note that the different ranges are used in these | t (VCO).<br>en an HF inst<br>swallowing r<br>frequency u | ruction is execunethod. | Ited in the | | | | V00: | VCO (Low) | Dividing method | voltage<br>(min.) | Input<br>frequency | Dividing<br>factor | Input | | 23 | VCOL | Signal<br>Input | Direct dividing | 0.1 V <sub>p-p</sub> | 0.5 to 15 MHz | 16 to (2 <sup>12</sup> ~ 1) | | | | | į | Pulse Swallowing [HF instruction execution] | 0.2 V <sub>p-p</sub> | 0.5 to 40 MHz | 1024 to (2 <sup>17</sup> – 1) | | | | <br> <br> -<br> -<br> - | <br> | When a VHF instruction method, which means pin is set to the pull-do Since an AC amplifier be suppressed with a c. | that the VCC<br>own state (GN<br>is included, th | IH pin is selecte<br>(D).<br>ne pertinent cor | d, the VCOL | | | 24 | V <sub>SS1</sub> | Ground | Ground pin of the dev | ce | | | | | 25<br>26 | EO <sub>1</sub><br>EO <sub>2</sub> | Error<br>Output | PLL error output pins. local oscillation freque ence frequency, high-le is lower than the refere The floating state is se other. These outputs a (LPF), then they are ay weveform is output fro select one of these pin When PLL disable (Wh set to low level), EQ1 | ncy (VCO ou<br>evel signals are<br>ence frequence<br>t when the two<br>re delivered to<br>opplied to the<br>opplied the opplied to the<br>opplied to the opplied to the<br>opplied to the opplied to the<br>opplied to the opplied to the<br>opplied to the opplied to the opplied to the<br>opplied to the opplied to the opplied to the opplied to the<br>opplied to the opplied opplie | tput) is higher in a coutput from the coutput from the coutput from the coutput frequencies at the coutput frequencies at the coutput frequencies at the coutput frequencies are floating state of the coutput frequencies are floating state of the coutput frequencies are floating state of the coutput frequencies are floating state of the coutput frequencies are floating state of the coutput frequencies are floating state of the coutput frequency | than the refer-<br>hese pins. If it<br>hals are output.<br>re equal to each<br>w-pass filter<br>Since the same<br>hay arbitrarily | CMOS<br>3-states | | 27 | CE | Chip Enable | Select signal input pin Set CE to the high leve Set CE to the low level the PLL section is unc- signal less than 140 µs If a CKSTP instruction CE pin is at the low level equivalent to NOP who and CPU stop their op can be set with the low | If to operate to the conditionally of the conditionally of the conditionally of the conditional to condi | the device in the<br>es. If this pin is<br>disabled. Howeve<br>ed. Howeve<br>ed. Howeve<br>ed. Howeve<br>ed. Howeve<br>ed. Howeve<br>disable in the standard<br>in the internal cithe memory (R. | at the low level, rer, a low-level ed when the CE = Low; it is lock generator AMI hold state | Input | | PIN NO. | SYMBOL | NAME | DESCRIPTION | OUTPUT<br>TYPE | |----------------------|------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------| | 27 | CE | Chip Enable | display outputs (LCD <sub>1</sub> to LCD <sub>16</sub> and COM <sub>1</sub> to COM <sub>3</sub> ) are set to the display off mode (low level). When the CE pin is changed from the low level to the high level, the device is reset and the program is started from address 0. In this case, port A is set to the input mode. | Input | | 28<br>29 | XO<br>XI | X'tal | Crystal resonator connecting pin. Oscillation frequency: 75 kHz. | CMOS (XO)<br>Input (XI) | | 30<br>to<br>33 | PA <sub>3</sub><br>to<br>PA <sub>0</sub> | Port A | 4-bit input/output (I/O) port. The bit-unit I/O specification is possible depending on the data, PAIO word stored at address 1 FH in BANK 0 of the data memory (RAM). This is used unconditionally as the input port when the device is powered, or the clock is stopped, or the CE pin is changed from the low level to the high level (at rise time). (Refer to Note 1 for details.) | CMOS<br>Push-pull<br>(when output | | 34<br>to<br>37 | PB3<br>to<br>PB0 | Port B | 4-bit output dedicated port. Since the sink current is especially reduced due to the device configuration, it can be used as the key return signal source for the key matrix. This means the reverse-current preventive diode can be omitted by using this port as the key return signal source. When used as an ordinary output port, however, the correct low level may not be output because the sink current is insufficient depending on the drive circuits. Connect a pull-down resistor in this case. [See Notes 1 and 2 for details.] | CMOS<br>Push-pull | | 41<br>54 | NC | No<br>Connection | This pin is not connected to the chip internally, that is, the user<br>can arbitrarily connect this pin depending on his particular re-<br>quirements. | _ | | 38<br>to<br>40<br>42 | PC <sub>3</sub><br>to<br>PC <sub>0</sub> | Port C | 4-bit output dedicated port. Since the sink current is especially reduced due to the device configuration, it can be used as the key return signal source for the key matrix. This means the reverse-current preventive diode can be omitted by using this port as the key return signal source. When used as an ordinary output port, however, the correct low level may not be output because the sink current is insufficient depending on the drive circuits. Connect a pull-down resistor in this case. (See Notes 1 and 2 for details.) | CMOS<br>Push-pull | | 43<br>to<br>45<br>47 | K3<br>to<br>K0 | Key-return<br>Signel Input | 4-bit input dedicated port to be ordinarily used as the key matrix input. When a KIN or KI instruction is executed, the states of these pins are read in the data memory (RAMI specified by the operand field. The device configuration allows port C, PB <sub>0</sub> , PB <sub>1</sub> and LCD <sub>9</sub> to LCD <sub>16</sub> to be used especially as the key return signal source. When LCD <sub>9</sub> to LCD <sub>16</sub> are used as the key source, the key source signal is output form these pins at 6.7 ms intervals while it is used for the display. Whether or not the key source signal is output can be determined with a TKLT or TKLF instruction. Therefore, a KI or KIN instruction must be executed after confirming that the key source signal has been output (TKLT or TKLF is exectued). (See Section 6 "KEY INPUT PROCEDURES" for details.) | Input | | PIN NO. | SYMBOL | NAME | DESCRIPTION | OUTPUT<br>TYPE | |---------------------------------|-------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 48<br>to<br>53<br>1<br>to<br>10 | LCD16 to LCD11 LCD10 to LCD1 | LCD<br>Segment<br>Signal Output | Segment signal output pins for the LCD panel. Up to 48 dots can be displayed by forming a matrix with COM <sub>1</sub> to COM <sub>3</sub> . Segment signal is output by the LCDD instruction executed. The LCD drive voltage is 3.1 V TYP, and drives the LCDs with 1/2 bias and 1/3 duty (frame frequency: 100 Hz). LCDg to LCD <sub>16</sub> can be used as the display segment output pins and at the same time as the key source signal pins for the key matrix. These signals are output according to the time division and the key source signals are output at 6.7 ms intervals. Whether or not the key source signal is to be output while the display is taking place can be selected by a program. These pins are automatically set to the low level (display off mode) at power on reset (when V <sub>DD</sub> is changed from the low level to the high level) or when the clock is stopped. The display mode is not changed at reset (when CE is changed from the low level to the high level). | CMOS<br>Push-pull | | 11<br>to<br>13 | COM3<br>to<br>COM1 | LCD<br>Common<br>Signal Output | Common signal output pins for the LCD panel. Up to 48 dots can be displayed by forming a matrix with LCD <sub>1</sub> to LCD <sub>16</sub> . Three values, V <sub>SS3</sub> , V <sub>SS2</sub> , and V <sub>DD</sub> are output at 50 Hz. These pins are set to the low level (display off mode) automatically at the power on reset (when V <sub>DD</sub> is changed from the low level to the high level) or when the clock is stopped. | CMOS<br>Push-pull | - Note 1: For port operation instructions such as IN, OUT, SPB, and RPB, ports PA<sub>Q</sub> and PA<sub>3</sub> correspond to the least-significant and most-significant bits of the register or operand data. This is also the case for ports B and C. - Note 2: Since the output dedicated ports (Port 8, Port C, VDP and CGP) output undefined data when the device is powered on (that is when VDD is changed from the low level to the high level), initialization must be performed by the program. The data output when the CE pin is changed from the low level to the high level, or vice versa, or when a CKSTP instruction is executed is the same as that previously output. For this reason, initialization is also required in some other cases as well. # **BLOCK DIAGRAM** # 1. CPU #### 1,1 PROGRAM COUNTER (PC) The program counter consists of an 11-bit binary counter for addressing a program in program memory (ROM) (Note 1) The contents of the program counter are usually incremented by one each time an instruction is executed. When a jump or subroutine call instruction is executed, the address specified by the operand field is loaded (Note 2). When a skip instruction (ADS, TMT, RTS, etc.) is executed, the address of the instruction following the skip instruction is specified regardless of the skip condition. If the skip condition is satisfied, the instruction following the skip instruction is assumed to be NOP (No Operation). In this case, the NOP instruction is executed and the address of the next instruction is specified. - Note 1: The μPD1701, μPD1703, μPD1704, μPD1705, μPD1710, μPD1711, μPD1720 and μPD1730 (whose ROM capacity is less than 1 K step) have a 10-bit program counter. - Note 2: The JMP instruction has a 10-bit operand field and so PC10 is set or reset depending on the operation code since two kinds of JMP instructions are available for the µPD1715. A mnemonic code JMP is used for both of these JMP instructions but the assembler automatically determines which kind of JMP instruction is to be specified. (See Section 1.3 "Program Memory" for details). There exists only one kind of CAL instruction. PC10 is reset when a CAL instruction is executed. #### 1.2 STACK REGISTER (SR) The stack register consists of 11 bits and is used to store the value obtained by adding one to the program counter contents. This is the 11-bit return address when a subroutine call instruction is executed. When a return instruction (RT or RTS) is executed, the stack register content is loaded back into the program counter, transferring control to the original program flow. #### 1,3 PROGRAM MEMORY (ROM) The ROM includes 16 bits x 1528 steps and is used to store programs. The available ROM area extends from address 000H to address 5F7H (for 1528 steps). Fig. 1-1 ROM layout The page concept is applicable to the $\mu$ PD1715 ROM: Page 0 for ROM 000H to 3FFH and page 1 for ROM 400H to 5F7H, When a program is written, the first address of a subroutine must exist in page 0. A subroutine whose first address is found in page 1 cannot be called from pages 0 and 1. (See Notes on CAL instruction usage for details). A JMP instruction can be used in the assembler language without paying attention to the page specification. The same instruction format, JMP ADDR can be arbitrarily used for the addresses from 000H to 5F7H. The JMP instruction, however, for transferring control to an address in page 0 has a different operation code from the one for transferring control to an address in page 1. The user must be careful to apply a patch modification during program debugging. (See Notes on JMP instruction usage for details.) Please pay attention to the following notes when using the CAL and JMP instructions due to the different page concepts (pages 0 and 1) applicable on the µPD1715 ROM. ## Notes on CAL instruction usage When a CAL instruction is used, the call address, that is the first address of the subroutine to be called must exist in page 0 (000H to 3FFH). A subroutine whose first address is found in page 1 (400H to 5F7H) cannot be called. The return address, however, may exist in page 1 because the stack register consists of 11 bits. Example 1: When the first address of a subroutine exists in page 0. As shown above, the return address (of RT or RTS) may exist in page 0 or 1 if the first address of the subroutine is found in page 0. If the first address of the subroutine exists in page 0, a CAL instruction can be used without paying attention to the page designation. If the first address of a subroutine cannot be placed in page 0 due to a programming restriction, the following method can be used: With this method, a JMP instruction is specified in page 0 and the subroutine SUB1 is called via the JMP instruction. #### Notes on JMP instruction usage The page concept does not apply to a JMP instruction written in the assembler, that is, the same specification is possible for all ROM addresses 000H to 5F7H. The operation code however, varies between a JMP instruction passing control to page 0 (addresses 000H to 3FFH) and one passing control to page 1 (addresses 400H to 5F7H). Operation code 06 is generated for the JMP instruction transferring control to page 0, while operation code 02 is used for the one transferring control to page 1. These operation codes are automatically designated by the $\mu$ PD1700 series assembler when the program is assembled. Example of operation code 06 (the jump destination address is found in page 0) Example of operation code 02 (the jump destination address is found in page 1) If a program patch is used for program modification during debugging, the programmer must use operation codes 02 and 06 properly. In addition, address conversion is necessary if the destination address of a JMP instruction exceeds 400H (use operation code 02). In this case, address 400H is assumed to be address 000H and other addresses are changed accordingly. For example, address 5F7H is converted to address 1F7H. For JMP 400H, the user must input 02000 to apply a patch in the program. For JMP 000H, 06000 should be input. #### 1,4 DATA MEMORY (RAM) RAM consists of 4 bits x 96 words and is used to store programs. The 96-word RAM is subdivided into BANKO (64 words) and BANK1 (32 words). For any data processing, the bank specification of 0 or 1 is required. Addresses 00H to 0FH in BANKO are used as general registers for data operations and transfer using related memory. These registers can be also used as ordinary memory area. When memory is used as a general register, the bank specification is unnecessary and the address can be accessed regardless of the bank specification. When used as data memory, however, BANKO must be specified in advance (Note). Fig. 1-2 RAM layout Information necessary for controlling the PLL, that is, the dividing value, reference frequency, or dividing system can also be set via the RAM. For setting the dividing value, 4 bits x 4 words (N's words) at addresses 00H, 10H, 20H, and 30H and the most-significant bit of an arbitrary general register; a total of 17 bits are allocated. For the reference frequency and dividing system, an arbitrary one word (four bits) in RAM except for the N's words and the word including the N<sub>F</sub> bits is assigned as the control word. The information in these bits is transferred to the PLL register with a PLL instruction. Address 1FH in BANKO is called the PAIO word and is used to specify the input or output for port A. #### Note: The most important point for general register operation in BANK1 is that the µPD1715 does not support any arithmetic instructions which perform operations between the data in a general register and the immediate data. In a program in BANKO, "AI 00, 1" results in the incrementation of a general register at data memory address 00 by one. The AI instruction, however, is valid for an operation between data in the memory and immediate data, that is, the operation is not conducted between a register and the immediate data. If BANK1 is specified for the instruction above, the general register at address 00 is not incremented by one; instead, the contents of data memory address 00 in BANK1 are incremented by one. D # 1.5 TIMER F/F (TM F/F) The timer F/F is set by the 8 Hz (125 ms) signal and is reset by the test timer (TTM) instruction. Since the timer F/F is automatically set at 125 ms intervals, it can be used to measure ordinary time (8 counts/second) or to count the mute time. The timer F/F is reset only by executing a TTM instruction so the TTM instruction must be executed within the 125 ms interval. If the TTM instruction is executed in a period equal to or greater than 125 ms, count errors occur and correct time management cannot be performed. Fig. 1-3 TTM instruction execution timing Furthermore, the timer F/F can also be used to check for a power failure. The timer F/F is reset when $V_{DD}$ is changed from the low level to the high level and it is reset when a CKSTP instruction is executed or when CE is changed from the low level to the high level (Note 3). Figure 1-4 shows the state transition diagram illustrating these relationships. Note 2: If the TTM instruction is executed during the time when the timer F/F is being set, control cannot be passed to any other routine from this loop. At this time, the timer F/F is set to 1 following the next 125 ms interval and control is passed to address 0. Caution must be exercised because if the TTM instruction execution is carried out periodically and if the interval of TTM execution happens to be equal to that of the timer F/F setting (125 ms), control cannot then be transferred to address (). Fig. 1-4 CPU state transition via CE pin As shown in Fig. 1-4, the program starts from address 0 when the system is powered on $(V_{DD} = Low \rightarrow High)$ with the timer F/F reset regardless of the CE pin state. After this point, the timer F/F cannot be set unless the TTM instruction is executed once (timer F/F set to the disabled state). Once the TTM instruction is executed, the timer F/F enabled state is set and the timer F/F is set at 125 ms intervals. If the CE pin is changed from the low level to the high level while the power is V<sub>DD</sub> = High, program control jumps to address 0 as soon as the timer F/F is set<sup>(Note 4)</sup>. Consequently, the program starts from address 0 with the timer F/F kept in the set state. As explained above, the timer content is different between the state when it has been restored from a power failure $\{V_{DD} = Low \rightarrow High\}$ and when it has returned from other than a power failure, that is, in the backup state $\{V_{DD} = High\}$ , CE = Low $\rightarrow$ High). Therefore, whether the current state has been restored from a power failure or from other than a power failure can be determined by checking the timer F/F content with a TTM instruction. If the program starts from address 0 and the TTM instruction is executed with 125 ms, the TTM instruction determines that the current state has been restored from a power failure when the result is 0 (false) and that it has been restored from other than a power failure when the result is 1 (true) (that is system backup has been conducted). In a program having a timer function which operates also for CE = Low (that is CKSTP is not used), the following function is required when the system is restored from other than a power failure ( $V_{DD}$ = High, CE = Low $\rightarrow$ High). Program control is transferred to address 0 if the timer F/F is set, so the timer must be updated after a TTM instruction is executed to detect a power failure (the result is true). If this routine is not included, the timer will be delayed 125 ms each time the CE pin is changed from the low level to the high level. Note 3: The μPD1715 sets the timer F/F and passes program control to address 0 when CE is changed from the low level to the high level after a CKSTP instruction is executed. The μPD1701, μPD1704, μPD1710 and μPD1719 reset the timer F/F and pass program control to address 0. The user must pay attention to the fact that the timer content varies between μPD1715 and μPD1701, μPD1704, μPD1710 and μPD1719 after a CKSTP execution. Note 4: If the timer F/F setting and TTM execution take place simultaneously when CE is changed from the low level to the high level, program control is not passed to address 0. TTM execution shows that the timer F/F has been set, then the timer F/F is reset. This means that the user must be careful when a power failure is to be detected by a TTM instruction. When the timer F/F setting and TTM execution are initiated simultaneously, the TTM instruction takes precedence. This phenomenon does not affect the correct operation of the timer and a power failure may be determined by mistake. In the following program, however, control cannot be transferred to address 0 if the TTM execution and timer F/F setting take place at the same time (that is resetting cannot be performed). # ABC: TTM JMP DEF AI NEC1, 1 AIC NEC2, 0 JMP ABC DEF: In this example, the TTM instruction is executed, the next "JMP DEF" is skipped because the timer F/F has been reset, then the next three instructions are executed. This means control is kept running in the loop. The loop time period is $200 \, \mu s$ (five steps). The timer F/F is set at $125 \, \text{ms}$ intervals and the DEF routine is executed. This routine consists of 5n + 5 steps (TTM + JMP + DEF routine: a multiple of $200 \, \mu s$ ). When the CE pin is changed from the low level to the high level during a TTM execution in this program, the reset operation is not initiated as explained above. The TTM instruction checks that the timer F/F has been set, then the DEF routine is executed. However, since a multiple of $200 \, \mu s$ has elapsed from the time when the TTM instruction is executed to the next TTM execution, the timer F/F is next set ( $125 \, \text{ms}$ interval) at the same time when the TTM instruction is executed. Consequently, the reset operation is not carried out and control is kept running in the loop. This is the case for a program in which the TTM instruction is executed at $125 \, \text{ms}$ intervals. For this reason, the programmer must be careful not to create a routine in which the TTM execution interval is $125 \, \text{ms}$ ## 1.6 INTERVAL PULSE (ITP) The interval pulse is output with duty 60 % at 5 ms intervals and can be checked with a TIP instruction. Since a flip-flop (F/F) is not included, the pulse output is not reset even if the TIP instruction is executed. A correct timer (with a 5 ms interval) can be implemented by checking the interval pulse edge with successive TIP execution. Fig. 1-5 Interval pulse timing # 1.7 UNLOCK F/F (UL F/F) When the PLL system is not locked, that is, when the reference frequency, $f_r$ is not equal to the VCO divided output frequency, pulses are output from the phase detector ( $\phi$ -DET) at $f_r$ intervals. The unlock F/F is set with this pulse and is reset when a TUL instruction is executed. For this reason, the interval at which the TUL instruction is executed must be longer than $f_r$ . If it is less than $f_r$ , the PLL system is assumed to be locked even if it is not actually locked, resulting in an error. For the first TUL instruction after a PLL execution, it is also necessary that a time period equal to or greater than $f_r$ must have elapsed after the PLL execution. Fig. 1-6 TUL instruction execution timing #### 1.8 CARRY F/F (C F/F) If a carry or borrow occurs as the result of the execution of an arithmetic instruction, the carry F/F is set; otherwise, it is reset. The carry F/F contents does not ordinarily change unless an arithmetic instruction is executed. In addition, the carry F/F can be directly set or reset with a carry F/F set/reset instruction (STC, RSC) or a status word manipulation instruction (SS, RS). #### 1.9 BANK F/F (B F/F) The BANK F/F is used for specifying a bank of data memory (RAM) and for addressing a port. The 96-ward RAM is subdivided into BANKO (64 words) and BANK1 (32 words). Before starting data processing in a given bank, the BANKO or BANK1 instruction must be executed to specify the bank. Data processing between banks is carried out through the general registers (addresses 00H to 0FH in BANKO). If addresses 00H to 0FH in BANKO are used as general registers, the bank specification is not necessary and these registers can be accessed from both BANKO and 1. When these addresses are used as memory area, BANKO must be specified. The BANK F/F is also used for addressing a port, Port addressing is specified by the use of two bits in the operand field of the instruction and the contents of the BANK F/F. (See 3. Section explanation of ports for details.) The BANK F/F is reset and BANK0 is automatically specified when the system is first powered on $(V_{DD} = Low \rightarrow High)$ and CE is changed from the low level to the high level. This means the device is reset. #### 1.10 KEY LATCH F/F (KL F/F) When LCD pins (LCD<sub>16</sub>) are used as the key matrix key source, key source signals are asynchronously output from these pins according to the program (at 6.7 ms intervals). Thus the program must obtain information about whether or not the key source data has already been output via ports J and K and whether the key return signal has been latched by the key latch. The key latch F/F has been provided for this purpose. The key latch F/F is reset when data is written through ports J or K or when a TKLT or TKLF instruction is executed and is set when the key source signal is output from pins LCD<sub>9</sub> to LCD<sub>16</sub> with a 200 $\mu$ s setup time and the key return signal is latched by the key latch (at 6.7 ms intervals). The F/F content can be checked by the TKLT or TKLF instructions. Moreover, the key latch F/F is valid only when the LCD control digit KLE is "1" and is not changed when it is "1". The key latch F/F is reset when the device is powered on or when the clock is stopped. #### 1.11 STATUS WORD A status word consists of four bits indicating internal device states. These bits can be set or reset by program control. The following F/F inputs are connected to the status word: #### Status word 1 (Write only word) Manipulation instruction: SS, RS, etc. | #3 | #2 | #1 | #0 | |------|------|-------|----| | BANK | BANK | Carry | 0 | | F/F2 | F/F1 | F/F | | Status word 1 is a write only word and can be set or reset by instructions such as SS and RS. Note: A read only word (Status Word 2) is provided as the status word in some systems of the μPD1700 series. When this is the case, the F/F state can be tested. #### 2. PLL #### 2.1 REFERENCE FREQUENCY GENERATOR (RFG) The PLL is used to generate six reference frequencies 1, 3, 5, 6.25, 12.5 and 25 kHz by dividing the 75 kHz signal from an external crystal resonator. The reference frequency can be selected by a program (according to the control word data). ### 2.2 PHASE DETECTOR (Ø-DET) The phase detector is used to detect the phase difference between the reference frequency ( $f_r$ ) and the frequency obtained by dividing the VCO output with a programmable divider. The phase detector output is input to the internal charge pump circuit and the resulting pulses are output to pins EO<sub>1</sub> and EO<sub>2</sub>: (1) $f_r > f_{OSC}/N$ : Low-level signal (2) $f_r < f_{OSC}/N$ : High-level signal (3) $f_r = f_{OSC}/N$ : Floating state Where, fasc is the VCO oscillation frequency and N is the dividing factor of the programmable divider. #### 2.3 PROGRAMMABLE DIVIDER (P/D) The programmable divider is a binary down counter consisting of a swallow counter and a programmable counter. The swallow counter is a 5-bit presettable down counter in which the contents of the NRO (4 bits) and the N<sub>F</sub> register (one bit) are preset with the period of the reference signal. The programmable counter consists of 12 bits in which the contents of registers NR1 to NR3 are preset. The countdown takes place simultaneously for the programmable divider and the swallow counter. Fig. 2-1 Programmable divider configuration #### 2.4 PLL REGISTER The following information is necessary for controlling the PLL in $\mu PD1715$ : - (1) Dividing ratio (N) - (2) Reference frequency (fr) - (3) Dividing method (direct or pulse swallowing method) The PLL register is used to store these items. The PLL register consists of the N register (16 bits) and the N<sub>F</sub> register (1 bit) for storing the dividing factor and the control word register (4 bits) for storing the reference frequency and dividing method information. They correspond to the N's word, the N<sub>F</sub> bit, and the control word (CW) in data memory (RAM) and are transferred by a PLL instruction. Note: Since the CW is in BANK1 in this example, BANK1 must be specified before the PLL instruction is executed. Fig. 2-2 PLL register operation at PLL execution The N's words are allocated to addresses 00H, 10H, 20H, and 30H in RAM, the $N_F$ bit to the most-significant bit of an arbitrary general register, and CW to any RAM are except for the N's words and the word that includes the $N_F$ bit. The control word data codes are specified to select six reference frequencies (Table 2-1). The most significant bit (#3) of the control words specifies the dividing method: 0 for the direct dividing method and 1 for the pulse swallowing method. When the direct dividing method is specified, the VCOL pin is selected and a 0.5 MHz to 15 MHz signal $\{V_{in} = 0.1 V_{p-p} \text{ MIN.}\}$ can be input to the VCOL pin. The input frequency is directly divided by the value set tin the programmable divider. Control word #3 #2 #0 #2 #0 fr (kHz) #1 0 0 0 n 1 6.25 O Direct dividing method 0 1 0 5 Pulse swallowing method 3 0 1 1 0 12.5 1 1 25 1 1 O 1 1 1 Disable PLL® Table 2-1 Control word codes \*: Bit 3 may be 0 or 1 in the PLL disable mode. When the pulse swallowing method is specified, the pin to be selected varies between the VHF instruction and the HF instruction. When a VHF instruction is executed in the pulse swallowing method, the VCOH pin is selected and when the M pin is set to high level and used the 1/4 divider, a 10 MHz to 130 MHz signal $\{V_{in} = 0.1 \ V_{p-p} \ MIN.\}$ can be input to the VCOH pin. If this is the case, the frequency of signal input to the VCOH pin is divided by the 1/4 divider, then it is delivered to the programmable counter via the 1/32 and 1/33 two-modulus prescaler. Also, if this is the case, when the M pin is set to low level, the frequency is divided by 1/2 divider. This is, the frequency of signal input to the VCOH pin is divided by the 1/2 divider, then it is delivered to the programmable counter via the two-modulus prescaler. If this is the case, a 10 MHz to 100 MHz signal $\{V_{in} = 0.1 \ V_{p-p} \ MIN.\}$ can be input to the VCOH pin. When an HF instruction is executed in the pulse swallowing method, the VCOL pin is selected and a 0.6 MHz to 40 MHz signal $\{V_{in} = 0.1 \ V_{p-p} \ MIN.\}$ can be input to the VCOL pin. In this case, the signal input to the VCOL pin is transferred to the programmable counter via the 1/32 and 1/33 two-modulus prescaler. As explained above, a VHF instruction or an HF instruction must be executed if the pulse swallowing method is specified. Figure 2-3 depicts an equivalent internal circuit for showing these operations. In the diagram, SW1 is set to the other side by executing VHF or HF, whereas SW2 operates according to the PLL instruction. If a VHF or HF instruction is executed when the direct dividing method is selected, the SW1 state changes according to the executed instruction, but the PLL operation in the direct dividing method is not affected at all. Ordinarily, the direct dividing method is selected to receive the MW or LW band, while the pulse swallowing method (VHF) is selected to receive the FM band and the pulse swallowing method (HF) is selected to receive the SW band. Note: The SW1 and SW2 states are undefined when the device is powered on $(V_{DD} = Low \rightarrow High)$ . Fig. 2-3 Equivalent internal circuit Table 2-2 VCOL and VCOH pin states by dividing methods | CW#3 | Dividing method | VCOL, VCOH pin state | Condition of<br>the M pin | Input frequency | Dividing ratio | |------|----------------------------------------------------|------------------------------------------|---------------------------|-----------------|-------------------------------| | 0 | Direct dividing method | N001 | | 0.5 to 15 MHz | 16 to (2 <sup>12</sup> – 1) | | | Pulse swallowing method (HF instruction execution) | VCOL pin = Active [VCOH pin = Pull-down] | Don't care | 0.5 to 40 MHz | 1024 to (2 <sup>17</sup> – 1) | | 1 | Pulse swallowing VCOH pin ≃ Active | | High (1/4) | 10 to 130 MHz | 4096 to (2 <sup>17</sup> – 2) | | | method (VHF in-<br>struction execution) | (VCQL pin = Pull-down) | Low (1/2) | 10 to 100 MHz | 2048 to (2 <sup>17</sup> - 4) | #### 2.5 PLL INFORMATION SETTING The PLL information (dividing ratio, dividing method, and reference frequency) can be set by a program. The dividing ratio of the programmable divider is set as follows. # 1. Direct dividing method $$N = \frac{fVCOL}{f_r}$$ fVCOL: VCOL pin input frequency fr : Reference frequency Example: When the MW band is received (Receive frequency: 1422 kHz, reference frequency: 3 kHz, IF frequency: 450 kHz) $$N = \frac{1422 + 450}{3} = 624$$ = 270H (H indicates hexadecimal notation) In the direct dividing method, the NO and N<sub>F</sub> contents are ignored. # 2. Pulse swallowing method (VHF instruction execution) $$N = \frac{fVCOH}{P \times f_r}$$ fVCOH: VCOH pin input frequency fr : Reference frequency P : Divider dividing value (= 2 or 4, selected by M pin) Example: When the FM (U.S.A.) band is received (M pin = High) (Receive frequency: 100.1 MHz, reference frequency: 25 kHz, IF frequency: 10.7 MHz) $$N = \frac{(100.1 + 10.7) \times 10^6}{4 \times 25 \times 10^3} = 1108$$ $$= 454H (H indicates hexadecimal notation)$$ In this example, the least-significant bit is the $N_F$ bit. When the value is changed by one, the VCO oscillation frequency changes by 100 kHz. To change the frequency in steps of 200 kHz, 400 kHz, and 800 kHz, the value relative to NO must be changed by one, two, and four, respectively. In the example above, value N is determined by assuming that the N<sub>F</sub> bit is the least-significant bit; however, programming will be facilitated by setting a value in 4-bit groups beginning from NO. That is, the reference frequency is assumed to be 50 kHz for calculation. $$N = \frac{(100.1 + 10.7) \times 10^6}{4 \times 50 \times 10^3} = 554$$ $$= 22AH$$ As explained above, the same value is obtained as in the case where the reference frequency is assumed to be 25 kHz. 3. Pulse swallowing method (HF instruction execution) $$N = \frac{fVCOL}{f_r}$$ fvCOL: VCOL pin input frequency fr : Reference frequency Example: When the SW band is received (Receive frequency: 25.50 MHz, reference frequency: 5 kHz, IF frequency: 450 kHz) $$N = \frac{25.5 \times 10^6 + 450 \times 10^3}{5 \times 10^3} = 5190$$ In this example, the N<sub>F</sub> bit is assumed to be the least significant bit. When the value is changed by one, the VCO oscillation frequency is changed by 5 kHz. To change the frequency in steps of 10 kHz, 20 kHz, and 40 kHz, the value relative to NO must be changed by one, two, and four, respectively. As is clear from these three examples, 17 bits beginning from the $N_F$ bit are valid when the pulse swallowing method is selected, whereas 12 bits beginning from the N1 word become valid when the direct dividing system is specified. # 3. PORTS The μPD1715 uses port A (PA<sub>3</sub> to PA<sub>0</sub>) as the input/output port and port B (PB<sub>3</sub> to PB<sub>0</sub>), port C (PC<sub>3</sub> to PC<sub>0</sub>), CGP (PD<sub>3</sub>), and VDP (PG<sub>2</sub>) as output dedicated ports. Furthermore, it has internal ports: Port D (PD<sub>2</sub>), port G (PG<sub>1</sub> to PG<sub>3</sub>), port H (PH<sub>3</sub> to PH<sub>0</sub>), port J (PJ<sub>2</sub> to PJ<sub>0</sub>), and port K (PK<sub>1</sub> and PK<sub>0</sub>). Internal ports are used to set data for the CGP and VDP and to set ports when LCD pins (LCD<sub>9</sub> to LCD<sub>16</sub>) are used as the key source. A port is addressed by the use of direct addressing with two bits in the operand field of an instruction and the BANK F/F. Table 3-1 lists the correspondence between direct addressing and the BANK F/F specification. | Direc | t Add. | BANK | | | |-------|--------|-------|-------|-------| | #1 | #0 | BANK0 | BANK1 | BANK2 | | 0 | 0 | PA | - | PJ | | 0 | 1 | PB | - | PK | | 1 | 0 | PC | PG | - | | 1 | 1 | PD | PH | - | Table 3-1 Port addresses Note: The BANK F/F is commonly used for port and RAM operations. If BANK0 (RAM) is used after the ports of BANKs1 and 2 have been operated, the BANK F/F must be returned to BANK0 before BANK0 is used. #### 3.1 PORTA For port A (PA<sub>3</sub> to PA<sub>0</sub>), bit-unit input/output can be specified. Input/output is specified according to the data stored at address 1 FH of BANKO (called the PAIO word) in data memory (RAM). To set a port as an input port, specify 0 in the bit of the PAIO word corresponding to the port. To set a port as an output port, specify 1 in the corresponding bit of the PAIO word. | | #3 | #2 | #1 | #O | |----------------------------------------|-----------------|-----------------|-----------------|-----| | PAIO word<br>(address 1FH<br>of BANKO) | PA <sub>3</sub> | PA <sub>2</sub> | PA <sub>1</sub> | PAO | Example 1: When PA<sub>3</sub> and PA<sub>2</sub> are set as output ports and PA<sub>1</sub> and PA<sub>0</sub> are set as input ports. | | #3 | #2 | #1 | #0 | |-----------|----|----|----|----| | PAIO word | 1 | 1 | 0 | 0 | Example 2: When port A (PA<sub>3</sub> to PA<sub>0</sub>) is set as an output port. | | #3 | #2 | #1 | #0 | |-----------|----|----|----|----| | PAIO word | 1 | 1 | 1 | 1 | For port A, an input/output instruction must be executed after the input/output specification is set in the PAIO word. The input/output mode once set remains unchanged until the PAIO word contents (at address IF of BANKO) are changed. The input mode however, is automatically set when the device is powered on (V<sub>DD</sub> = Low → High), and the CKSTP instruction is executed, or when CE is changed from the low level to the high level. It should be noted that the PAIO word contents are not necessarily reflected on the port A input/output state. The device operates in the input mode for port A from this point on until the PAIO word is set. #### Example: ``` BANKO MVI 1FH, 1111B; Set all bits of port A for output ports. WVI 08H, 1100B; Set ports as follows: PA<sub>3</sub> and PA<sub>2</sub> to the high level, and PA<sub>1</sub> and PA<sub>0</sub> to the low level. ``` OUT 0, 08 H ; Set ports as follows: PA $_3$ and PA $_2$ to the high level, and PA $_1$ and PA $_0$ to the low level. : #### 3.2 PORT B AND PORT C Port B (PB<sub>3</sub> to PB<sub>0</sub>) and port C (PC<sub>3</sub> to PC<sub>0</sub>) of the µPD1715 are CMOS-type output dedicated ports. Ordinarily, they are used by output instructions such as OUT, SPB, and RPB. If an input (IN) instruction is executed, the data being output is read in the register specified by the operand field of the IN instruction. The output data is not changed by the IN execution. If "1" is output when an output instruction is executed, the high-level signal (V<sub>DD</sub> potential) is output; if "0" is output, the low-level signal (GND potential) is output. Note 1: Since data output from port B and port C is undefined when the device is powered on (V<sub>DD</sub> ≈ Low → High), these ports must be initialized by a program when the device is powered on. Note 2: Data output from port B and port C is not changed for a CE change (High to low, or vice versa) with V<sub>DD</sub> = High. That is, the previous state remains unchanged. This is also the case when a CKSTP instruction is executed. Example 1: Port initialization at device power on ``` START: RPB 0 , 1111B ; Port A (PA3 to PA0) = All low 1FH, 1111B; Set all bits of port A for output ports. MVI ,1111B ; Port B (PB<sub>3</sub> to PB<sub>0</sub>) = All low RPB 2 ,1111B ; Port C (PC3 to PC0) = All low RPB RPB 3 .1111B ; CGP (PD3) = Low TTM ; If the timer F/F has been set, the RAM ; initialization is not carried out. .IMP BACKUP MVI 00H. 0 RAM initialization MVI 01H, 0 BACKUP: ``` 6 JMP \$-1 #### Example 2: Port reset at clock stop For port B, port C, and CGP (PD<sub>3</sub>), the previous states are retained even if a clock stop (CKSTP) instruction is executed in the µPD1715. Consequently, if it is necessary to prevent current from flowing out of a port when the clock is stopped (that is if the port is to be set to the low level), the port must be reset before the clock stop instruction is executed as follows. ① TCET ; Do not skip if pin CE is at the low level for more than 120 μs before ①. ② TCEF ; Skip if pin CE is at the low level for more than 160 μs before ②. 3 JMP NOTSTP; Jump to NOTSTP if pin CE is found to be at the high level during ① or ② (CKSTP) is not executed). RPB 1, 1111B; Reset port B completely. RPB 2, 1111B; Reset port C completely. RPB 3, 1111B; Reset CGP. (5) CKSTP; The branch to address 0 is synchronized with the 8 Hz signal if pin CE is set to the high level after ③ (the reset operation is initiated). If this is the case, the loop formed by ⑤ and ⑥ is executed until the 8 Hz signal rises up. If pin CE continues to be at the low level at ⑤, the clock is stopped. Note: Even if a low-level signal not exceeding 140 µs is input to pin CE, the reset operation is not initiated; so ① and ② are provided to prevent wrong operation. The low-level signal must continue for at least 120 µs (three instruction cycles) for a TCET or TCEF instruction to determine the low-level state. If pin CE is at the low level for more than 160 µs (four instruction cycles) before a CKSTP instruction is issued, the CKSTP instruction stops the clock, ## 3.3 CLOCK GENERATOR PORT (CGP) The CGP is used as the modulated signal output port for outputting the 1 kHz or 3 kHz pulse. It can also be used to output bit-unit data. Port usage can be specified by the use of an internal port, port D. An internal port has no pins, but it can be operated with the same port manipulation instructions as the ordinary ports. The CGP pin output is set when port D is specified as follows: | | Port D | | | | | | |---|--------|----|-------|--------|--|--| | | #3 | #2 | #1 | #0 | | | | | | | Don | t care | | | | 1 | #3 | #2 | CGF | P pin | | | | | 0 | 0 | Low | | | | | | 1 | 0 | High | | | | | | 0 | 1 | 3 kHz | | | | | | 1 | 1 | 1 kHz | | | | The 3 kHz and 1 kHz pulses are output respectively with the following waveforms. Example: The 3 kHz pulse is output from CGP. BANK0 ; Specify BANKO. MVI 00H, 0100B; Set the 3 kHz output data at address 00H. OUT ; Output the 3 kHz pulse from CGP. #### 3.4 VARIABLE DUTY PORT (VDP) The VDP can be used as a variable-duty port for outputting a 1.12 kHz pulse repeatedly and it is also used as a bit-unit output port. The VDP can vary duty of a 1.12 kHz pulse in 64 steps: from 2/67 to 65/67. These operations can be specified by use of internal ports, port G and port H. An internal port has no pins but it can be used in the same way as the ordinary ports. This means that all port manipulation instructions are applicable. Since the addresses of ports G and H are allocated to BANK1, it must be specified before the port operation is started. Bits are related to each other for ports G and H as follows: The duty value is obtained by the following expression in the VDP mode: $$duty = \frac{Time \ period \ of \ High}{Period} = \frac{(VDP \ data) + 2}{67}$$ The duty variable range is expressed as follows: duty = $$\frac{26.7 \ \mu s}{893 \ \mu s}$$ to $\frac{867 \ \mu s}{893 \ \mu s}$ If $PG_1$ of the control bit is set to 0, the $PG_2$ through mode is set and the VDP can be used as a bit-unit output port. In this case, the $PG_2$ contents are output. The VDP pin is at the low level at power-on reset ( $V_{DD} = Low \rightarrow High$ ) or when the clock is stopped. The VDP pin state is not affected by the states of port G and port H and the reset state is released when a write instruction (OUT, SPB, or RPB) to port G is executed. The previous state is retained at reset (CE = Low $\rightarrow$ High). # 3.5 PORT J AND PORT K PJ<sub>2</sub> to PJ<sub>0</sub>, PK<sub>1</sub> and PK<sub>0</sub> are internal ports for setting the input data of the key source decoder. In other words, the input data of the key source decoder is set via these ports. The difference between these ports and the general-purpose output port is that the output of port J and port K is not delivered to any external pins so all port manipulation instructions can be used for port J and port K. The contents of port J and port K are retained even when the clock is stopped with a CKSTP instruction. If IN, TPT, or TPF is executed for port J and port K, the instruction is executed on the data which is being output from port J and port K to the key source decoder. Since only the two low-order bits are valid on port K, the two high-order bits are read as "0" if an IN instruction is executed for port K. #### 4. LCD DRIVER The $\mu$ PD1715 includes a 1/3 duty, 1/2 bias driving (voltage average method) LCD driver (frame frequency: 100 Hz, driving voltage: 3.1 V). Figure 4-1 shows the timing chart for the LCD driver operation. As can be seen from Fig. 4-1, the common signal outputs three kinds of voltages: V<sub>DD</sub>, V<sub>SS3</sub>, and intermediate voltage V<sub>SS2</sub>. That is, the common signal voltage changes $\pm \frac{V_{DD} - V_{SS3}}{2}$ relative to V<sub>SS2</sub>. Consequently, three segments (A, B, and C) can be driven by a segment output. The segment for which the potential difference from the common signal $\{V_{DD} - V_{SS3}\}$ becomes the greatest is turned on. Eight pins (LCDg to LCD<sub>16</sub>) among the segment output pins are configured to be used as the key source of the key matrix while they are used for display. Figure 4-2 depicts the LCD driving signal waveform for this operation. Figure 4-1 shows the LCD driving signal waveform when segment output pins are not used as the key source (in the key input through mode). As shown in Fig. 4-2, the LCD display and key source signals are output according to the time division. The key source signal has an interval of 6.7 ms and is output for 133 $\mu$ s. Since the key source signal is not synchronized with the program, it is impossible to input the key state as it is with a KIN or KI instruction. To overcome this difficulty, when segment pins are used as key source signals, the data on key input pins ( $K_3$ to $K_0$ ) is latched when the key source signal is output, then the latched data is read with a KIN or KI instruction. However, if the key latch F/F is in the reset state, the data is automatically latched at intervals of 6.7 ms of the key source signal. Therefore, when the LCD pin is used as the key source, a quick key response cannot be expected; however, it is sufficient for ordinary usage. Ports can be effectively used when the LCD pin is assigned as the key source of the key matrix. Fig. 4-1 LCD driving signal waveform (key input through mode) (A, B, C-OFF) Fig. 4-2 LCD driving signal waveform (key source output mode) (A, B, C-OFF) Key source output ON Key source output ON Key source output ON Key source output ON (A, B, C-OFF) (A. B. C-OFF) #### 4.1 DIGIT The 48 dots that can be displayed on the LCD are controlled in 12 groups: 0 to 8. Each group is called a digit. In addition to these 12 digits, there is a control digit F, which corresponds to the LCD control word for controlling the LCD driver and not to any dots on the LCD panel. This means that a data transfer to digit F indicates a transfer of data to the LCD control word. Bit #3 of the LCD control word is called the LCD Enable bit and is used to control the display mode state (on/off). Bit #2 is the Latch Enable bit for controlling whether or not LCD pins (LCD<sub>9</sub> to LCD<sub>16</sub>) are to be used as the key source. Two low-order bits (#1 and #0) are assigned as "Don't care". The LCD control word has the following functions: Note; Reset time indicates the time when the device is powered on or the clock is stopped. Figure 4-3 shows the digit configuration. For dots placed at the even-numbered positions, Dig-0, Dig-2, Dig-4, Dig-6, Dig-8, and Dig-A, the data transferred with an LCDD instruction is stored in the segment PLA and the data output from the PLA is displayed. For dots placed at the odd-numbered positions, Dig-1, Dig-3, Dig-5, Dig-7, Dig-9, and Dig-B, the data transferred by an LCDD instruction is displayed. Table 4-1 lists the correspondence between the data and dots to be displayed. Some dots belong to two kinds of digits. These dots can be displayed in two ways: The pertinent even-numbered position is specified at LCDD execution to display the dot via the PLA, or the odd-numbered position is specified as data output directly from the RAM for the dot display. Fig. 4-3 LCD matrix | | rt using | | + RAM bits | | | | |-------------------------------------|------------------------------------------|----------|------------|----|---|---| | Bit correspondence for add-numbered | d withou | 9 | LSB | 0# | 8 | • | | | positions (to be displayed without using | | | # | D | | | | s (to be | | | #2 | ű | _ | | 200 | position | \$<br>\$ | MSB | #3 | | م | | 200 4-1 | | | , | | | | D #### 4.2 DISPLAY PROCEDURE In the µPD1715 system, data is displayed by executing the following instruction to an external LCD panel: LCDD M, D M indicates an arbitrary address in the data memory {RAM} and D specifies the digit number of the digit to be displayed. Value D has one of the following 13 values: 12 values for Dig-0, Dig-B (00H to 0DH) and the dislay on/off and key source signal output assignment (0FH) as shown in the LCD matrix in Fig. 4-3. If value D contains one of the values 00H to 0D for the even-numbered positions (Dig-0, Dig-2, Dig-4, Dig-6, Dig-8, and Dig-A). The content of the data memory (RAM) specified by value M is unconditionally output to the character position specified by value D through the programmable logic array (PLA) for the display. If value D indicates one of the odd-numbered positions (Dig-1, Dig-3, Dig-5, Dig-7, Dig-9, and Dig-B), the contents of data memory (RAM) specified by value M are directly output (for the display) to the character position specified by value D without using the PLA. Tabel 4-1 lists the correspondence between the RAM data bits to be output to odd-numbered positions and the segments arranged at the odd-numbered positions. The following is an example of the operations at LCDD execution: Data "4" at address 24H in data memory (RAM) is delivered to the PLA, then the PLA content is output to the Dig-6 position. If SPLSEL contains "3", the content at address 4 in pattern group 0 is output to the Dig-6 position. If SPLSEL contains "2", the content at address 4 in pattern group 1 is output. Example: Digit display at odd-numbered positon Data "4" at address 24H in data memory (RAM) is directly output to the Dig-9 position. Four segments, bg, eg, fg, and gg, are arranged at the Dig-9 position. When value 4 = 0100B is output, only segment fg turns on. (See Table 4-1 for details.) Similarly, when value 5 = 0101B is output to the Dig-9 position, segments fg and eg turn on. As can be seen from the LCD matrix in Fig. 4-3, the Dig-8 position (even-numbered position) can be used as the Dig-9 position (odd-numbered position). For example, LCDD 10H, 08H results in the Dig-8 position being displayed via the PLA. For the following instruction, however, LCDD 10H, 09H the Dig-8 position is displayed without using the PLA. Similarly, the Dig-3 position (odd-numbered position) can be used as the Dig-0 position (even-numbered position). That is, data can be displayed at these positions via the PLA or without using the PLA. When the device is powered on $(V_{DD} = Low \rightarrow High)$ or when a CKSTP instruction is executed, the $\mu PD1715$ automatically sets the LCD segment pins $(LCD_1)$ to $LCD_{16}$ and LCD common pins $(COM_1)$ to $COM_3$ to the low level (that is display off mode). This means that all segments on the LCD panel are turned off in the display off mode. In the display off mode, the display is not turned on even if LCDD M, D (where, $0 \le D \le 0DH$ ) is executed. This LCDD instruction only causes the latch data in the LCD segment latch circuit to be rewritten. Consequently, the display on mode must be set to display any segment on the LCD panel. The following instruction is used to change the device from the display off mode to the display on mode: MVI M, 1XXXB LCDD M, 0FH As listed above, 0FH is specified for the second operand (D) of the LCDD instruction and 1XXXB (X = 0 or 1) is specified as the contents of the data memory (RAM) addressed by value M. In order to set the device from the display on mode to the display off mode by a program, value 0XXXB (X = 0 or 1) is output to the Dig-F position. The latch data in the LCD segment is not changed when the display off mode is set unless LCDD M, D (where, $0 \le D \le 0DH$ ) is executed, that is, the previous data (stored in the display on mode) is retained. A program for blinking all segments on the LCD panel at a predetermined interval can be implemented by using LCDD instructions which set the display on mode an display off mode in succession as explanined above. The following is an example of such a program: : LCDD 12H, 0AH ; Output data to Dig-A position. LCDD 11H, 0BH ; Output data to Dig-B position. MVI CONT, 8 ; Set the 5-second timer. ANI 34H, 0100B; Set the display off mode data. FLASH: LCDD 34H, 0FH ; Display off mode (all segments off) CAL WT500M ; Call subroutine for 500 ms wait. ORI 34H, 1000B; Reverse display. SIS CONT, 1; Skip after 5-time operation, that is, five seconds. JMP FLASH; Return to FLASH again if five seconds have not elapsed. : In this program example, each digit positions on the LCD panel is turned on, then all segments, that is, the entire LCD panel is blinked at 500 ms intervals for five seconds (500 ms off, 500 ms on). Note: The contents of the LCD segment latch are undefined when the device is powered on (V<sub>DD</sub> = Low -- Highl. If the display on mode is set immediately after the power is turned on, undefined data may be displayed in some cases. To prevent this from occurring, the data to be displayed in the display off mode must be output in advance to the respective character positions before the display on mode is set. #### 5. KEY INPUT PROCEDURE The µPD1715 supports three key matrix configurations. The first uses only the general-purpose ports (PA<sub>3</sub> to PA<sub>0</sub>, PB<sub>3</sub> to PB<sub>0</sub>, PC<sub>3</sub> to PC<sub>0</sub>, VDP, and CGP) for the key matrix source signals. The second configuration uses only the LCD pins (LCD<sub>9</sub> to LCD<sub>16</sub>) and the third uses the general-purpose ports and LCD pins (LCD<sub>9</sub> to LCD<sub>16</sub>) for the key source signals. The following are examples of these three key matrix configurations: #### 5.1 GENERAL-PURPOSE POSTS USED FOR KEY SOURCE Fig. 5-1. Example of the key matrix configuration which uses the general purpose ports for its key source Since the µPD1715 is driven with a low voltage, V<sub>DD</sub> = 2.0 V to 3.6 V, the reverse current preventive diode must be carefully inserted when configuring the key matrix. This means that since the voltage of the signal output from the key source is low, only the voltage drop corresponding to a diode stage is allowed to determine the high-level condition at the key input pin. Because of this, the sink current of port C (PC<sub>3</sub> to PC<sub>0</sub>) is set lower than other ports. For this reason, even if the momentary switch is repeatedly pressed as in Fig. 5-1, the high-level condition of the key input pin is guaranteed because the sink current of port C is low. The above explanation also applies to the other two key matrix configurations. When the above configuration is used, the program must reset the LCD control digit, KLE (key latch enable F/F) to set the key input through mode. (The device is set to this mode when it is powered on or when the clock is stopped). When this operation is complete, the contents of key input pins (K<sub>3</sub> to K<sub>0</sub>) can be directly read with a KI or KIN instruction. #### 5.2 LCD PINS USED FOR KEY SOURCE To output key source signals from the LCD pins, the KLE of the LCD control digit must be set to allow the device to enter the key source output mode. When this occurs, the LCD display data and key source signals are output form the LCD pins according to the time division. Since the program is asynchronous with the key source signal output, the key latch data can be read by the program by executing a KI or KIN instruction after a TKLT or TKLF instruction. The state of the key input pin (K<sub>3</sub> to K<sub>0</sub>) when the key source signal is output from the LCD pin is latched in the key latch. Figure 5-2 illustrates the concept behind these operations. ## 5.3 GENERAL-POUPOSE PORTS AND THE LCD PINS USED AS THE KEY SOURCE In the third key matrix configuration, both general-purpose ports and LCD pins are used for the key source. This is a combination of the first and second key matrix configurations. In this configuration, the general-purpose ports (port C) and the LCD pins are used for the key source of the key matrix. In this usage, momentary switches must be provided for port C and the other switches must be provided for the LCD pins. Figure 5-4 shows an example of this key matrix configuration. Fig. 5.4 Example of a key matrix configuration using general-purpose ports and LCD pins for the key source When reading the key input signal of the momentary key, LCD pins must be set to low level for preventing that the input signal of diode and alternate key is read. In Fig. 5-4, using the following program for reading key input signal of the momentary key. #### Example: | • | | | |-------|---------------|---------------------------------------------------------------------------------| | BANK0 | | | | MVI | 01H, 1100B; | LCD pins are used as key source signal outputs | | LCDD | 01H, 0FH ; | COD pins are used as key source signal outputs | | *SPB | 2, 1111B ; | Port C is output | | MVI | 02H, 0011B; | | | MVI | 03H, 0111B; | | | BANK2 | ; | Key source signal is output from LCD pins | | OUT | 0, 03H ; | Key source signal of LCD <sub>9</sub> to LCD <sub>16</sub> pin is all low level | | OUT | 1, 02H ; | | | BANK0 | ; , | | | TKLT | ;` | Remain in the wait state during key source signal latch time. | | JMP | <b>\$-1</b> ; | Hemain in the wait state during key source signal later time. | | KI | 04H ; | Read the momentary key return signal | | : | | | | : | | | Port C must be output befor key source signal of LCD pin is output. If port C is output after key source signal of LCD pin is output, the key source signal is not exectly read. Fig. 5-2 Concept of key input operations using LCD pins for key source The key source signal is output at a high level for 133 $\mu$ s every 6.7 ms. The key source signal output from the LCD pin is specified for internal ports: Port J (address 00B in BANK2) and port K (address 01B in BANK2). Figure 5-3 shows an example of the key matrix configuration when only the LCD pins are used for the key source. Fig. 5-3 Example of the key matrix configuration using the LCD pins as the key source With this key matrix configuration, it must be remembered that the signal output when a key is pressed should not be transferred to the other LCD pins. If the signal output when a key is pressed is transferred to other LCD pins, the LCD driving signal waveform is disturbed and an erroneous display may result. For this reason, stage diodes for preventing such a roundabout signal are necessary between the LCD pins and the key matrix when the key matrix is configured as shown in Fig. 5-1. Since only a voltage drop corresponding to a stage of the diode is allowed in the µPD1715, the key matrix cannot be configured as shown in Fig. 5-1. Figure 5-3 shows the key matrix configuration obtained when the facts explained above are considered. The data input to the two high-order bits of the key source decoder via PK<sub>1</sub> and PK<sub>0</sub> is called phase, whereas the bit input to each of the three low-order bits of the key source decoder, PJ<sub>2</sub> to PJ<sub>0</sub> is called the key source bit. The data output from the key source decoder is specified by the phase and key source bits. The phase is used especially to indicate the key scanning stage for the binary search method. In the following key search program example, the key source decoder operates using the binary search method by using LCDg to LCD16 as the key source. #### 5-4 KEY SOURCE DECODER The $\mu$ PD1715 allows the use of the LCD pins (LCD<sub>9</sub> to LCD<sub>16</sub>) for the key source. In this case, the key source signal is output at 6.7 ms intervals for 133 $\mu$ s. In all the keys on these eight key source lines are assumed to be scanned during this timing, a maximum of 53.6 ms is required to detect the key position after a key is pressed. The $\mu$ PD1715 has an integrated key source decoder to minimize the key position detecting time. The key source decoder permits detecting of the key position by use of the binary search method. The key source decoder has 5-bit input and 8-bit output. The two high-order bits of the input are connected to the internal ports, PK<sub>1</sub> and PK<sub>0</sub>; and the three low-order bits are connected to PJ<sub>2</sub>, PJ<sub>1</sub>, and PJ<sub>0</sub>. Table 5-1 outlines the decode table of the key source decoder. Decoder input LCD pins PK O O o n n n Table 5-1 Key source (LCD pin) decode table Note: The shading indicates that the key source signal is output to the pertinent pin. ## 6. PROGRAMMABLE LOGIC ARRAY (PLA) The μPD1715 includes the segment PLA to be controlled by a user program. Ordinarily, the display patterns of the LCD panel are programmed in the segment PLA. Up to 32 patterns (16 x 2) can be generated. As explained before, the segment PLA is selected only when an even-numbered position is specified by an LCDD instruction. (See Section 4 "LCD Driver" for details.) #### 6-1 SEGMENT PLA CONFIGURATION Figure 6-1 shows the segment PLA configuration. Fig. 6-1 Segment PLA configuration The contents of data memory (RAM) addressed by the first operand of the LCDD instruction are input to the four low-order bits of segment PLA. For example, when an LCDD instruction is executed with the following RAM contents, the data at address 05H of BANK1 in the data memory (RAM), that is, value 6 is input. Note: Since the RAM address in BANK1 is accessed, the BANK1 instruction must be executed before the LCDD instruction. #### CODING EXAMPLE ; Key source specification KEYSCAN: MVI RK, 3; RK = Phase Data MVI RJ, 0 MVI RS, 1000B ; RS = Key Source bit KSOUT1: BANK2 OUT PJ, RJ OUT PK, RK OUT PK, RK BANKO WAIT: TKLT ; Remain in the wait state until the key data is input to the key latch. JMP WAIT KIN KDATA ; KDATA ← Key Latch Data JMP RSHIFT ; Go to RSHIFT if the key data is input. SNEI RK, 3; If PHASE's data is 3, process the loop until the key data is input. JMP WAIT RS. RS RS. 1 ADN ORI SU RJ, RS; Key source bit is set just before, it is reset. RSHIFT: MVI RC, 2 ; Shift contents of RS left 3 bits. SFTLOOP: SIS RC, 1 JMP SFTLOOP AD iRJ, RS ; OR the shifted bit at key source bit. SIS RK, 1; Update the PHASE and go to KSOUT1, JMP KSOUT1; if PHASE0 has not been completed. SU RJ, RS BANK2 ; Confirm that the key of the key source determined in phase 0 has RPB PK, OFH ; been actually on. OUT PJ, RJ BANK0 KIN TKLT: Wait until the data is latched at key latch. JMP \$-1 KDATA JMP SCNEND; Scan operation is completed if KDATA is not 0. ; The segment number of pressed the key is input to KDATA. JMP KEYSCAN ; If KDATA is ZERO, noise is assumed and the operation is carried ; out again from the start point. The contents of bit 3 or 2 at the RAM column address specified by the LCDD instruction is latched in the most-significant bit of the segment PLA circuit. The bit to be latched must be specified when the device mask is ordered. (See Section 6-4 PLA program example for details.) When bit 3 is specified, "0" is input to the most-significant bit of the segment PLA if the RAM at column address 00H to 07H is specified by the LCDD instruction and "1" is input if address 08H to 0FH is specified. When bit 2 is specified, "0" is input to the most-significant bit of the segment PLA if address 00H to 03H or 08H to 08H is specified and "1" is input if address 04H to 07H or 0CH to 0FH is specified. The 32 segment PLA patterns are classified into two pattern groups, each consisting of 16 patterns according to the data input to the most-significant bit of the segment PLA. Consequently, even if the RAM data contents are the same, two types of display patterns can be generated by changing the RAM column address contained in the LCDD instruction. The 16 patterns that can be generated when the most-significant bit of segment PLA is "0" are called pattern group 0, whereas those generated when the most-significant bit is "1" are called pattern group 1. Fig. 6-2 Pattern groups when SPLSEL is specified for bit 3 Fig. 6-3 Pattern groups when SPLSEL is specified for bit 2 These pattern group divisions are determined by considering RAM or program efficiency when a program is created. An SPLSEL pseudo instruction is used to specify bit 3 or 2 to be input to the most-significant bit of the segment PLA: SPLSEL 3 or, SPLSEL 2 (See Section 6.4 PLA program example for details.) ## 6.2 SEGMENT PLA PATTERN EXAMPLES Tables 6-1 and 6-2 outline examples of pattern groups 0 and 1, respectively. Table 6-1 Example of pattern group 0 | | Seame | nt PLA | innut | | | | Segn | nent out | tput | | | Output pattern | |---|---------|--------|-------|---|---|---|------|----------|------|---|---|---------------------| | | Segrife | | прис | | 9 | f | е | d | С | b | а | Output pattern | | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Ü | | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | <b>-</b> | | | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 2 | | | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 7 | | | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | ų | | | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 5 | | | o | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 5 | | , | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | Į. | | | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 8 | | | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 9 | | | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Blank (display off) | | | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | Ε | | | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | | | | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | X | | | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | P | | | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | • | Table 6-2 Example of pattern group 1 | | C | ent PLA | | | | | Segn | nent out | tput | | | Output pattern | |---|-------|---------|----------|---|---|---|------|----------|------|---|-----|----------------| | | Segme | ini rur | c iniput | | g | f | e | ď | С | b | a | Output pattern | | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | SEC OFF | | | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | SEC OFF | | | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 . | SEC | | | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | , | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | ' | 1 | 0 | o | 0 | 0 | 0 | a | 0 | 0 | a | 0 | NO USE | | | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | o | 0 | 0 | NO USE | | | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NO USE | #### 6.3 DISPLAY PROGRAM EXAMPLE In the following program example, the LCD panel shown in Fig. 6-4 is used to display PLA patterns listed in Tables 6-1 and 6-2. It is assumed that bit 2 (SPLSEL 2) is specified as the most-significant bit of the segment latch. Fig. 6-4 LCD panel example LCDD 17H, 01H ; "FM", "MHz" Display data set LCDD 18H, 00H ; "1" Frequency data set LCDD 19H, 02H ; "0" Frequency data set LCDD 1AH, 04H ; "2" Frequency data set LCDD 1BH, 06H ; "7" Frequency data set LCDD 1CH, 08H ; "5" Frequency data set LCDD 1DH, 03H ; "ch" Display data set ; DECIMAL POINT Display data set LCDD 1EH, 07H LCDD 18H, OAH ; "4" PRESET STATION NO. Display data set LCDD 3FH, 0FH ; ALL DIGITS ON Fig. 6-5 Display example #### 6.4 PLA PROGRAM EXAMPLE The PLA definition is required for all µPD1700 series devices. If the PLA section is not defined, the tape order cannot be accepted. The PLA definition is placed at the end of an assembler source program and contains the following items. All of these items are required, that is, none of the items can be dispensed with. #### (1) PLA pseudo instruction Indicates the beginning of the PLA definition area immediately after the end of the program description area. #### (2) Segment PLA Select (SPLSEL) pseudo instruction Selects the RAM address division for generating segment pattern groups 0 and 1. The following two instruction formats are available: SPLSEL 3 and SPLSEL 2 #### (3) Define Segment PLA (DSP) pseudo instruction Defines 32 segment PLA patterns. The patterns must be defined beginning with the 16 patterns in pattern group 0. The following is an example of a pattern definition. The first specified bit corresponds to segment g and the subsequent bits correspond to segments f, e, d, c, b, and a in this order. #### (4) END Indicates the end of the source program immediately after the PLA definition area has ended. If this instruction is omitted, the program is not assembled. Note 1: The digit PLA definition is also required for the μPD1700 series devices having the digit PLA. These include the μPD1701, μPD1703, μPD1704, μPD1705, μPD1707, μPD1711, and the μPD1712. A define Digit PLA (DDP) pseudo instruction is used to define the digit PLA. Similarly, the MTDIG definition is required for devices having the digit pin. These include the μPD1701, μPD1703, μPD1704, μPD1705, μPD1707, μPD1701, μPD1711, and μPD1712. Note 2: The PLA definition begins with PLA and ends with END. The user may specify SPLSEL, DSP, DDP, and MTDIG between PLA and END in an arbitrary order. #### PLA program example ``` : *****PLA DEFINITION **** PLA SPLSEL 2 ; ***SEGMENT PATTERN 0 *** gf edc ba DSP 0111111B ; 0 0000110B DSP : 1 DSP 1011011B ; 2 DSP ; 3 1001111B DSP 1100110B ; 4 DSP 1101101B ; 5 DSP 1111101B ; 6 DSP 0100111B ; 7 DSP 1111111B ; 8 DSP 1101111B ; 9 DSP 0000000B ; BLANK DSP 1111001B : E ; C DSP 0111001B DSP 1110110B ; H DSP 1110011B ; P DSP 1000000B ; – ; *** SEGMENT PATTERN 1 *** ; 0 (FM 50 kHz), ' SEC '- OFF DSP 1000010B ; 5 (FM 50 kHz), ' SEC ' - OFF DSP 0100010B ; SEC DSP 0010000B DSP 0000000B ; NO USE ; NO USE DSP 0000000B DSP 0000000B ; NO USE DSP 0000000B ; NO USE DSP 0000000B ; NO USE DSP 80000000 ; NO USE DSP 0000000B : NO USE DSP 80000008 ; BLANK DSP 0000000B ; NO USE DSP 0000000B ; NO USE ; NO USE DSP 0000000B ; NO USE DSP 0000000B ; NO USE DSP 0000000B ; ; END ``` # 7. INSTRUCTION # 7.1 µPD1715 INSTRUCTION SET | | | _ | b <sub>15</sub> | h <sub>14</sub> | 0 | 0 | | 0 1 | 1 ( | ) | | 1 1 | | |-----------------|-------------------|--------|-----------------|-----------------|------------------------------------|------------------------|-----------|--------|--------------|---------------------------------|------|-----|---| | h <sub>13</sub> | h <sub>12</sub> b | 011 b1 | 0 | | 1 | 0 | | ı | 2 | | | 3 | | | 0 | 0 | 0 | 0 | 0 | NOP<br>VHF<br>HF | | KIN<br>KI | M<br>M | | | ST | М, | r | | 0 | 0 | 0 | 1 | 1 | SPB<br>SS<br>BANK1<br>BANK2<br>STC | P. N | ORI | М, Г | | | MVRS | М, | r | | 0 | 0 | 1 | 0 | 2 | JMP | ADDR<br>(page 1) | MVI | M, I | ост | P, r | IN | r, | P | | 0 | 0 | 1 | 1 | 3 | RPB<br>RS<br>BANKO<br>RSC | P. N<br>N <sub>1</sub> | ANI | М, І | CKSTP | | MVRD | r, | М | | 0 | 1 | 0 | 0 | 4 | RT | | Al | М, І | MVSR | M <sub>1</sub> . M <sub>2</sub> | AD | r, | M | | 0 | 1 | 0 | 1 | 5 | RTS | | SI | М, І | EXL | r, M | su | r. | М | | 0 | 1 | 1 | 0 | 6 | ЈМР | ADDR<br>(page 0) | AIC | М, [ | LD | r, M | AC | r, | M | | 0 | 1 | 1 | 1 | 7 | CAL | ADDR<br>(page 0) | SIB | M, I | LCDD | M. D | SB | г, | М | | 1 | 0 | 0 | 0 | 8 | TPF<br>TCEF | P, N | AIN | M, I | TKLF<br>TKLT | | ADN | r, | М | | 1 | 0 | 0 | 1 | 9 | TPT<br>TCET | P, N | SIN | М, І | TTM<br>TIP | | SUN | г, | М | | 1 | 0 | 1 | 0 | A | TMF | M, N | AICN | M, I | TUL | | ACN | r, | М | | 1 | 0 | 1 | 1 | В | ТМТ | M. N | SIBN | М, І | PLL | М, г | SBN | r, | M | | 1 | 1 | 0 | 0 | С | SLTI | м, і | AIS | М, [ | SLT | r, M | ADS | r. | M | | 1 | 1 | 0 | 1 | D | SGEI | М, І | SIS | М, І | SGE | r, M | sus | г, | М | | 1 | 1 | 1 | 0 | E | SEQI | М, І | AICS | M, 1 | SEQ | r, <b>M</b> | ACS | г, | М | | 1 | 1 | 1 | 1 | F | SNEI | М, І | SIBS | M, i | SNE | r, M | SBS | r, | м | ## 7.2 INSTRUCTIONS $NOTE: D_{\text{H}}: Data\ memory\ address\ high\ (row\ address)\{2\ bits$ DL: Data memory address low (column address) 4 bits Rn: Register number [4 bits] I: Immediate data [4 bits] N: Bit position [4 bits] ADDR : Program memory address [10 bits] r : General register One of addresses 00-0FH of BANKO M : Data memory address One of 00-3FH of BANKO and address 00-1FH of BANKI P : Port, 0≤P≤3 $N_1$ : Bit position of status word 1 $0 \le N_1 \le 7$ ( ) : Contents of register or memory c : Carry b Borrow ( in : Contents on bit n of register or memory h : Halt release conditions 0 ≤h≤7 | | | Ope | rand | | | | Machin | e code | | |-------------|----------|-----|------|--------------------------------------------------------------------------|---------------------------------------------------|----------------|----------------|-----------------|----| | 1 | Mnemonic | 1ST | 2ND | Function | Operation | Operation code | | | - | | | AD | r | м | Add memory to register | r ← (r: + (M) | 110100 | D <sub>H</sub> | Dı | Rn | | | ADS | r | м | Add memory to register, then skip if carry | r ← (r) + (M)<br>skip if carry | 1:1100 | DH | Đ <sub>t</sub> | Rn | | | ADN | r | м | Add memory to register, then skip if not carry | r ← (r) + (M)<br>skip if not carry | 111000 | DH | D <sub>L</sub> | Rn | | | AC | r | м | Add memory to register with carry | r ← (r) + (M) + c | 110110 | D <sub>H</sub> | D <sub>L</sub> | Rn | | | ACS | ٠ | М | Add memory to register with carry, then skip if carry | $r \leftarrow (r) + (M) + c$<br>skip if carry | 111110 | D <sub>H</sub> | D <sub>I.</sub> | Rn | | Addition | ACN | ٠ | М | Add memory to register with carry, then skip if not carry | $r \leftarrow (r) + (M) + c$<br>skip if not carry | 111010 | Dн | D <sub>L</sub> | Rn | | PPV | Ai | М | I | Add immediate data to memory | $M \leftarrow (M) + I$ | 010100 | D <sub>H</sub> | D <sub>L</sub> | 1 | | | AIS | М | I | Add immediate data to memory, then skip if carry | M ← (M) + I<br>skip if carry | 011100 | DH | Dı | I | | | AIN | М | I | Add immediate data to memory, then skip if not carry | M ← (M) + I<br>skip if not carry | 011000 | D <sub>H</sub> | Dt | ı | | | AIC | М | ı | Add immediate data to memory with carry | M ← (M) + [ + c | 010110 | Dн | Dı | 1 | | | AICS | М | ī | Add immediate data to memory with carry. then skip if carry | $M \leftarrow (M) + 1 + c$ skip if carry | 011110 | DH | Dı | 1 | | | AICN | М | ı | Add immediate data to memory with carry,<br>then skip if not carry | M ← (M) + 1 + c<br>skip if not carry | 011010 | D <sub>H</sub> | Dı | ı | | | su | r | М | Subtract memory from register | r ← (r) ~ (M) | 110101 | D <sub>H</sub> | Du | Rn | | | sus | г | М | Subtract memory from register, then skip if borrow | r ← (r) − (M)<br>skip if borrow | 111101 | DH | D <sub>L</sub> | Rn | | | SUN | r | М | Subtract memory from register, then skip if not borrow | r←(r) ~ (M)<br>skip if not borrow | 111001 | D <sub>H</sub> | $D_1$ | Rn | | | SB | г | м | Subtract memory from register with borrow | $r \leftarrow (r) = (M) = b$ | 110111 | D <sub>H</sub> | D <sub>L</sub> | Rn | | | SBS | r | М | Subtract memory from register with borrow, then skip if borrow | _r ← 'r) = 'M) = b<br>skip if borrow | 111111 | D <sub>H</sub> | Di | Rn | | Subtraction | SBN | r | М | Subtract memory from register with<br>borrow, skip if not borrow | r ⊷ (r) = (M) = b<br>skip if not horrow | 111011 | Ðĸ | Dt | Rn | | Subtr | SI | М | I : | Subtract immediate data from memory | M += (M) = I | 010101 | Ðπ | D <sub>1</sub> | 1 | | | sis | М | | Subtract immediate data from memory, then skip if borrow | M ← (M) ·· I<br>skip if horrow | 011101 | D <sub>H</sub> | D <sub>1</sub> | 1 | | | SIN | М | ı | Subtract immediate data from memory, then skip if not borrow | M ← (M) = 1<br>skip if not borrow | 011001 | Dя | Dt | 1 | | | SIB | М | ı | Subtract immediate data from memory with borrow | -М ← (М) — Г - Ъ | 010111 | Dя | Dt | ı | | | SIBS | М | 1 | Subtract immediate data from memory with borrow, then skip if borrow | M ← (M) + 1 = b<br>skip if horrow | 011111 | Ds | D <sub>1</sub> | ı | | | SIBN | М | 1 | Subtract immediate data from memory with burrow, then skip if not horrow | M + (M) I - b<br>skip if not borrow | 011011 | D <sub>H</sub> | D <sub>i</sub> | I | | | | Ope | rand | | | | Machin | e code | | |---------------|----------|-----|------|-------------------------------------------------------------------------|----------------------------------------------------------|----------------|----------------|---------|-----------------| | | Mnemonic | | 2N1) | Function | Operation | Operation code | | | | | | SEQ | r | М | Skip if register equals memory | r – M<br>skip if zero | 101110 | DH | DL | Rn | | | SNE | r | М | Skip if register not equals memory | r – M<br>skip if not zero | 101111 | D <sub>H</sub> | DL | Rn | | | SGE | r | М | Skip if register is greater than or equal to memory | r – M<br>skip if not horrow(r)≥(M) | 101101 | D <sub>H</sub> | DL | Rn | | umparison | SI.T | г | М | Skip if register is less than memory | r - M<br>skip if borrow(r) < (M) | 101100 | D <sub>H</sub> | DL | Rn | | (.ompa | SEQI | М | 1 | Skip if memory equals immediate data | M — [<br>skip if zero | 001110 | D <sub>H</sub> | DL | ı | | | SNEI | М | ı | Skip if memory not equals immediate data | M - I<br>skip if not zero | 001111 | D <sub>H</sub> | DL | I | | | SGEL | М | ı | Skip if memory is greater than or equal to immediate data | M = I<br>skip if not borrow(M) ≥ I | 001101 | D <sub>H</sub> | DL | 1 | | | SI.TI | М | 1 | Skip if memory is less than immediate data | M - 1<br>skip if barrow(M) < I | 001100 | D <sub>H</sub> | DL | 1 | | operation | ANI | М | ı | Lugic AND of memory and immediate data | $M \leftarrow (M) \wedge I$ | 010011 | DH | DL | Ì | | | ORI | М | ı | Logic OR of memory and immediate data | $M \leftarrow (M) \lor I$ | 010001 | D <sub>H</sub> | DL | 1 | | Logical | EXL | r | м | Exclusive OR Logic of memory and register | r ← (r) (+ (M) | 100101 | D <sub>H</sub> | DL | Rn | | | LD | r | М | Load memory to register | r ← (M) | 100110 | D <sub>H</sub> | DL | Rn | | | ST | М | r | Store register to memory | $M \leftarrow (r)$ | 110000 | D <sub>H</sub> | DL | Rn | | / | MVRD | r | М | Move memory to destination memory referring to register in the same row | $iD_{H}, Rn \leftarrow (M)$ | 110011 | D <sub>H</sub> | DL | Rn | | Transfe | MVRS | М | r | Move source memory referring to register to memory in the same row | $M \leftarrow (D_H, R_H)$ | 110001 | D <sub>H</sub> | DL | Rn | | | MVSR | М, | Mz | Move memory to memory in the same row | $\{D_H,DL_1\}\leftarrow\{D_H,DL_2\}$ | 100100 | D <sub>H</sub> | DĻı | D <sub>L2</sub> | | | MVI | М | ı | Move immediate data to memory | M ← I | 010010 | D <sub>H</sub> | DL | ı | | | Pl.L | М | r | Load NO~N3.N, & memory to PLL registers | PLLR ← (N0 ~ N3), N <sub>F</sub> & (M) | 101011 | D <sub>H</sub> | DL | Rn | | test | TMT | М | N | Test memory bits, then skip if all bits specified are true | if M(N) = all "1", then skip | 001011 | D <sub>H</sub> | DL | N | | B B | TMF | М | N | Test memory bits, then akip if all bits specified are false | if M (N) = all "0", then skip | 001010 | D <sub>H</sub> | DL | N | | Jump | JMP | AD | DR | Jump to the address specified in page 0 | PC←ADDR in page 0 | 000110 | | ADDR(10 | bits) | | <b>-</b> | | | | Jump to the address specified in page 1 | PC←ADDR in page 1 | 000010 | - | | | | | CAL | AD | DR | Call subroutine in page 0 | Stack←[(PC)+1,PAGE], PC←ADDR<br>PAGE←0 | 000111 | | ADDR(10 | bits) | | Subroutine | RT | | | Return to main routine | PC←(stack) | 000100 | - | _ | _ | | 55 | RTS | | | Return to main routine, then skip<br>unconditionary | PC←(stack), and skip | 000101 | | _ | - | | | ттм | | | Test and reset timer F F, then skip if it has not been set | if Timer F'F=1,then Timer F'F←0 if Timer F'F=0,then skip | 101001 | - | - | - | | 2 | TUL | | | Test and reset unlock F F, then skip if it has not been set | if UL F/F=1, then UL F/F←0 if UL F/F=0, then skip | 101010 | - | - | - | | F/F | TKLT | | | Test and reset key latch F/F, then skip if true | if KL F/F=1, then skip and<br>KL F/F←0 | 101000 | 1 1 | 0001 | - | | | TKLF | | | Test and reset key latch F/F, then skip if false | if KL F/F=1, then KL F/F⊶0 if KL F/F=0, then skip | 101000 | 0 1 | 0001 | - | | Timer<br>test | TII | | | Test interval pulse, then skip if low | if IPG=0, then skip | 101001 | - | 0000 | 0000 | | _ | |----| | | | ┏. | | _ | | Г | | Ope | rand | | | 1 | Mache | ie code | _ | |-------------------------------|----------|----------------|------|-----------------------------------------------------------|---------------------------------------|----------------|----------------|------------------|------| | ı | Mnemonic | 1ST | 2ND | Function | Operation | Operation code | | | | | | ss | N, | | Set status word 1 | (STATUS WORD 1)5-1 | 000001 | - | 0 N <sub>1</sub> | - | | | RS | N <sub>1</sub> | | Reset status word ( | (STATUS WORD 1),+0 | 0 0 0 0 1 1 | - | 0 N <sub>1</sub> | _ | | 1 | STC | | | Set carry F'F | carry F F←1 | 0 0 0 0 0 1 | - | 0010 | - | | i i | RSC | | | Reset carry F F | carry F F← 0 | 000011 | - | 0010 | - | | P. | BANKO | | | Select BANKO | BANK F/F1←0, BANK F/F2←0 | 000011 | - | 1100 | - | | Status word and terminal test | BANKI | | | Select BANK1 | BANK F/F1←1, BANK F/F2←0 | 000001 | - | 0100 | - | | Statu | BANK2 | | | Select BANK2 | BANK F/F1←0. BANK F/F2←1 | 000001 | - | 1000 | _ | | | TCET | | | Test CE, skip if true | if CE=1, then skip | 001001 | - | 0010 | _ | | | TCEF | | | Test CE, skip if false | if CE=0, then skip | 001000 | - | 0010 | - | | | LCDD | М | D | Output memory to LCD DIG "D" directly | LCD(D)←SEGPLA←(M) or<br>LCD(D)←(M) | 100111 | D <sub>H</sub> | D | DL | | | KI | М | | Input key data to memory | MK <sub>0-3</sub> | 010000 | Dis | DL | 0000 | | | KIN | М | | Input key data to memory, then skip if data are zero | M+-K <sub>0+3</sub> , skip if (M) = 0 | 010000 | Dн | DL | - | | JA. | in | r | P | Input data on port to register | r⊷(Port(P)) | 110010 | þ | - | Rn | | Input / output | оит | Р | ٠ | Output contents of register to port | (Port(P) )—(r) | 100010 | P | - | Rn | | Ē | SPB | P | N | Set port bits | (Port(P) K←1 | 000001 | P | 0000 | × | | | RPB | P | N | Reset port bits | (Port(P) K+0 | 000011 | P | 0000 | N | | | трт | P | z | Test port bits, then skip if all bits specified are true | if (Port(P) ) = all 1s, then skip | 001001 | P | 0000 | N | | | TPF | Р | N | Test port bits, then skip if all bits specified are false | if (Port(P) ) = all Os. then skip | 001000 | Р | 0000 | N | | | VHF | | | Connect FM terminal to prescaler via<br>1/2 divider | FM terminal → 1/2 → prescaler | 000000 | 0 0 | 0000 | 0001 | | | HF | | | Connect AM terminal to prescaler directly | AM terminal → prescaler | 000000 | 0 0 | 0000 | 0000 | | Others | CKSTP | | | Clock stop by CE | stop clock if CE=0 | 100011 | - | 1110 | 1110 | | | HALT | h | | Halt the CPU,<br>Restart by condition h | Halt | 100011 | 0 0 | - | h 1 | | | NOP | | | No operation | | 000000 | - | - | - | ## 8. INPUT/OUTPUT CIRCUITS Input/output circuit for different µPD1715 pin are outlined below in simplified format. # (1) LCD1 to LCD16, PB0 to PB3, PC0 to PC3, EO1, EO2, CGP and VDP ## (2) M # (3) PA<sub>0</sub> to PA<sub>3</sub> # (4) COM<sub>1</sub>, COM<sub>2</sub> and COM<sub>3</sub> # (5) K<sub>0</sub> to K<sub>3</sub> ## (6) VCOH and VCOL # (7) CE # 9. ELECTRICAL CHARACTERISTICS # ABSOLUTE MAXIMUM RATINGS | Supply Voltage | V <sub>DD</sub> | -0.3 to +4.0 | V | |-----------------------|-----------------|-------------------------------|----| | Input Voltage | $v_{l}$ | -0.3 to +V <sub>DD</sub> +0.3 | V | | Output Voltage | Vo | -0.3 to +V <sub>DD</sub> +0.3 | V | | Output Sink Current | ło | 10 | mA | | Operating Temperature | Τa | -20 to +75 | °c | | Storage Temperature | $\tau_{stq}$ | -55 to +125 | °c | ## RECOMMENDED OPERATING CONDITIONS | CHARACTERISTIC | SYMBOL | MIN. | TYP. | MAX. | UNIT | CONDITION | |----------------------------|-----------------|------|------|-----------------|------|--------------------------------------------------| | Supply Voltage | V <sub>DD</sub> | 2.0 | 3.0 | 3.6 | v | | | Operating Temperature | Ta | -20 | | +75 | °c | | | Input Oscillation Voltage | Vin | 0.2 | | VDD | Vp-p | VCOL pin | | Input Oscillation Voltage | Vin | 0.1 | | VDD | Vp-p | VCOH pin | | Data Retention Voltage | VDR | 1.5 | | v <sub>DD</sub> | v | When the detection of<br>power failure is judged | | Supply Voltage Rising Time | Trise | | | 500 | ms | V <sub>DD</sub> =0 → 1.7 V | # DC CHARACTERISTICS ( $V_{DD}$ = +1.7 to +3.6 V, $T_a$ = -20 to +75 °C) | CHARACTERISTIC | SYMBOL | MIN. | TYP. | MAX. | UNIT | CONDITION | |--------------------------------|------------------|---------------------|------|---------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Supply Voltage | V <sub>DD1</sub> | 2.0 | 3.0 | 3.6 | ٧ | CPU and PLL operations | | Supply Voltage | V <sub>DD2</sub> | 1.9 | 3.0 | 3.6 | ٧ | CPU and PLL operations, T <sub>a</sub> =-20 to +50 °C | | Supply Voltage | V <sub>DD3</sub> | 1.7 | 3.0 | 3.6 | ٧ | CPU operation | | Supply Current | I <sub>DD1</sub> | | 8 | 12 | mA | VCOH pin, 120 MHz 0.2 Vp-p since wave signal input (Vpp=3 V) | | Supply Current | I <sub>DD2</sub> | | | 30 | μΑ | CPU operation (when excution HALT instruction) (VDD=3 V, T <sub>8</sub> =25 °C) | | Minimum Data Retention Voltage | VDR | 1.5 | | V <sub>DD</sub> | ٧ | When the detection of power failure is judged by TTM instruction excution | | Data Retention Current | IDR | | | 3 | μА | When clock oscillation is stopped. V <sub>DD</sub> =3 V | | High Level Output Current | <sup>1</sup> ОН1 | -0.5 | | | mA | PA <sub>0</sub> to PA <sub>3</sub> , PB <sub>0</sub> to PB <sub>3</sub> , PC <sub>0</sub> to PC <sub>3</sub> , CGP pins, V <sub>OH</sub> =V <sub>DD</sub> -1 V | | High Level Output Current | lOH2 | -0.2 | | | A | EO <sub>1</sub> , EO <sub>2</sub> , VDP pins, V <sub>OH</sub> =V <sub>DD</sub> -1 V | | High Level Output Current | Іонз | -50 | - | | μА | LCD <sub>1</sub> to LCD <sub>16</sub> pins, V <sub>OH</sub> =V <sub>DD</sub> -1 V | | Low Level Output Current | lOL1 | 0.5 | | | mA | PA <sub>0</sub> to PA <sub>3</sub> , PB <sub>2</sub> , PB <sub>3</sub> , CGP pins, V <sub>OL</sub> =1 V | | Low Level Output Current | lOL2 | 0.2 | | | Α | EO <sub>1</sub> , EO <sub>2</sub> , VDP pins, V <sub>OL</sub> =1 V | | Low Level Output Current | lor3 | 5 | | | μА | LCD <sub>1</sub> to LCD <sub>16</sub> pins, PB <sub>0</sub> , PB <sub>1</sub> , PC <sub>0</sub> to PC <sub>3</sub> pins, V <sub>OL</sub> =1 V | | High Level Input Current | liH1 | 3 | | 30 | μА | K <sub>0</sub> to K <sub>3</sub> pins, V <sub>IH</sub> =V <sub>DD</sub> =1.8 V | | High Level Input Current | IH2 | 40 | | | μΑ | VCOH, VCOL, XI pins, V <sub>IH</sub> =V <sub>DD</sub> ≈1.8 V | | High Level Input Voltage | V <sub>IH1</sub> | 0.5·V <sub>DD</sub> | | | v | K <sub>0</sub> to K <sub>3</sub> , M pins | | High Level Input Voltage | V <sub>1H2</sub> | 0.8·V <sub>DD</sub> | | | v | CE, M, PA <sub>0</sub> to PA <sub>3</sub> pins | | Low Level Input Voltage | V <sub>IL1</sub> | | | 0.1-V <sub>DD</sub> | v | K <sub>0</sub> to K <sub>3</sub> pins | | Low Level Input Voltage | V <sub>IL2</sub> | | | 0.2·V <sub>DD</sub> | v | CE, M, PA <sub>0</sub> to PA <sub>3</sub> pins | | LCD Drive Voltage | VDD-VSS3 | 3.0 | 3.1 | 3.3 | v | $T_a$ =25 °C, C <sub>1</sub> =0.1 $\mu$ F, C <sub>2</sub> =0.01 $\mu$ F, LCD pin open | | LCD Drive Voltage (Note) | VDD-VSS3 | 2.8 | 3.0 | 3.1 | v | T <sub>a</sub> =25 °C, C <sub>1</sub> =0.1 μF, C <sub>2</sub> =0.001 μF, LCD pin open | | Output Leakage Current | 16 | | | +1 | μΑ | EO <sub>1</sub> , EO <sub>2</sub> pins | # AC CHARACTERISTICS ( $V_{DD}$ = +2.0 to +3.6 V, $T_a$ = -20 to +75 °C) | CHARACTERISTIC | SYMBOL | MIN. | TYP. | MAX. | UNIT | CONDITION | |---------------------|------------------|------|------|------|------|-----------------------------------------------| | Operating Frequency | f <sub>in1</sub> | 0.5 | | 15 | MHz | VCOL pin, MF mode, Vi≂0.1 Vp-p | | Operating Frequency | fin2 | 0.5 | | 40 | MHz | VCOL pin, HF mode, Vi=0.2 Vp-p | | Operating Frequency | fin3 | 10 | | 100 | MHz | VCOH pin, VHF mode, Vi=0.1 Vp-p,<br>M pin=Low | | Operating Frequency | fin4 | 10 | | 130 | MHz | VCOH pin VHF mode, Vi≈0.1 Vp-p,<br>M pin≈High | Note: Ratings listed above are subject to change due to provisional characteristics. # 10. PACKAGE DIMENSIONS (UNIT: mm) 54-pin plastic QFP P54G-85-F NOTE Each lead centerline is located within 0.15 mm (0.006 inch) of its true position (T.P.) at maximum material condition. | ITEM | MILLIMETERS | INCHES | |------|-------------|---------------| | | 13.5104 | 0.531 :8812 | | 8 | 9.5*** | 0.374 ***** | | С | 95.01 | 0.374 ***** | | 0 | 13 5 *** | 0.531 :8817 | | F | 0.5 | 0.020 | | G | 0.85 | 0.033 | | н | 0.301010 | 0.012:888 | | 1 | 0.15 | 0.006 | | J | 0 65 (T P.) | 0.026 (T.P.) | | K | 2.0**2 | 0.079 1888 | | L | 1.2 *** | 0.047 - 888 | | м | 0.15 - 8 48 | 0.006:388 | | N | 0.15 | 0.006 | | P | 1.5:01 | 0.059 : 0 004 | | Q | 0.1 **1 | 0 004 - 0 004 | | R | 0.1 **1 | 0.004 10 004 | | S | 1.8 MAX | 0.071 MAX. | # 54-pin plastic QFP (Straight lead type) #### NOTE Each lead centerline is located within 0.15 mm (0.006 inch) of its true position (T.P.) at maximum material condition | ITEM | MILLIMETERS | INCHES | |------|-------------|--------------| | Α | 14.1 04 | 0.555 *** | | 8 | 95.02 | 0.37410000 | | С | 95.03 | 0.374,0000 | | D | 14 1 -04 | 0.555 : 0016 | | F | 0.5 | 0.020 | | G | 0.85 | 0.033 | | н | 0 30 -0 10 | 0.012 888 | | 1 | 0.15 | 0.006 | | J | 0.85 (T.P.) | 0.026 (T P.) | | K | 23.02 | 0.091:888 | | м | 0 15 8 8 | 0.006:888 | | Р | 1.5-01 | 0.059 **** | | т | 0.5 | 0.020 | | U | 0.85 | 0.033 | # 54-pin plastic QFP (Reverse bent type) ## detail of lead end P54G-85-R # NOTE Each lead centerline is located within 0.15 mm (0.008 inch) of its true position (T.P.) at maximum material condition. | ITEM | MILLIMETERS | INCHES | |------|-------------|---------------| | A | 139'0" | 0 547 - 8016 | | 8 | 95.01 | 0 374 10 900 | | С | 95.41 | 0 374 20 000 | | D | 13.9104 | 0 547 19919 | | F | 0.5 | 0 020 | | G | 0.85 | 0.033 | | н | 0 30 - 0 10 | 0.012 1888 | | i | 0.15 | 0.008 | | J | 0.65 (T P ) | 0.026 (T.P.) | | K | 2.2 **** | 0.079 : 888 | | L | 0.9 * * 2 | 0 047 :888 | | M | 0.15 8 4 | 0.006 : 8285 | | N | 0.15 | 0.006 | | P | 1.5 *** | 0.059 *** *** | | a | 01'0' | 0.004 : 0.004 | | R | 01'0' | 0.004 -0.004 | | s | 1 8 MAX | 0071 MAX | # PACKAGE DIMENSION FOR ENGINEERING SAMPLE (UNIT: mm) 54-pin Ceramic QFP # Note: The length of lead is not fixed, because the tips of the leads are not managed cutting process