#### CMOS 4-BIT MICROCONTROLLER ## TMP47C456AF The 47C456A is a high speed and high performance 4-bit single chip microcomputer based on the TLCS-47 CMOS series. The 47C456A has LCD driver, DTMF generator and large-capacity RAM for repertory dial, which is suitable for application in telephones. The 47C456A has two oscillation circuits. It is possible to switch the operating mode; high speed operation. | PART | No. | ROM | RAM | PACKAGE | PIGGYBACK | |--------|--------|--------------|-------------|---------|-------------| | TMP470 | 1456AF | 4096 x 8-bit | 768 × 4-bit | QFP80 | TMP47C956AG | #### **FEATURES** - ◆4-bit single chip microcomputer - ◆Instruction execution time: 8.3µs (at 960KHz), 244µs (at 32.8KHz) - ◆Low voltage operation: 2.7V min. - ♦90 basic instructions - ◆ Table look-up instructions - ◆ Subroutine nesting: 15 levels max. - ♦6 interrupt sources (External: 2, Internal: 4) All sources have independent latches each, and multiple interrupt control is available. - ◆I/O port (34 pins) - Input 1 port 4 pins I/O 7 ports 27 pins - Output 1 port 3 pins - ♦Interval Timer - ◆Two 12-bit Timer/Counters Timer, event counter, and pulse width measurement mode - ◆Watchdog Timer - ◆ Serial Interface with 4-bit buffer External/internal clock, and leading/trailing edge shift mode - ◆ LCD driver (automatic display) - LCD direct drive (Max.16-digit display at 1/4 duty LCD) - 1/4, 1/3, 1/2 duties or static drive are programmably selectable. - ◆DTMF (Dual Tone Multi Frequency) output - DTMF output with one instruction - Single tone output function - $\Rightarrow$ RAM for repartry dial : 768 $\times$ 4-bit max. - **◆BEEP** output function - ◆ Dual-clock operation High-speed/Low-power-consumption operating mode ◆Real Time Emulator: BM47216A ## PIN ASSIGNMENT (TOP VIEW) #### **BLOCK DIAGRAM** # PIN FUNCTION | PIN NAME | Input/Output | FUNCTIONS | <u> </u> | |------------------------|-----------------|--------------------------------------------------------------------------------|--------------------------------| | K03 - K00 | Input | 4-bit input port | | | R33 ( <del>WTO</del> ) | I/O (Output) | 4-bit I/O port with latch. When used as the input port, the latch must be | Watchdog timer output | | R32 - R30 | 1/0 | set to "1". | | | R43 - R40 | | | | | R53 - R50 | | 4-bit I/O port with latch. | | | R63 - R60 | 1/0 | When used as the input port, the latch must be s | et to "1". | | R73 - R70 | | | | | R83 (T1) | | 4-bit I/O port with latch. | Timer/Counter 1 external input | | R82 (ĪNT1) | | When used as the input port, external | External interrupt 1 input | | R81 (T2) | !/O (Input) | interrupt input pin, or timer/counter input pin, the latch must be set to "1". | Timer/Counter 2 external input | | R80 (ĪNT2) | | | External interrupt 2 input | | R92 (ŠČK) | 1/0 (1/0) | 3-bit I/O port with latch. | Serial clock I/O | | R91 (SO) | I/O (Output) | When used as the input port or serial port, the latch must be set to "1". | Serial data output | | R90 (\$1) | I/O (Input) | Taker most de set to | Serial data input | | P142 - P141 | Output | 3-bit I/O port with latch | | | P140 (BEEP) | Output (Output) | 3-ort //O port with fatch | BEEP output | | SEG31 - SEG0 | Output | LCD Segment driver output | | | COM4 - COM1 | Jacque | LCD Common driver output | | | TONE | Output | Tone output | | | XIN | Input | Resonator connecting pins (High-frequency). | | | XOUT | Output | For inputting external clock, XIN is used and XOU | T is opened. | | XTIN | Input | Resonator connecting pins (Low-frequency). | | | XTOUT | Output | For inputting external clock, XIN is used and XOU | T is opened. | | RESET | Input | Reset signal input | | | TEST | Input | Test pin for shipping test. Be opened or fixed to lo | ow level. | | VDD | | + 2.7V to 6.0V | | | vss | Power Supply | 0V (GND) | | | VLC | | LCD drive power supply | | #### OPERATIONAL DESCRIPTION Concerning the 47C456A, the configuration and functions of hardwares are described. As the description has been provided with priority on those parts differing from the 47C400A, the technical data sheets for the 47C400A shall also be referred to. #### 1. SYSTEM CONFIGURATION - (1) Data Memory - (2) I/O port - (3) System Clock Controller - (4) Interval Timer - (5) Timer/Counter (TC1, TC2) - (6) Serial Interface - (7) LCD Driver - (8) DTMF Generator - (9) BEEP Output Circuit - (10) Watchdog Timer ## 2. INTERNAL CPU FUNCTION ### 2.1 Data Memory The 47C456A data memory consists of a 768 x 4-bit RAM. First 256 x 4-bit RAM is the same as the data memory built into the 47C400A, so refer to the technical data sheets for the 47C400A for an explanation of the operation. Extended 512 x 4-bit RAM is mainly used for storing repertory dialing data and is controlled by the RAM address register, RAM data buffer register and TONE/RAM command register. Figure 2-1. RAM Block Diagram ## (1) RAM (512 × 4-bit) Address Register The RAM address register is a 9-bit register to specify addresses for the RAM data memory. The upper 1 bit is accessed with port address OP12, the next 4 bits are accessed with the port address OP0B/IP0B and the lower 4 bits are accessed with port address OP0A/IP0A. These registers are initialized to "0" during reset. Figure 2-2. RAM Address Register ## (2) RAM (512 x 4-bit) Data Buffer Register The RAM data buffer register is a 4-bit buffer register to read or write RAM data. When writing data to RAM, it is accessed as port address OPOC. Port address IPOC is used for access when reading data from RAM. Figure 2-3. RAM Data Buffer Register #### (3) RAM (512 × 4-bit) Command Register The RAM command register (OPOD/IPOD) controls the reading or writing data, and whether RAM is to be accessed or put in stand-by mode. This register is accessed as the port address OPOD/IPOD. The RAM command register is also used as the TONE command register. Figure 2-4. RAM Command Register ### 2.1.1 Access for RAM (512 $\times$ 4-bit) To write data to RAM; load the address into the RAM address register and the data into the RAM data buffer register (OPOC), then put the RAM command register in the write mode. The data will be written to the specified RAM address by this operation. The data are latched in the RAM data buffer register, therefore, RAM data buffer register operation is not necessary when the same data are written continuously. To read data from RAM, set the RAM command register to the read mode and load the address into the RAM address register, then read the data via RAM data buffer register (IPOC). Data are not latched in the RAM data buffer register. ``` Example 1: To write data "9" to address 182H and data "7" to address 15AH in RAM. LD A,#1 ; Sets data "182H" to RAM address register. OUT A,%OP12 #8,%OPQB OUT OUT #2,%OP0A OUT #9,%OPOC ; Writes data "9" to RAM data buffer register. OUT #0011B,%OP0D ; Sets RAM to write mode. OUT #0010B,%OP0D ; Sets RAM to stand-by mode. OUT #5,%OP0B ; Sets data "15AH" to RAM address register. OUT #0AH,%OPOA OUT ; Writes data "7" to RAM data buffer register. #7.%OPOC OUT #0011B,%OP0D ; Sets RAM to write mode. OUT #0010B,%OP0D ; Sets RAM to stand-by mode. Example 2: To write data "0" to address 120H through 127H in RAM. OUT #0,%OPOC ; Writes data "0" to RAM data buffer register. LD A,#0 ; Sets data "120H" to RAM address register. OUT #1,%OP12 OUT #2,%OP0B OUT A,%OPOA OUT #0011B,%OP0D : Sets RAM to write mode. SLOOP : CMPR A,#7 ; Increases address register. TESTP ZF В SWEND INC OUT A,%OPOA BR SLOOP. SWEND : OUT #0010B,%OP0D ; Sets RAM to stand-by mode. Example 3: To read data from address OB1H in RAM and store to Accumulator. OUT #0001B,%OP0D ; Sets RAM to read mode. LD A,#0 ; Sets data "OB1H" to RAM address register OUT A,%OP12 OUT #0BH,%0P0B OUT #1,%OP0A IN %IPOC,A ; Reads data from RAM and stores to Accumulator. ``` ## 3. PERIPHERAL HARDWARE FUNCTION #### 3.1 I/O Ports The 47C456A has 9 ports (34 pins) each as follows: (i) K0 ; 4-bit input (2) R3 ; 4-bit input/o (2) R3 ; 4-bit input/output (3) R4, R5, R6, R7 ; 4-bit input/output 4 R8 ; 4-bit input/output (shared by external interrupt input and timer/counter input) (5) R9 ; 3-bit input/output (shared by serial port) (6) P14 : 3-bit output (P140 is shared by REEP output 6 P14 ; 3-bit output (P140 is shared by BEEP output) The port K0, R3 and P14 of the 47C456A differ from those of the 47C400A. The 47C456A does not have the port P1 and P2. Table 3-1 lists the port address assignments and the I/O instructions that can access the ports. #### (1) Port K0 (K03-K00) The 4-bit input port with pull-up resistors. Figure 3-1. Port K0 ### (2) Port R3 (R33-R30) The 4-bit I/O port with latch. When used as an input port, the latch must be set to "1". The latch is initialized to "1" during reset. Figure 3-2. Port R3 #### (3) Port P14 (P142-P140) The 3-bit output port with latch. The latch is initialized to "1" during reset. The pin P140 is shared by the BEEP output. When used as the BEEP output, the latch must be set to "1". Figure 3-3. Port P14 | t od | Por | Ţ | | | Input/Ou | Input/Output instruction | tion | | | |-----------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|------------|--------------------------|------------------------|---------------|----------------------------| | address<br>(**) | Input (IP**) | Output (OP**) | IN %p, A<br>IN %p, @HL | OUT A, %p<br>OUT@HL, %p | OUT #k, %p | OUTB @HL | SET %p, b<br>CLR %p, b | TEST %p, b | SET @L<br>CLR @L<br>TEST@L | | 00 | troo troo. CX | | | | | 1 | | | | | T , | | | )( | ( | ( | ( | . ( | ) ( | | | | KOW register | ROW register | ) | ) | j | (Anora) | ) | j | ı | | 02 | COLUMN register | COLUMN register | 0 | Ö | 0 | ( ) | () | ( ) | ı | | 03 | R3 input port | R3 output port | 0 | O | $\bigcirc$ | ı | 0 | () | ı | | 04 | R4 input port | R4 output port | С | · ( ) | С | ı | (C) | () | 0 | | 70 | troot troots | B5 out out | ) ( | ) ( | ( | | ) C | ι(, | C | | 50 | | 100000000000000000000000000000000000000 | )( | )( | )( | 1 | )( | )( | )( | | 90 | Re input port | Re output port | )( | )( | )( | ı | )( | )( | )( | | 07 | R7 input port | R7 output port | 0 | 0 | 0 | ļ | 0 | $\overline{}$ | Э | | 80 | R8 input port | R8 output port | 0 | 0 | 0 | 1 | () | $\overline{}$ | ı | | 60 | R9 input port | R9 output port | 0 | $\bigcirc$ | 0 | ì | $\bigcirc$ | $\bigcirc$ | í | | 0A | RAM address register | RAM address register | 0 | () | 0 | 1 | () | () | ı | | 90 | RAM address register | RAM address register | 0 | () | 0 | 1 | $\bigcirc$ | () | ı | | JU. | RAM data buffer register | RAM data buffer register | C | С | ·C | 1 | С | C | 1 | | | BAM command register | BAM Command register | ) ( | ) ( | ) ( | , | ) | ) ( | | | ) i | CONTRACTOR SEGISCE | יאואן כסוויווופן ומ נבאוזים | )( | ) | ) | ì | ı | )( | ) | | 0E | SIO, SLOW operation status | | )<br> | i | 1 | ł | 1 | .) | ı | | 0F | Serial receive buffer | Serial transfer buffer | 0 | 0 | () | _ | _ | 1 | 1 | | 10 <sub>H</sub> | Undefined | | 1 | 1 | | | i | | | | = | Undefined | | 1 | ı | ı | ı | ı | ı | ı | | 12 | Undefined | RAM address register | ı | 0 | i | 1 | ı | ì | 1 | | 13 | Undefined | BEEP output control | l | 0 | ı | 1 | ı | ı | ı | | 14 | Undefined | P14 output port | 1 | 0 | ı | • | ı | , | ı | | 15 | Undefined | Watchdog Timer control | 1 | () | 1 | ı | ı | 1 | ı | | 16 | Undefined | System clock control | 1 | 0 | ı | 1 | ı | ı | 1 | | 17 | Undefined | | ١ | ı | ı | ı | ı | ı | 1 | | 18 | Undefined | | 1 | i | 1 | 1 | ı | ı | 1 | | 19 | Undefined | Interval Timer interrupt control | j | 0 | ı | f | ı | ı | 1 | | 1 | Undefined | A PARTICIPATION OF THE PARTICI | ı | i | ı | 1 | ı | 1 | 1 | | 18 | Undefined | LCD drive control | 1 | 1 | 1 | 1 | 1 | 4 | ı | | 7 | Undefined | Timer/Counter 1 control | 1 | () | 1 | ı | ı | ı | 1 | | 01 | Undefined | Timer/Counter 2 control | ı | 0 | ı | ı | 1 | ı | ı | | 핃 | Undefined | | 1 | 1 | 1 | ı | ı | ı | 1 | | 16 | Undefined | Serial interface control | _ | $\odot$ | - | - | - | - | 1 | The 5-bit to 8-bit data conversion instruction [OUTB @HL], automatic access to ROW register and COLUMN register. "---" means the reserved state. Unavailable for the user program. Note 1. Note 2. Table 3-1. Port Address Assignments and Available I/O Instructions ## 2.2 System Clock Controller The 47C456A has two oscillation circuits with a high-frequency clock and a low-frequency clock. Power consumption can be decreased by switching to low-speed operation using the low-frequency clock when necessary (dual clock operation). The high-frequency clock can be obtained by connecting an oscillator to the XIN and XOUT pins; the low-frequency clock can be obtained by connecting the oscillator to the XTIN and XOUT pins. ## 2.2.1 Circuit Configuration Figure 2-4 shows the configuration of system clock controller. Figure 3-4. System Clock Controller # 2.2.2 Dual Clock Operation Controller Dual clock operation involves two modes: Normal operating mode using the high-frequency clock, and SLOW operating mode using the low-frequency clock. Both oscillators start operating when the power is turned on, after which the Normal operation is selected automatically. The high-frequency clock stops oscillating when a command is issued to switch to the SLOW operation. Operating mode switching is performed using the command register (OP16). The status of the low-frequency clock and the current operating mode can be monitored using the status register (IPOE). Figure 3-5 shows the operating mode transitions, and Figure 3-6 shows the command and status registers. ### (1) Operating Mode Transmission Figure 3-5. Operating Mode Transmission Diagram ## (2) Operating Mode Control System clock control command register (Port address OP16) LF DWUT (Initial value 0000) Selects operating mode 00: Normal operating mode 01: SLOW operating mode 1\*: Reserved Sets warm up time (Example) At fs = 32.768KHz 00: Reserved Note 1. + ; don't care 01: 28/fs 7.8 Note 2. fs; Low-frequency clock [Hz] 1\*: 211/fs 62.5 System clock control status register (Port address IPOE) 2 1 (SIQF) (SEF) SMF SLS Figure 3-6. Command register and Status register - Note 1. The following operations and functions cannot be used in the SLOW operation; therefore, this must be taken into consideration in programming. - ① Timer/Counter 4096Hz (at fs = 32.8kHz) count operation (can be used with other count rates). - ② Interval timer interrupt 4096Hz (at fs = 32.8kHz) operation (can be used with other timer rates). - 3 Serial Interface - (4) VFT drive circuit - Note 2. The power consumption of the oscillator and internal hardware is decreased in the SLOW operation, but power consumption through pin interfaces (dependent on the external circuitry and program) may prevent overall low power consumption operation; therefore, caution is necessary during system design and interface circuit design. ## (3) Operation mode switching The following procedure is used to switch between the Normal operation and the SLOW operation. The Normal operation is selected during reset. Also, the current operating mode can be checked by monitoring SLS (status register bit 0). a. Switching from Normal operation to SLOW operation After monitoring SMF (status register bit 1) by program and confirming that the low-frequency clock is stable, set bit 2 of the command register to "1". The high-frequency clock will then stop. Also, after switching from Normal operation to SLOW operation (accessing the command register), execute the NOP (No Operation) instruction. #### b. Returning from SLOW operation to Normal operation When bit 2 of the command register is cleared to "0", the warm-up time must be set in DWUT. When the set warm-up time elapses, operation is switched to the Normal operation. Example 1 : Normal operation → SLOW operation SSMF: TEST %IP0E, 1 : TEST %IPOE, 1 ; To wait until SMF goes to "1" B SSMF LD A, #0100B ; Selects SLOW operating mode OUT A, %OP16 NOP ; No operation Example 2 : SLOW operation → Normal operation : LD A, #0001B; Selects Normal operation and sets warm-up OUT A, %0P16 time (7.8ms) High-freq. clock (XOUT) Basic clock Normal operation Changed to the SLOW operation Operating mode by program. SLS Warm-up operation Operating mode by program. Figure 3-7. System Clock Switching Timing TOSHIBA TMP47C456A/956A #### 3.3 Interval Timer ## 3.3.1 Configuration of Interval Timer The interval timer is configured with a 15-stage binary counter and inputs the oscillation circuit output (fs) for the low-frequency clock; therefore, the final stage output is fs/2<sup>15</sup> [Hz]. This interval timer is cleared to "0" during reset. Also, "fs" is input directly into the interval timer; therefore, the interval timer interrupts, timer/counter and LCD driver will not operate normally if the low-frequency oscillation is not stable. Figure 3-8. Interval Timer ## 3.3.2 Interval Timer Interrupt (ITMR) Constant-frequency interrupts can be generated using the interval timer, Four different frequencies can be selected for interval timer interrupts using the command register (OP19). The command register is also initialized to "0" during reset. An interval timer interrupt is generated at the first rising edge of the binary counters output after the command is set to the command register. Figure 3-9. Command Register #### 3.4 Timer/Counter The timer/Counter of the 47C456A is operated by a low-frequency clock (fs); therefore, the following operating frequencies differ from those of the 47C400A. - (1) Internal pulse rate. - 2 Maximum frequency applied in the event counter mode. - ③ Drop ratio of instruction execution time when the timer is used. ## (1) Internal pulse rate The intrnal pulse rates shown in Table 3-2 can be selected by setting the values of the lower 2 bits of the TC1 and TC2 control command registers (OP1C, OP1D). | The values of lower 2 bits | | | | | At fs = 32 | 2.768KHz | |----------------------------|---------------------|-----------|----------------------|---------|---------------------|-------------------| | (bit1, 0) | Internal pu | ilse rate | Max. settii | ng time | Internal pulse rate | Max. setting time | | 00 | fs / 23 | [Hz] | 215 / fs | [sec] | 4096 [Hz] | 1 [sec] | | 01 | fs / 2 <sup>7</sup> | | 219 / fs | | 265 | 16 | | 10 | fs / 211 | | 2 <sup>23</sup> / fs | | 16 | 256 | | 11 | fs/215 | | 2 <sup>27</sup> / fs | | 1 | 4096 | Table 3-2. Internal Pulse Rate (2) Maximum frequency applied in the event counter mode. | | | Г | Norn<br>operat<br>mod | | — SLOW operating | / —<br>mode | $\neg$ | |----|------------------------|-----|-----------------------|------|------------------|-------------|--------| | a. | In 1-channel operation | | fc/32 | [Hz] | fs / 32 | [Hz] | | | b. | In 2-channel operation | TC1 | fc/32 | | fs/32 | | | | | | TC2 | fc/40 | | fs / 40 | | | (3) Drop ratio of instruction execution time when the timer is used. With the 47C456A, count operation is inserted in the ratio of once per [(basic clock frequency) /23] / (internal pulse rate ) instruction cycle; therefore, execution speed drops as follows: Example 1: When fc = 960KHz and fs = 32.8kHz in the Normal operation and the internal pulse rate fs/ $2^3$ is selected, count operation is inserted once per each cycle of 29 instructions; therefore, there is a drop of 100/28 = 3.57% for an instruction execution speed of $8.3\mu s$ . Example 2: When fs = 32.8kHz in the SLOW operation, and the internal pulse rate fs/211 is selected, count operation is inserted once per each cycle of 256 instructions; therefore, there is a drop of 0.39% for an instruction execution speed of 244µs. In addition, when the basic clock is obtained from "fs" (SLOW operation), count operation cannot be used with an internal pulse rate of fs/23. ## 3.5 Serial Interface When operating using the internal clock, fs/2<sup>2</sup> [Hz] is used as the serial clock. Consequently, when operating at fs = 32.768kHz, the maximum transfer rate is 8192bit/sec. When the reading and writing of serial data cannot follow this clock rate, the serial clock is automatically stopped and the next shift operation stands by untill the processing is completed. External clock can be used in the same way as for the 47C400A. The serial interface cannot be used in the SLOW operating mode. #### 3.6 LCD Driver The 47C456A has circuit that directly drives the Liquid Crystal Display (LCD) and its control circuit. The 47C456A has the following connecting pins with: ${\mathfrak D}$ Segment output 32 pins (SEG31 - SEG1) 2 Common output 4 pins (COM4 - COM1) In addition, VLC pin is provided as the drive power pin. The devices that can be directly driven is selectable from LCD devices of following drive methods: 1/4 duty (1/3 bias) LCD 1/3 duty (1/3 bias) LCD 1/3 duty (1/3 bias) LCD 1/2 duty (1/2 bias) LCD Max.96 segments (8 segments x 12 digits) 1/2 duty (1/2 bias) LCD Max.64 segments (8 segments x 8 digits) Static LCD Max.32 segments (8 segments x 4 digits) # 2.6.1 Circuit Configuration Figure 3-10 shows the configuration of the LCD driver. Figure 3-10. Configuration of LCD Driver ## 2.6.2 Control of LCD Driver The LCD driver is controlled by the command register (OP1B). LCD driver control command register (Port address OP1B) 3 2 1 0 EDSP DTY (Initial value 0000) LCD display control 00: Designation of driving methods 01: Blanking 10: Reserved 11: Enables display Selection of driving methods 00: 1/4 duty (1/3 bias) 01: 1/3 duty (1/3 bias) 10: 1/2 duty (1/2 bias) 11: Static Figure 3-11. LCD Driver Control Command Register #### (1) Driving methods of LCD 4 kinds of driving methods can be selected by DTY (bits 1 and 0 of command register). Figure 3-12 shows driving waveforms for LCD. Note. : $f_F$ ; Frame frequency $V_{LCD}$ ; LCD drive voltage ( = $V_{DD}$ – $V_{LC}$ ) Figure 3-12. Driving Waveform for LCD (Voltage between COM-SEG) ### (2) Frame frequency The frame frequency is set according to the driving method and base frequency as shown in Table 3-3. The base frequency is given by the Interval Timer. | | | Frame Frequenc | cy [Hz] | | |-----------------------------------------|-----------|------------------------------------|-----------------------------------|--------------------| | Base Driving<br>Method<br>Frequency[Hz] | 1 / 4duty | 1 / 3duty | 1 / 2duty | static | | fs 29 | fs 29 | $\frac{4}{3} \cdot \frac{fs}{2^9}$ | $\frac{4}{2} \cdot \frac{fs}{29}$ | $\frac{fs}{2^{9}}$ | | At fs = 32.768KHz | 64 | 85 | 128 | 64 | fs; Basic clock frequency [Hz] Table 3-3. Frame Frequency Setting ## (3) LCD drive voltage The LCD drive voltage ( $V_{LCD}$ ) is obtained from the difference in potential ( $V_{DD}$ - $V_{LC}$ ) between pins VDD and VLC. Thus, when the CPU operating voltage and LCD drive voltage are the same, the VLC pin is connected to the VSS pin. The LCD light only when the difference in potential between the segment output and common output is $\pm V_{LCD}$ , and turn off at all other times. During reset, the power switch of the LCD driver is turned off automatically, shutting off the VLC voltage. Both the segment output and common output become V<sub>DD</sub> level at this time and the LCD turn off The power switch is turned on to supply VLC voltage to the LCD driver by setting EDSP (bits 2 and 3 of the command register) to " $11_B$ ". After that, the power switch will not turn off even during blanking (setting EDSP to " $01_B$ ") and the VLC voltage continues to flow. ## 3.6.3 LCD Display Operation ### (1) Display data setting Display data are stored to the display data area (Max. 32 words) in the data memory. The display data stored to the display data area are read automatically and sent to the LCD driver by the hardware. The LCD driver generates the segment signals and common signals in accordance with the display data and drive method. Thus, display patterns can be changed by merely overwriting the contents of the display data area with a program. The table look-up instruction is mainly used for this overwriting. Figure 3-13 shows the correspondence between the display data area and the SEG/COM pins. The LCD light when the display data is "1" and turn off when "0". The number of segment which can be driven differs depending on the LCD drive method; therefore, the number of display data area bits used to store the data also differs (Refer to Table 3-4). Consequently, data memory not used to store display data and data memory for which the addresses are not connected to LCD can be used to store ordinary user's processing data. | Driving Method | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |----------------|-------|-------|-------|-------| | 1 / 4 duty | СОМ4 | сомз | COM2 | сом1 | | 1 / 3 duty | - | сомз | COM2 | COM1 | | 1 / 2 duty | • | - | COM2 | сом1 | | Static | - | - | - | сом1 | Figure 3-13. Display Data Area and SEG/COM Note. – ; This bit is not used for display data. Table 3-4. Driving Method and Bit for Display Data ### (2) Blanking Blanking is applied by setting EDSP to "01<sub>B</sub>" and turns off the LCD by outputting the non light operation level to the COM pin. The SEG pin continuously outputs the signal level in accordance with the display data and drive method. At static drive, no voltage is applied between the COM and SEG pins when the LCD is turned off by data (display data cleared to "0"), but the COM pin output becomes constant at the $V_{LCD}/2$ level when turning off the LCD by blanking, so the COM and SEG pins are then driven by $V_{LCD}/2$ . ## 3.6.4 Control Method of LCD Driver ## (1) Initial Setting Flow chart of initial setting is shown in Figure 3-14. Example: Driving of 1 / 4duty LCD LD A, #0000B; Sets 1/4 duty drive OUT A, %0P1B ; Initializes display data area ; LD A, #1100B; Enable display (Relese of blanking) OUT A, %0P1B : 100290 ## (2) Display Data Normally, display data are kept permanently in the program memory and are then stored to the display data area by the table look-up instruction. This can be explained using numerical display with 1/4 duty LCD as an example. The COM and SEG connections to the LCD are the same as those shown in Figure 3-15 and the display data are as shown in Table 3-5. Programming example for displaying numerals corresponding to BCD data stored at address $10_H$ in the data memory is shown below. The display data area is at addresses $20_H$ and $21_H$ . ``` LD HL, #0FCH ; Sets the data counter LD A, 10H ST A, @HL+ ST #DTBL/16 ,@HL+ ST #DTBL/256,@HL+ LD HL, #20H ; Stores display data LDL A. @DC ST A, @HL+ A, @DC+ LDH ST A, @HL+ ``` DTBL: DATA 11011111B, 00000110B, 11100011B, 10100111B, 00110110B, 10110101B, 11110101B, 00010111B, 11110111B | Numeral | Display | Displa | y data | Numeral | Display | Displa | y data | |------------|------------|--------|--------|---------|---------|--------|--------| | 1401116141 | | Upper | Lower | Numera | 5,55,63 | Upper | Lower | | 0 | Ū. | 1101 | 1111 | 5 | 5 | 1011 | 0101 | | 1 | 1 | 0000 | 0110 | 6 | E | 1111 | 0101 | | 2 | | 1110 | 0011 | 7 | 7 | 0001 | 0111 | | 3 | | 1010 | 0111 | 8 | | 1111 | 0111 | | 4 | <b>L</b> [ | 0011 | 0110 | 9 | | 1011 | 0111 | Table 3-5. Example of Display Data (1/4 Duty) Table 3-6 shows the same numerical display used in Table 3-5, but using 1/2 duty LCD. The connections of the COM and SEG pins to the LCD are the same as those shown in Figure 3-17. Programming example for displaying numerals corresponding to BCD data stored at address $10_{\rm H}$ in the data memory is shown below. The display data area is at addresses 20 through $23_{\rm H}$ . ``` LD HL, OFCH ; Sets the data counter LD A, 10H ST A, @HL+ ST #DTBL/16, @HL+ ST #DTBL/256, @HL+ LD HL, #20H ; Stores display data LDL A, @DC ST A, @HL+ RORC RORC Α ST A, @HL+ A, @DC+ LDH ST A, @HL+ RORC Α RORC ST A, @HL+ ``` DTBL: DATA 01110111B, 00100010B, 10010111B, 10100111B, 11100010B, 111100101B, 11110111B, 11110111B | Num | | Displa | y data | | Num | | Displa | y data | | |------|-------|--------|--------|-------|------|-------|--------------|---------------|--------------| | eral | Upper | | i | Lower | eral | Upper | | | Lower | | 0 | **01 | **11 | **01 | **11 | 5 | **11 | **10 | **01 | <b>*</b> *01 | | 1 | **00 | **10 | **00 | **10 | 6 | **11 | **11 | * <b>*</b> 01 | **01 | | 2 | **10 | **10 | **01 | **11 | 7 | **01 | <b>*</b> *10 | **00 | **11 | | 3 | **10 | **01 | **01 | **11 | 8 | **11 | **11 | **O1 | **11 | | 4 | **11 | **10 | **00 | **10 | 9 | **11 | **10 | **01 | **11 | Note. \*; don't care Table 3-6. Example of Display Data (1/2 Duty) Figure 3-16. 1/3 Duty (1/3 Bias) Drive Figure 3-15. 1/4 Duty (1/3 Bias) Drive Figure 3-18. Static Drive #### 3.7 DTMF Generator The 47C456A has a DTMF (Dual Tone Multi Frequency) generator which generates dialing signals for tone dialing type telephones. There are two groups of tone dial signals, one group of 4 sine wave low frequencies and another group of 4 sine wave high frequencies. All of these frequencies can be selected individually and combined with a frequency from the other group for a total of 16 different DTMF composite waves. ## 3.7.1 Configuration of DTMF Generator Figure 3-19 shows configuration of the DTMF generator. The 47C456A generates two stepped, quasi sine waves for tone dial signals which can be combined and output. The high or low group of frequencies is selected by setting frequency selection codes into the ROW and COLUMN registers. Figure 3-19. Configuration of DTMF Generator #### 3.7.2 Control of DTMF Generator Tone output is controlled by ROW register (OP01/IP01) and COLUMN register (OP02/IP02). And single tone is controlled by TONE command register (OP0D/IP0D). ROW register, COLUMN register and TONE command register are initialized to "0" during reset. TONE command register (Port address OP0D/IP0D) Figure 3-20. TONE command register Figure 3-21. ROW, COLUMN Register Tones are outputted by loading the frequency selection codes shown in Figure 3-21 into the ROW and COLUMN registers. In the enable mode of single tone output and either ROW or COLUMN register is disabled, another register remains to be enabled, and so single tone can be outputted, by loading an ineffective code into the register. When both the registers are enabled, dual tone can be outputted. In the disable mode of single tone output, effective codes are loaded into both ROW and COLUMN registers and then dual tone can be outputted. At this time, an ineffective code is loaded into ROW or COLUMN register and then the 47C456A has no tone output signal. The [OUTB @HL] instruction can set 8-bit data into both registers (the upper 4 bits of the ROM data go to the COLUMN register and the lower 4 bits go to the ROW register) at the same time, and DTMF signal is outputted without single tone output. ``` Example 1: To output 1481.5Hz single tone ``` OUT #8,%0P0D; Sets the enable mode of single tone output. OUT #0,%0P01; Sets an ineffective code into ROW register. OUT #4,%0P02; Sets data "4" into COLUMN register Example 2:8 bits data corresponding to the 5 bits of data linking the content of carry flag and the contents of data memory RAM address 90<sub>H</sub> are read from the ROM, frequency selection codes are loaded into ROW and COLUMN registers, and dual tone is outputted. LD HL,#90H; HL←90<sub>H</sub> (Sets the address of the data memory) OUTB GHL; Sets the ROM data into the ROW and COLUMN register. 100290 Table 3-7 shows the corresponding frequency selection codes of the ROW and COLUMN registers for the telephone dial keys. Table 3-8 shows the deviation between the 47C456A tone output frequency and standard frequency. | | | COLUMN register (OP02 / IP02) | | | | |--------------|--------------------------|-------------------------------|----------------|----------------|--| | | Frequency selection code | 0001<br>(1209) | 0010<br>(1336) | 0100<br>(1477) | | | | 0001 (697) | 1 | 2 | 3 | | | | 0010 (770) | 4 | 5 | 6 | | | ROW register | 0100 (852) | 7 | 8 | 9 | | | (OP01/IP01) | 1000 (941) | * | 0 | # | | | | | Standa | rd telephone d | ial key | | Contents of ( ) are standard frequencies, unit: Hz Table 3-7. Corresponding frequency selection codes of the ROW and COLUMN registers for the telephone dial keys | | | | | ROW Tone | | | |--------|--------------|-------------|-----------|----------------------------|-------------------------------|------------------| | Freque | ncy sel<br>2 | ection<br>1 | code<br>0 | Tone output frequency [Hz] | Standard<br>frequency<br>[Hz] | Deviation<br>[%] | | 0 | 0 | 0 | 1 | 697.7 | 697 | + 0.10 | | 0 | 0 | 1 | 0 | 769.2 | 770 | - 0.10 | | 0 | 1 | 0 | 0 | 857.1 | 852 | + 0.60 | | 1 | 0 | 0 | 0 | 937.5 | 941 | - 0.37 | | | | | | COLUMN Tone | | | |--------|---------|---------|-----------|----------------------------|-------------------------------|---------------| | Freque | ncy sel | lection | code<br>0 | Tone output frequency [Hz] | Standard<br>frequency<br>[Hz] | Deviation [%] | | 0 | 0 | 0 | 1 | 1212.1 | 1209 | + 0.26 | | 0 | 0 | 1 | 0 | 1333.3 | 1336 | - 0.20 | | 0 | 1 | 0 | 0 | 1481.5 | 1477 | + 0.30 | | 1 | 0 | 0 | 0 | 1621.6 | 1633 | - 0.70 | Table 3-8. Tone output frequencies and Deviation from standard of 47C456A TOSHIBA TMP47C456A/956A ## 3.7.3 Test mode for tone output The 47C456A includes a test mode for checking tone output waveforms. Tones can be outputted by the circuit shown in Figure 3-22. ROW data are inputted from the port R6 and COLUMN data are inputted from the port R3, and any desired single or dual tones can be outputted by setting the frequency selection codes shown in Figure 3-21. Figure 3-23 shows a single tone waveform and Figure 3-24 shows a dual tone waveform. #### 3.8 BEEP Output Circuit BEEP output circuit generates square wave in the audible frequency range. This circuit can drive the key input confirmation tone generator circuit for telephone applications. BEEP output is from the P140 (BEEP) pin. This pin is for both P140 output and BEEP output. Set the P140 output latch to "1" for BEEP output. ## 3.8.1 BEEP Output Circuit Configuration Figure 3-25 shows the BEEP output circuit configuration. The clock pulse of BEEP output circuit is supplied by an interval timer. BEEP output is controlled by frequency selection and output enable/disable setting. Figure 3-25. BEEP Output Circuit Configuration and Timing Chart ## 3.8.2 Control of BEEP Output BEEP output is controlled by the command register (OP13). BEEP Output Control command register (Port address OP13) Figure 3-26. BEEP Output Control Command Register TOSHIBA TMP47C456A/956A ### 3.9 Watchdog Timer (WDT) The purpose of the watchdog timer is detect the malfunction (runaway) of program due to external noise or other causes and return the operation to the normal condition. The watchdog timer output is output to R33 (WTO) pin. When the watchdog timer is used, the output latch of R33 must be set to "1". Further, during reset, the output latch of R33 is set to "1", and the watchdog timer becomes disable sate. The initialization at time of runaway will become possible when the WTO pin and RESET pin are connected each other. ## 3.9.1 Configuration of Watchdog Timer The watchdog timer consists of 10-stage binary counter, flip-flop (F/F), and its control circuit. The F/F is set to "1" during reset, and cleared to "0" at the rising edge of the binary counter output. Figure 3-27. Configuration of Watchdog Timer ## 3.9.2 Control of Watchdog Timer The watchdog timer is controlled by the command register (OP15) . This command register is initialized to " $1000_B$ " during reset. The following are procedure to detect the malfunction (runaway ) of CPU by the watchdog timer. - (1) At first, detection time of the watchdog timer should be set and binary counter should be cleared. - ② The watchdog timer should be become enable - 3 Binary counter must be cleared before the detection time of the watchdog timer. When the malfunction of CPU is taken place for some reason and binary counter is not cleared, the F/F is cleared to '0" at the rising edge of the binary counter and signal of malfunction detection is become active (WTO output is "L"). Note. It is necessary to clear the binary counter prior to enabling watchdog timer. Further, when switching the system clock, it is necessary to halt the watchdog timer during the warm-up time at changing from the SLOW operating mode the Normal operating mode. Figure 3-28. Command Register Example : To set to the watchdog detection time (63 $\times$ 28 / fs [sec] ). And to enable the watchdog timer. LD A, #0010B ; OP15 $\leftarrow$ 0010B ## **ELECTRICAL CHARACTERISTICS** ABSOLUTE MAXIMUM RATINGS $(V_{SS} = 0V)$ | PARAMETER | SYMBOL | PINS | RATING | UNIT | |--------------------------------|-------------------|----------------------------|--------------------------------|------| | Supply Voltage | V <sub>DD</sub> | | - 0.5 to 7 | V | | Supply Voltage (LCD drive) | V <sub>LC</sub> | | - 0.5 to V <sub>DD</sub> + 0.5 | V | | Input Voltage | V <sub>IN</sub> | | - 0.5 to V <sub>DD</sub> + 0.5 | V | | Output Voltage | V <sub>OUT1</sub> | Except sink open drain pin | - 0.5 to V <sub>DD</sub> + 0.5 | | | | V <sub>OUT2</sub> | Sink open drain pin | - 0.5 to 10 | 7 | | Output Current (per 1 pin) | lout | | 3.2 | mA | | Power Dissipation [Topr = 70℃] | PD | | 600 | mW | | Soldering Temperature (time) | T <sub>sld</sub> | | 260 (10sec) | τ | | Storage Temperature | T <sub>stg</sub> | | - 55 to 125 | TC | | Operating Temperature | Topr | | - 30 to 60 | ъ | RECOMMENDED OPERATING CONDITIONS $(V_{SS} = 0V, T_{opr} = -30 \text{ to } 60^{\circ}\text{C})$ | PARAMETER | SYMBOL | PINS | CONDITIONS | Min. | Max. | UNIT | |---------------------------------|------------------|-------------------------|----------------------------------------------|------------------------|------------------------|------| | | | | In the Normal mode | 2.7 | | | | Supply Voltage | V <sub>DD</sub> | | In the SLOW mode | 2.7 | 6.0 | V | | | V <sub>IH1</sub> | Except Hysteresis Input | | | | - | | Input High Voltage | V <sub>1H2</sub> | Hysteresis Input | V <sub>DD</sub> ≥ 4.5V | V <sub>DD</sub> × 0.75 | V <sub>DD</sub> | V | | | V <sub>1H3</sub> | | V <sub>DD</sub> < 4.5V V <sub>DD</sub> × 0.9 | | | | | | V <sub>IL1</sub> | Except Hysteresis Input | | | $V_{DD} \times 0.3$ | | | Input Low Voltage | V <sub>IL2</sub> | Hysteresis Input | V <sub>DD</sub> ≥ 4.5V | 0 | V <sub>DD</sub> × 0.25 | V | | | V <sub>IL3</sub> | | V <sub>DD</sub> < 4.5∨ | | V <sub>DD</sub> × 0.1 | | | Clock Frequency<br>(High freq.) | fc | XIN, XOUT | | 960 | | KHZ | | Clock Frequency<br>(Low freq.) | fs | XTIN, XTOUT | | 30.0 | 34.0 | KHZ | Note . Input Voltage $V_{IH3}$ , $V_{IL3}$ : in the SLOW mode D.C. CHARACTERISTICS $(V_{SS} = 0V, T_{opr} = -30 \text{ to } 60^{\circ}\text{C})$ | PARAMETER | SYMBOL | PINS | CONDITIONS | Min. | Тур. | Max. | UNIT | |--------------------------------------|-------------------|------------------------------------|--------------------------------------------------------------------------------|------|------|------|------| | Hysteresis Voltage | V <sub>HS</sub> | Hysteresis Input | | _ | 0.7 | - | v | | Input Current | I <sub>IN1</sub> | Port K0, TEST<br>RESET | TEST $V_{DD} = 5.5V$ , | | | ± 2 | μА | | | I <sub>IN2</sub> | Ports R (open drain) | V <sub>IN</sub> = 5.5V / 0V | | | | | | Low Level Input<br>Current | l <sub>IL</sub> | Ports R (push-pull) | $V_{DD} = 5.5V, V_{IN} = 0.4V$ | - | _ | - 2 | mA | | Input Resistance | R <sub>IN1</sub> | Port K0 with pull-up/pull-<br>down | | 30 | 70 | 150 | | | | R <sub>IN2</sub> | RESET | | 100 | 220 | 450 | ΚΩ | | Output Leakage<br>Current | lo | Ports R (open drain) | V <sub>DD</sub> = 5.5V, V <sub>OUT</sub> = 5.5V | - | - | 2 | μΑ | | Output Level High<br>Voltage | V <sub>OH</sub> | Ports R (push-pull) | V <sub>DD</sub> = 4.5V, I <sub>OH</sub> = -200μA | 2.4 | - | - | V | | Output Level Low<br>Voltage | V <sub>OL2</sub> | Except XOUT | V <sub>DD</sub> = 4.5V, I <sub>OL</sub> = 1.6mA | - | 1 | 0.4 | V | | Segment Output<br>Resistance | ROS | SEG pin | | | | | | | Common Output<br>Resistance | R <sub>OC</sub> | COM pin | | - | 20 | _ | ΚΩ | | _ | V <sub>O2/3</sub> | | $V_{DD} = 5V, V_{DD} - V_{LC} = 3V$ | 3.8 | 4.0 | 4.2 | V | | Segment/Common Output Voltage | V <sub>O1/2</sub> | SEG / COM pin | | 3.3 | 3.5 | 3.7 | | | | V <sub>O1/3</sub> | | | 2.8 | 3.0 | 3.2 | | | Supply Current | 100 | | $V_{DD} = 5.5V, V_{LC} = V_{SS}$<br>fc = 960KHz | - | 0.6 | 1.2 | | | (in the Nomal mode) | IDDT | | $V_{DD} = 5.5V$ , $V_{LC} = V_{SS}$<br>fc = 960KHz<br>When tone is oscillating | _ | 2.2 | 3.5 | mA | | Supply Current<br>(in the SLOW mode) | I <sub>DDS</sub> | | V <sub>DD</sub> = 3V, V <sub>LC</sub> = V <sub>SS</sub><br>fs = 32.768KHz | - | 15 | 30 | μА | - Note 1. Typ. values shows those at $T_{opr} = 25$ °C, $V_{DD} = 5V$ . - Note 2. Input Current $I_{IN1}$ : The current through resistor is not included, when the input resistor (pull-up/pull-down) is contained. - Note 3. Output Resistance Ros, Roc: Shows on-resistance at the level switching. - Note 4. V<sub>O2/3</sub>: Shows 2/3 level output voltage, when the 1/4 or 1/3 duty LCD is used. - V<sub>O1/2</sub>: Shows 1/2 level output voltage, when the 1/2 duty or static LCD is used. - V<sub>O1/3</sub>: Shows 1/3 level output voltage, when the 1/4 or 1/3 duty LCD is used. - Note 5. Supply Current $I_{DD}$ : $V_{IN} = 5.3V/0.2V$ - The port KO is open when the input resistor is contained. - The voltage applied to the port R is within the valid range. - Note 6. Supply Current I<sub>DDS</sub>: V<sub>IN</sub> = 2.8V/0.2V. Only low frequency clock is only osillated (connecting - XTIN, XTOUT). $$(V_{SS} = 0V, V_{DD} = 2.7 \text{ to 6.0V}, T_{opr} = -30 \text{ to } 60^{\circ}\text{C})$$ | PARAMETER | SYMBOL | CONDITIONS | Min. | Тур. | Max. | UNIT | |-----------------------------------------|------------------|--------------------|--------------------------|------|------|------| | Instruction Cycle Time | t <sub>cy</sub> | In the Normal mode | 8.3 | 8.3 | | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | l ccy | In the SLOW mode | 235 | | 267 | μs | | High level Clock pulse Width | twcH | | 80 | | | | | Low level Clock pulse Width | twcL | External clock | 80 | - | | ns | | Shift Data Hold Time | t <sub>SDH</sub> | | 0.5t <sub>cy</sub> – 300 | _ | _ | ns | Note. Shift Data Hold Time: External Circuit for SCK pin and SO pin. Serial port (completion of transmission) TONE OUTPUT CHARACTERISTICS $$(V_{SS} = 0V, V_{DD} = 2.7 \text{ to } 6.0V, T_{opt} = -30 \text{ to } 60^{\circ}\text{C})$$ | PARAMETER | SYMBOL | CONDITIONS | Min. | Тур. | Max. | UNIT | |----------------------------------|-------------------|--------------------------------------|------|------|------|-------| | Tone Output Voltage (ROW) | V <sub>TONE</sub> | $RL \ge 10K\Omega$ , $V_{DD} = 2.7V$ | 125 | 185 | 250 | mVrms | | Pre-emphasis High Band (COL/ROW) | РЕНВ | PEHB = 20log (COL/ROW) | 1 | 2 | 3 | dB | | Output Distortion | DIS | | - | | 10 | % | | Frequency Stability | Δf | Except error of osc. frequency | _ | _ | 0.7 | % | RECOMMENDED OSCILLATING CONDITIONS $(V_{SS} = 0V, VDD = 2.7 \text{ to } 6.0V, Topr = -30 \text{ to } 60^{\circ}\text{C})$ 960KHz Ceramic Resonator KBR - 960H3 (KYOCERA) $C_{XIN} = C_{XOUT} = 100pF$ CSB960J21 (MURATA) $C_{XIN} = C_{XOUT} = 220pF$ ## TYPICAL CHARACTERISTICS ## INPUT/OUTPUT CIRCUITRY (1) Control pins Input/Output circuitries of the 47C456A control pins are shown below. | CONTROL PIN | 1/0 | CIRCUITRY | REMARKS | |---------------|-----------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | XIN<br>XOUT | INPUT<br>OUTPUT | OSC. enable R R XIN XOUT | Resonator connecting pins (High frequency) $R = 1K\Omega \text{ (typ.)}$ $R_f = 1.5M\Omega \text{ (typ.)}$ $R_O = 2K\Omega \text{ (typ.)}$ | | XTIN<br>XTOUT | INPUT<br>OUTPUT | R R RO | Resonator connecting pins (Low frequency) $R = 1K\Omega \text{ (typ.)}$ $R_f = 15M\Omega \text{ (typ.)}$ $R_O = 200K\Omega \text{ (typ.)}$ | | RESET | INPUT | R <sub>IN</sub> R | Hysteresis input Pull-up resistor $R_{IN} = 220K\Omega \text{ (typ.)}$ $R = 1K\Omega \text{ (typ.)}$ | | TEST | INPUT | R <sub>IN</sub> & | Pull-down resistor $R_{IN} = 70K\Omega \text{ (typ.)}$ $R = 1K\Omega \text{ (typ.)}$ | # (2) I/O Ports The input/output circuitries of the 47C456A I/O ports are shown below, any one of the circuitries can be chosen by a code (WB, WE, WH) as a mask option. | PORT | I/O | INPUT/OUTPUT CIR | CUITRY and CODE | REMARKS | |----------------------|--------|----------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------| | ко | Input | R <sub>IN</sub> X | Pull-up resistor $R_{IN} = 70K\Omega (typ.)$ $R = 1K\Omega (typ.)$ | | | R3<br>R4<br>R5<br>R6 | 1/0 | WB Initial "Hi-Z" | Initial "High" VDD | Sink open drain or push-pull output R = 1KΩ (typ.) | | R7 | I/O | WB, WE Initial "Hi-Z" | Initial "High" OVDD | Sink open drain<br>or<br>push-pull output<br>R = 1KΩ (typ.) | | R8 | I/O | —————————————————————————————————————— | R R | Sink open drain<br>Initial "Hi-Z"<br>Hysteresis input<br>R = 1KΩ (typ.) | | R9 | I/O | WB, WE Initial "Hi-Z" | Initial "High" OVDD | Sink open drain or push-pull output Hysteresis input R = 1KΩ (typ.) | | P14 | Output | Initial "Hi-Z" | WE, WH Initial "High" | Sink open drain<br>or<br>push-pull output | —This Page Intentionally Left Blank— #### CMOS 4-BIT MICROCONTROLLER ## **TMP47C956AG** The 47C956A, which is equipped with an EPROM as program memory, is a piggyback type evaluator chip used for development and operational confirmation of the 47C456A application systems (programs). The 47C956A is pin compatible with the 47C456A which is mask-programmed ROM device. ## PIN FUNCTION (Top of the package) | PIN NAME | Input / Output | FUNCTIONS | |----------|----------------|-------------------------------| | A11 ~ A0 | Output | Program memory address output | | 17 ~ 10 | Input | Program memory data input | | CF | | Chip enable signal output | | ŌĒ | Output | Output enable signal output | | vcc | Power supply | + 5V (connected with VDD) | | GND | 7 Ovver supply | 0V (connected with VSS) | #### A.C. CHARACTERISTICS | PARAMETER | SYMBOL | CONDITIONS | Min. | Тур. | Max. | UNIT | |--------------------|-----------------|------------------------------------------|------|------|------|------| | Address Delay Time | t <sub>AD</sub> | $V_{SS} = 0V$ , $V_{DD} = 2.7 \sim 6.0V$ | _ | _ | 150 | ns | | Data Setup Time | t <sub>fS</sub> | C <sub>L</sub> = 100pF | 150 | _ | _ | ns | | Data Hold Time | t <sub>IH</sub> | Topr = -30~60℃ | 50 | _ | | ns | ## **NOTES FOR USE** (1) Program memory The program area is shown in Figure 1. Figure 1. Program area ## (2) I/O ports Input/Output circuitries of the 47C956A I/O ports are similar to the code WB of the 47C456A. When this chip is used as evaluator with other I/O code, it is necessary to provide the external resistors. Figure 2. I/O code and external circuity