# SH93420A ## Caller ID Controller with LCD driver #### **Features** - Memory - ROM: 14K x 10 bits Includes: Program code Character/Graphic pattern • RAM: 4K x 4 bits Includes: RAM mapped control registers Memory registers Stack LCD memory Data memory - Subroutine nesting - 16-level subroutine nesting - LCD Controller/Driver - 16 commons x 56 segments - Duty option: 1/8, 1/16 - Bias option: 1/4, 1/516-level contrast control - Ring detector - · Built-in ring detector - FSK demodulator - Compatible with Bell 202 and ITU-T V.23 - Keyboard - 8 x 4 keys maximum - Battery-low detection - · 4-level detection for battery-low - I/O Pins - · 12 general I/O pins - 8 I/O pins shared with LCD common pins - 16 I/O pins shared with LCD segment pins - DTMF Generator - · Built-in low distortion DTMF generator #### **General Description** This chip is a single-chip CMOS 4-bit micro-controller that dedicates to serve the telephone calling identification. To achieve the best performance, it is integrated with one real time clock, two 8-bit timers, one 12-bit Timer, one watch dog timer, one serial I/O, FSK demodulator, Ring detector, DTMF generator and 16 x 56 LCD driver. Up to 36 pins of this chip can be specified as a general I/O. The - Interrupts - 11 interrupts are available - Beeper - · 4 options of frequency for each CPU speed - Timers/Counters - · One Watch dog Timer - One 8-bit Watch Timer/Counter (driven by a standard 32.768KHz crystal oscillator) - One 8-bit programmable Timer/Counter with external clock option - · One 8-bit programmable Timer - One 12-bit programmable Timer - Communication port - 1 high speed serial I/O port - Power-down modes - Stop mode (CPU stop with main oscillator off) - Halt mode (CPU stop with main oscillator on) - Dual Oscillators System - Main oscillator frequency (Fmain): 3.579545MHz crystal/ceramic oscillator - Watch oscillator frequency (Fwatch): 32.768KHz crystal oscillator - Instruction Execution Time - $1.1\mu s$ , $2.2\mu s$ or $4.4\mu s$ (Fmain = 3.58MHz) - Power System - Operating voltage range: For CPU: 2.4V to 5.5V For FSK demodulator: 3.5V to 5.5V - CPU Standby current: 3μA typical for 3V - Package Type - 100-pin QFP package built-in DTMF generator can provide the call back service. Eleven interrupt vectors provide rapid response to internal and external events. Ring detected circuit can work even in STOP mode. Furthermore, it also offers two power consumption modes (STOP and HALT) for energy saving in idle condition. ### **Pin Configuration** ### **Pad Configuration** ### **Block Diagram** ### **Pin Description** | Pin No. | Designation | I/O | Description | |---------|--------------------------|------------|-----------------------------------------------------| | 1 ~ 29 | SEG11~39 | 0 | LCD segment signal outputs | | 30 ~ 33 | SEG40~43 /<br>P8.3~0 | O<br>I/O | LCD segment signal outputs / Port8 | | 34 ~ 37 | SEG44~47 /<br>P7.3~0 | O<br>I/O | LCD segment signal outputs / Port7 | | 38 ~ 41 | SEG48~51 /<br>P6.3~0 | O<br>I/O | LCD segment signal outputs / Port6 | | 42 ~ 45 | SEG52~55 /<br>P5.3~0 | O<br>I/O | LCD segment signal outputs / Port5 | | 46 ~ 49 | KIN3~0 (INT2)/<br>P2.3~0 | I<br>I/O | Keyboard interrupt inputs ( INT2 ) / Port2 | | 50 | WDTEN | - 1 | Enable watch dog timer while connect to High | | 51 | VDD | Р | Power supply input | | 52 | XOUT | 0 | Main oscillator output | | 53 | XIN | I | Main oscillator input | | 54 | TEST | I | Enable TEST MODE 1 when low (For factory used only) | | 55 | XTOUT | 0 | Watch crystal oscillator output | | 56 | XTIN | I | Watch crystal oscillator input | | 57 | RESET | I | System reset input (High active) | | 58 | SCK /<br>P0.0 | I/O<br>I/O | Serial clock I/O /<br>Port0.0 | | 59 | SI /<br>P0.1 | I<br>I/O | Serial data input / Port0.1 | | 60 | SO /<br>P0.2 | O<br>I/O | Serial data output / Port0.2 | | 61 | BUZ /<br>P0.3 | O<br>I/O | Buzzer output (Normal low) / Port0.3 | | 62 | INTO /<br>P1.0 | <br> /O | External interrupt inputs (INT0)/ Port1.0 | | 63 | INT1 /<br>P1.1 | I<br>I/O | External interrupt inputs (INT1) / Port1.1 | | 64 | P1.2 | I/O | Port1.2 | | 65 | INT3 /<br>P1.3 | I<br>I/O | External interrupt input (INT3)/<br>Port1.3 | | 66 | AVDD | Р | Analog power supply input | | 67 | TIP | I | TIP line input pin | | | | | | ### Pin Description (continued) | 69 | AGND | Р | Analog ground | |----------|-------------------------------|---------------|----------------------------------------------------------------------| | 70 | RDET | 1 | Ring detected input pin | | 71 | XRT | 0 | Ring detected output pin (open drain, low active) | | 72 | DTMF | 0 | DTMF signal output pin | | 73 | GND | Р | Ground | | 74 ~ 81 | COM0-7 | 0 | LCD common signal outputs (Keyboard scanning outputs) | | 82 ~ 85 | COM8~11 /<br>P3.0~3 /<br>INT2 | 0<br>I/0<br>I | LCD common signal outputs / Port3 / Keyboard interrupt inputs (INT2) | | 86 ~ 89 | COM12~15 /<br>P4.0~3 | O<br>I/O | LCD common signal outputs / Port4 | | 90 ~ 100 | SEG0~10 | 0 | LCD segment signal outputs | ## Note: All external interrupt inputs would be triggered by any negative-edge signal ### **Absolute Maximum Ratings** | Power Supply Voltage0.5V to 6.0V | |-----------------------------------| | Input Voltage0.5V to VDD+0.5V | | Output Voltage0.5V to VDD+0.5V | | Power Dissipation 0.05W | | Operating Temperature 0°C to 70°C | | Storage Temperature55°C to 135°C | ### Comments Stresses above those listed under **Absolute Maximum Ratings** may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these of any other conditions above specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability. DC Electrical Characteristics (Temperature = 0°C to 70°C, V<sub>DD</sub> = 5.0V±10%, GND = 0V) | Parameter | Symbol | Min. | Тур. | Max. | Unit | Conditions | | | | |-----------------------|------------------|----------------------|-------------------------------|------------------------|--------------------------------|------------------------------------|-------------------------------------------|--|--| | Supply voltage | Vcpu | 2.4 | | 5.5 | V | For all mode with FSK off | | | | | Supply voltage | VFSK | 3.5 | | 5.5 | V | For all mode | e with FSK on | | | | | I <sub>DD1</sub> | | 1.5 | 2 | mA | V <sub>DD</sub> = 5V | Normal mode | | | | Operating current | I <sub>DD2</sub> | | 0.7 | 1.2 | mA | V <sub>DD</sub> = 3V | FSK off, DTMF off | | | | Operating current | I <sub>DD3</sub> | | I <sub>DD1</sub> + 1.6 | I <sub>DD1</sub> + 2.5 | mA | V <sub>DD</sub> = 5V | Normal mode<br>FSK on, DTMF off | | | | | I <sub>DD4</sub> | | I <sub>DD1</sub> + 0.45 | I <sub>DD1</sub> + 1.0 | mA | V <sub>DD</sub> = 5V | Normal mode<br>FSK off, DTMF on | | | | Standby current | ISB1 | | 600 | 900 | μΑ | V <sub>DD</sub> = 5V | Halt mode<br>FSK off, DTMF off<br>LCD off | | | | Startuby Current | ISB2 12 | | 30 | μΑ | V <sub>DD</sub> = 5V Stop mode | | | | | | | Is <sub>B3</sub> | | 3 | 20 | μΑ | V <sub>DD</sub> = 3V | FSK off, DTMF off<br>LCD off | | | | | V <sub>IH1</sub> | 0.9 V <sub>DD</sub> | | V <sub>DD</sub> +0.3 | V | RESET | | | | | Input high voltage | V <sub>IH2</sub> | V <sub>DD</sub> -0.3 | | V <sub>DD</sub> +0.3 | V | XIN, XTIN | | | | | | VIH3 | 0.8 V <sub>DD</sub> | | V <sub>DD</sub> +0.3 | ٧ | All pins exce | ept RESET, XIN & | | | | | VIL1 | -0.3 | | 0.1 V <sub>DD</sub> | V | RESET | | | | | Input low voltage | VIL2 | -0.3 | | 0.3 | V | XIN, XTIN | | | | | , | VIL3 | -0.3 | | 0.2 V <sub>DD</sub> | V | All pins exce | ept RESET, XIN & | | | | Output high voltage | Vон | V <sub>DD</sub> -1.0 | | | V | Output pin v | vithout loading | | | | Output low voltage | Vol | | | 0.6 | V | Output pin v | Output pin without loading | | | | Drive/Sink current of | <b>І</b> он1 | 1.5 | 2.0 | | mA | Voн = 4.0V, | | | | | general output pins | lol1 | -1.5 | -2.0 | | mA | Port0, Port1 | , Port2, Port3 & Port4 | | | | Drive/Sink current of | <b>І</b> он2 | 1.0 | 1.5 | | mA | Voн = 4.0V, | | | | | shared output nine | | mA | Port5, Port6, Port7 and Port8 | | | | | | | | Pull-up resistance 1 | R <sub>UP1</sub> | 130 | 180 | 230 | ΚΩ | Port0, Port1, Port2, Port3 & Port4 | | | | | Pull-up resistance 2 | R <sub>UP2</sub> | 50 | 100 | 150 | ΚΩ | Port5, Port6 | 6, Port7 & Port8 | | | # Analog Electrical Characteristics (Temperature = $0^{\circ}$ C to $70^{\circ}$ C, $V_{DD}$ = $5.0V\pm10\%$ , GND = 0V) | Parameter | Symbol | Min. | Тур. | Max. | Unit | Conditions | |-----------------------------------------------|--------|-----------|------------------------------|-----------------------|-------|---------------------------------------------------| | Single Row Tone Output<br>Amplitude | Vor | 500 | 580 | 650 | mVp-p | With 100KΩ pull-up resister | | Single Column Tone Output<br>Amplitude | Voc | 685 | 760 | 835 | mVp-p | With 100KΩ pull-up resister | | DTMF output distortion | DIS% | | 2 | 5 | % | With 100K $\Omega$ pull-up resister | | DTMF pre-emphasis | Twist | 1 | 2 | 3 | dB | With 100K $\Omega$ pull-up resister | | Tip/Ring input impedance | Rin | 400 | 500 | 600 | ΚΩ | Input frequency = 0 | | Input sensitivity of Tip and Ring | Psig | -48 | <b>–45</b> | | dBm | SNR = 15dB | | Hysteresis of Carrier detected | Нср | | 3 | | dB | SNR = 15dB | | Frequency response of the Band<br>Pass Filter | | | -54<br>0<br>+1<br>-19<br>-35 | | dB | ≤ 60Hz<br>1200Hz<br>2200Hz<br>5000Hz<br>≥ 10000Hz | | Battery detected level | VBAT | VDET -0.3 | | V <sub>DET</sub> +0.3 | V | V <sub>DET</sub> = 2.8V or 3.6V or 4.4V | # AC Electrical Characteristics (Temperature = $0^{\circ}$ C to $70^{\circ}$ C, $V_{DD}$ = $5.0V\pm10\%$ , GND = 0V) | Parameter | Symbol | Min. | Тур. | Max. | Unit | Conditions | |--------------------------------------|------------------|------|----------|------|------|------------------------------------------| | Execution cycle time | Тсүс | 1.1 | | 4.4 | μs | Fmain = 3.58MHz | | Hardware Reset duration | Tres | 2 | | | Тсус | Fmain = 3.58MHz | | CPU start up time from Reset or STOP | Тсри | | 2.5 | 10 | ms | Fmain = 3.58MHz<br>By crystal oscillator | | FSK power up time before data in | $T_{PUD}$ | | 8 | 20 | ms | Psig = 40dBm, SNR = 30dB | | CD delay time | T <sub>CDD</sub> | | 7 | 20 | ms | Psig = 40dBm, SNR = 30dB | | CD hold time | T <sub>CDH</sub> | | 9 | 20 | ms | Psig = 40dBm, SNR = 30dB | | Main oscillator frequency | Fmain | | 3.579545 | | MHz | Crystal or Ceramic oscillator | | Watch oscillator frequency | Fwatch | | 32.768 | | KHz | Crystal oscillator | | Watch oscillator start up time | Tws | | | 1 | Sec | | | Serial clock cycle time | Tsp | 250 | | | ns | | | Serial output data delay time | Tsp | | | 120 | ns | | | Serial input data set up time | Tss | 35 | | | ns | | | Serial input data hold time | Тѕн | 75 | | | ns | | #### **Functional Description** #### **Program memory** This 4-bit CPU can directly access up to 14K words of program memory. Most instruction (except RET & RETI) would complete its operation in one or two execution cycle(s). For instruction RET or RETI, it takes 3 execution cycles to complete the operation of returning from a subroutine. #### Vector address area (\$0000 to \$001F) This chip provides a vector address area for program initialization and interrupt services. They are: #### **ROM MAP** | \$0000 | Vector Address Area | |--------|-----------------------| | \$001F | vector Address Area | | \$0020 | | | | Zero-page Subroutines | | \$003F | | | \$0040 | | | | Overhaus Description | | | System Program | | | | | \$37FF | | #### Random Access Data Memory Resident data memory is organized as 4096 x 4 bits (4096 nibbles). RAM is used for data storage, register storage, stack, and storage of segment data for LCD display RAM. All the interrupt control registers and other special function registers are implemented by means of memory mapping to the internal RAM space. #### **RAM Addressing** Like most CPU structure, data may be accessed either by direct or indirect addressing. Direct addressing is defined by operand itself while indirect addressing is defined by the three registers, V, X and Y. Indirect addressing is more general than direct addressing because only the first 1K data can be accessed by means of direct addressing while the others have no limitation for this. There are 16 special RAM spaces (R0 to R15) that can be accessed directly either by special instruction or the general one. #### **RAM Mapping** This chip employs memory-mapped registers for controlling the system function and on-chip peripherals, such as Interrupts, I/O port, LCD control and Timers. All the control bits and data are defined from address \$000 through \$03F in data memory. #### **RAM MAP** | \$000 | RAM Mapped Register | |-------|-------------------------| | \$040 | Memory Register (R0~15) | | \$050 | Data | | \$100 | LCD Display Area | | \$200 | Stack | | \$240 | | | | Data | | \$FFF | | ### **RAM Mapped Register** | Re | gister | Contents | | | | | | | | | |---------------|--------|---------------------------------|--------------|-----------------------------|--------------|-------------|-----------|--|--|--| | Addr | Name | Description | Bit3 | Bit2 | Bit1 | Bit0 | Attribute | | | | | \$000 | SENSE0 | Sense register 0 | IE0 (s/r/t) | IRQ0 (r/t) | RSP (s/r/t) | IE (s/r/t) | - | | | | | \$001 | SENSE1 | Sense register 1 | IE2 (s/r/t) | IRQ2 (r/t) | IE1 (s/r/t) | IRQ1 (r/t) | - | | | | | \$002 | SENSE2 | Sense register 2 | IET1 (s/r/t) | IRQT1 (r/t) | IET0 (s/r/t) | IRQT0 (r/t) | - | | | | | \$003 | SENSE3 | Sense register 3 | IET2 (s/r/t) | IRQT2 (r/t) | IESI (s/r/t) | IRQSI (r/t) | - | | | | | \$004 | TMOD0 | Timer 0 mode register | TMOD0.3 | TMOD0.2 | TMOD0.1 | TMOD0.0 | W | | | | | \$005 | TMOD1 | Timer 1 mode register | TMOD1.3 | TMOD1.2 | TMOD1.1 | TMOD1.0 | W | | | | | <b>*</b> 000 | TC00 | Timer 0 counter register 0 | TC00.3 | TC00.2 | TC00.1 | TC00.0 | R | | | | | \$006 | TL00 | Timer 0 load register 0 | TL00.3 | TL00.2 | TL00.1 | TL00.0 | W | | | | | \$007 | TC01 | Timer 0 counter register 1 | TC01.3 | TC01.2 | TC01.1 | TC01.0 | R | | | | | φυυτ | TL01 | Timer 0 load register 1 | TL01.3 | TL01.2 | TL01.1 | TL01.0 | W | | | | | \$008 | TC10 | Timer 1 counter register 0 | TC10.3 | TC10.2 | TC10.1 | TC10.0 | R | | | | | φυυο | TL10 | Timer 1 load register 0 | TL10.3 | TL10.2 | TL10.1 | TL10.0 | W | | | | | \$009 | TC11 | Timer 1 counter register 1 | TC11.3 | TC11.2 | TC11.1 | TC11.0 | R | | | | | <b>\$</b> 009 | TL11 | Timer 1 load register 1 | TL11.3 | TL11.2 | TL11.1 | TL11.0 | W | | | | | \$00A | SIOL | Serial data low register | SIOL.3 | SIOL.2 | SIOL.1 | SIOL.0 | R/W/t | | | | | \$00B | SIOH | Serial data high register | SIOH.3 | SIOH.2 | SIOH.1 | SIOH.0 | R/W/t | | | | | \$00C | SIOM | Serial mode register | SIOM.3 | SIOM.2 | SIOM.1 | SIOM.0 | R/W | | | | | \$00D | CKS | System clock register | WDRST (r) | ENOSC<br>(Must be set to 1) | CKS.1 | CKS.0 | W | | | | | \$00E | BPM | Beep mode register | BPM.3 | BPM.2 | BPM.1 | BPM.0 | W | | | | | \$00F | TESTM | Test mode register | | CONFIDE | ENTIAL | | W | | | | | \$010 | PMODA | Port mode register A | PMODA.3 | PMODA.2 | PMODA.1 | PMODA.0 | W | | | | | \$011 | PMODB | Port mode register B | PMODB.3 | PMODB.2 | PMODB.1 | PMODB.0 | W | | | | | \$012 | PMODC | Port mode register C | PMODC.3 | PMODC.2 | PMODC.1 | PMODC.0 | W | | | | | \$013 | TMOD3 | Timer 3 mode register | TMOD3.3 | TMOD3.2 | TMOD3.1 | TMOD3.0 | W | | | | | \$014 | PMODE | Port mode register E | PMODE.3 | PMODE.2 | PMODE.1 | PMODE.0 | W | | | | | \$015 | PMODF | Port mode register F | PMODF.3 | PMODF.2 | PMODF.1 | PMODF.0 | W | | | | | \$016 | - | Reserved for EV-chip | - | - | - | - | - | | | | | \$017 | LCON | LCD control register | LCON.3 | LCON.2 | LCON.1 | LCON.0 | W/s/r | | | | | \$018 | LMOD0 | LCD mode register 0 | LMOD0.3 | LMOD0.2 | LMOD0.1 | LMOD0.0 | W | | | | | \$019 | LMOD1 | LCD mode register 1 | LMOD1.3 | LMOD1.2 | LMOD1.1 | LMOD1.0 | W | | | | | \$01A | TGC | Tone generator control register | TGC.3 | TGC.2 | TGC.1 | TGC.0 | W | | | | | \$01B | TGD | Tone generator Data register | TGD.3 | TGD.2 | TGD.1 | TGD.0 | W | | | | ### RAM Mapped Register (continued) | Re | gister | Contents | | | | | | | | | |--------------|--------|----------------------------|--------------|-------------|--------------|-------------|-----------|--|--|--| | Addr | Name | Description | Bit3 | Bit2 | Bit1 | Bit0 | Attribute | | | | | <b>CO10</b> | TC30 | Timer 3 counter register 0 | TC30.3 | TC30.2 | TC30.1 | TC30.0 | R | | | | | \$01C | TL30 | Timer 3 load register 0 | TL30.3 | TL30.2 | TL30.1 | TL30.0 | W | | | | | 0045 | TC31 | Timer 3 counter register 1 | TC31.3 | TC31.2 | TC31.1 | TC31.0 | R | | | | | \$01D | TL31 | Timer 3 load register 1 | TL31.3 | TL31.2 | TL31.1 | TL31.0 | W | | | | | 0045 | TC32 | Timer 3 counter register 2 | TC32.3 | TC32.2 | TC32.1 | TC32.0 | R | | | | | \$01E | TL32 | Timer 3 load register 2 | TL32.3 | TL32.2 | TL32.1 | TL32.0 | W | | | | | \$01F | CTL0 | Control register 0 | KPRS (R/t) | ENBAT (W/t) | KPAD (W/t) | KRVS (W/t) | - | | | | | \$020 | SPA | Stack pointer register A | Reserved | Reserved | Reserved | SP.10 | R/W/t | | | | | \$021 | SPB | Stack pointer register B | SP.9 | SP.8 | SP.7 | SP.6 | R/W/t | | | | | \$022 | SPC | Stack pointer register C | SP.5 | SP.4 | SP.3 | SP.2 | R/t | | | | | \$023 | SENSE4 | Sense register 4 | IECD (s/r/t) | IRQCD (r/t) | IET3 (s/r/t) | IRQT3 (r/t) | - | | | | | \$024 | SENSE5 | Sense register 5 | IERT (s/r/t) | IRQRT (r/t) | IE3 (s/r/t) | IRQ3 (r/t) | - | | | | | \$025 | TMOD2 | Timer 2 mode register | TMOD2.3 | TMOD2.2 | TMOD2.1 | TMOD2.0 | W | | | | | <b>#</b> 000 | TC20 | Timer 2 counter register 0 | TC20.3 | TC20.2 | TC20.1 | TC20.0 | R | | | | | \$026 | TL20 | Timer 2 load register 0 | TL20.3 | TL20.2 | TL20.1 | TL20.0 | W | | | | | <b>#</b> 007 | TC21 | Timer 2 counter register 1 | TC21.3 | TC21.2 | TC21.1 | TC21.0 | R | | | | | \$027 | TL21 | Timer 2 load register 1 | TL21.3 | TL21.2 | TL21.1 | TL21.0 | W | | | | | \$028 | KREG0 | Keypad register 0 | KREG0.3 | KREG0.2 | KREG0.1 | KREG0.0 | R/W/t | | | | | \$029 | KREG1 | Keypad register 1 | KREG1.3 | KREG1.2 | KREG1.1 | KREG1.0 | R/W/t | | | | | \$02A | KREG2 | Keypad register 2 | KREG2.3 | KREG2.2 | KREG2.1 | KREG2.0 | R/W/t | | | | | \$02B | KREG3 | Keypad register 3 | KREG3.3 | KREG3.2 | KREG3.1 | KREG3.0 | R/W/t | | | | | \$02C | KREG4 | Keypad register 4 | KREG4.3 | KREG4.2 | KREG4.1 | KREG4.0 | R/W/t | | | | | \$02D | KREG5 | Keypad register 5 | KREG5.3 | KREG5.2 | KREG5.1 | KREG5.0 | R/W/t | | | | | \$02E | KREG6 | Keypad register 6 | KREG6.3 | KREG6.2 | KREG6.1 | KREG6.0 | R/W/t | | | | | \$02F | KREG7 | Keypad register 7 | KREG7.3 | KREG7.2 | KREG7.1 | KREG7.0 | R/W/t | | | | | \$030 | P0 | Port 0 | P0.3 | P0.2 | P0.1 | P0.0 | R/W/t | | | | | \$031 | P1 | Port 1 | P1.3 | P1.2 | P1.1 | P1.0 | R/W/t | | | | | \$032 | P2 | Port 2 | P2.3 | P2.2 | P2.1 | P2.0 | R/W/t | | | | | \$033 | P3 | Port 3 | P3.3 | P3.2 | P3.1 | P3.0 | R/W/t | | | | | \$034 | P4 | Port 4 | P4.3 | P4.2 | P4.1 | P4.0 | R/W/t | | | | | \$035 | P5 | Port 5 | P5.3 | P5.2 | P5.1 | P5.0 | R/W/t | | | | | \$036 | P6 | Port 6 | P6.3 | P6.2 | P6.1 | P6.0 | R/W/t | | | | | \$037 | P7 | Port 7 | P7.3 | P7.2 | P7.1 | P7.0 | R/W/t | | | | | \$038 | P8 | Port 8 | P8.3 | P8.2 | P8.1 | P8.0 | R/W/t | | | | #### RAM Mapped Register (continued) | Reg | gister | Contents | | | | | | | | |-------|--------|---------------------------|----------|--------|--------|--------|-----------|--|--| | Addr | Name | Description | Bit3 | Bit2 | Bit1 | Bit0 | Attribute | | | | \$039 | - | Reserved | - | - | - | - | - | | | | \$03A | - | Reserved for EV-chip | - | - | - | - | - | | | | \$03B | - | Reserved for EV-chip | - | - | - | - | - | | | | \$03C | CTL1 | Control register 1 | RT | RD | CD | DOUT | R/t | | | | \$03D | CTL2 | Oceative land what the O | RP | BAT.2 | BAT.1 | BAT.0 | R/t | | | | φυου | CILZ | Control register 2 | Reserved | PWDN | ENRD | BEEP | W | | | | \$03E | CVAR | Contrast control register | CVAR.3 | CVAR.2 | CVAR.1 | CVAR.0 | W | | | | \$03F | - | Reserved | - | - | - | - | - | | | #### **Notes** R/W/s/r/t: Available for all nibble-read instructions, for example, MTA > Available for all nibble-write instructions, for example, ITMD W: Available for instructions. SM and SMD s: Available for instructions, RM and RMD Available for instructions. TM and TMD ☞ IE: Enable all Interrupts of this chip ☞ IEn: Enable Interrupt n. IRQn: Interrupt request of INTn Enable Interrupt of Timer n, IRQTn: Interrupt request of Timer n Enable Interrupt of Serial interface, IRQSI: Interrupt request of Serial interface Enable Interrupt of Ring time detected, IRQRT: Interrupt request of Ring time detected ☞ IECD: Enable Interrupt of Carrier detected, IRQCD: Interrupt request of Carrier detected RSP: Reset stack pointer address ☞ SP.y: Bit y of stack pointer, Clock selection register CKS.0 and CKS.1 are used to select the system clock speed. If CKS = xx00, then system clock = Fmain/16 If CKS = xx01, then system clock = Fmain/8 If CKS = xx10, then system clock = Fmain/4 F KPRS: It would be set when any key is pressed Enable Key pressed detection F KPAD: Reverse Keyboard scanning signal KRVS: Contrast control register (Write-only) WDRST: Reset watch-dog timer Enable low-battery detection when high ENBAT: Battery power level data (Please refer to the Battery-low table) Bit for indicates Ring pulse signal RP: RT: Bit for indicates Ring time pulse status Bit for indicates Ring detected status RD: Bit for indicates Carrier detected status FSK demodulator output data bit DOUT: Enable Internal Ring detector ENRD: PWDN: Turn off the FSK demodulator when set Enable the clock for FSK demodulator and frequency counter (within the Ring Detector) when set F ENOSC: (It must be set to one during initialization if FSK demodulator has to be used in case!) BEEP: **Enable Beeper** $\mathscr{F}$ (m = 0, 1, 2; n = 0, 1, 2, 3; x = 0,1; y = 2, ..., 10 #### Registers and Flags This chip provides nine registers and two flags for CPU operation. They are described below: ### Accumulator A (4 bits) and Register B (4 bits) Accumulator A and Register B are 4-bit registers that hold the result of the arithmetic logic units (ALU). They are the very basic registers for a CPU to execute all the arithmetic calculation, logic operation and data transfer among memories, I/Os and registers. #### Register V (4 bits) Register V is a 4-bit register that holds the page address (256 addresses per page) of RAM. #### Register X (4 bits), Register Y (4 bits) Register X and Y register are used for indirect RAM addressing such that the RAM address is defined as the following format: | Bit location | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|----|----|----|----|----|----|----|----|----|----|----|----| | RAM addr | V3 | V2 | V1 | V0 | Х3 | X2 | X1 | X0 | Y3 | Y2 | Y1 | Y0 | ### Register EX (4 bits), Register EY (4 bits) Register EX and EY are 4-bit registers available to assist register X and Y, respectively. #### Carry Flag, CY (1 bit) The carry flag holds the ALU overflow bit generated by arithmetic operation. It can be set or reset by instruction directly, and is affected by the rotation instruction. #### Status Flag, SF (1 bit) The flag holds ALU compare, arithmetic instruction and the status of accumulator. This flag would be tested by those instructions of conditional jump and conditional call. After the execution of BR, LBR, CAL, or CALL instruction, the status bit would be set. Furthermore, SF will be pushed onto the stack during serving interrupt. Note that SF will not be restored by instruction RET, but instruction RETI #### Program Counter, PC (14 bits) The program counter is used for addressing ROM data. It is reserved in the RAM space from \$200 to \$23F, so that 16 program addresses can be restored for subroutine call function or interrupt service. #### Stack Pointer, SP (11 bits) The stack pointer is implemented by a typical RAM mapped structure so as to make the system become more flexible. SP is an 11-bit register that holds the start address of the recent level of Stack. Stack is combined of sixteen 4-nibble registers, which hold the return address with its status flag and carry flag. Therefore, 16-level stack operation is possible. And yet it can be initialized to the starting address (\$23F) of the stack by either system reset or software method. The following table shows how the stack register configured: #### Reset Stack Pointer Flag, RSP (1bit) RSP is used for resetting the stack pointer to \$23F and it will be cleared while system RESET. In general, it would not be used unless software reset of stack pointer is necessary for extraordinary condition. The stack pointer can be reset to \$23F by reset RSP through instruction RM/RMD. Stack Register Bits Configuration: (For level 1) | Address | | Bit 3 | | Bit 2 | | Bit 1 | | Bit 0 | | | |---------|-----|-------|-----|-------|-----|-------|-----|-------|--|--| | \$23F | S3 | -PC3 | S2 | -PC2 | S1 | -PC1 | S0 | -PC0 | | | | \$23E | S7 | CY | S6 | -PC6 | S5 | -PC5 | S4 | -PC4 | | | | \$23D | S11 | -PC10 | S10 | -PC9 | S9 | -PC8 | S8 | -PC7 | | | | \$23C | S15 | SF | S14 | -PC13 | S13 | -PC12 | S12 | -PC11 | | | **Note:** PC stored in the stack is a negative value. #### **Memory Allocation of Stack Level** | Level | Address | Level | Address | Level | Address | Level | Address | |-------|---------------|-------|---------------|-------|---------------|-------|---------------| | 16 | \$203 ~ \$200 | 12 | \$213 ~ \$210 | 8 | \$223 ~ \$220 | 4 | \$233 ~ \$230 | | 15 | \$207 ~ \$204 | 11 | \$217 ~ \$214 | 7 | \$227 ~ \$224 | 3 | \$237 ~ \$234 | | 14 | \$20B ~ \$208 | 10 | \$21B ~ \$218 | 6 | \$22B ~ \$228 | 2 | \$23B ~ \$238 | | 13 | \$20F ~ \$20C | 9 | \$21F ~ \$21C | 5 | \$22F ~ \$22C | 1 | \$23F ~ \$23C | #### Interrupts There are eleven interrupts with one system initialization: - 1. System initialization: - RESET (Reset pin) - 2. General interrupts: - INTO (Interrupt from pin P1.0) INT1 (Interrupt from pin P1.1) - INT2 (Interrupt from pin Port2 / Port3) - INT3 (Interrupt from pin P1.3) - 3. Timer interrupts: - TIMER0 (Interrupt from pin Timer 0) - TIMER1 (Interrupt from pin Timer 1) - TIMER2 (Interrupt from pin Timer 2) - TIMER3 (Interrupt from pin Timer 3) - 4. Serial communication port interrupt: - SERIAL (interrupt from Serial COM port) - 5. Ring detected interrupt: - RT (interrupt from Ring detector) - 6. Carrier detected interrupt: - CD (interrupt from FSK demodulator) #### Interrupt Control bits and Request flags The RAM mapped register from \$00 through \$03, \$23 and \$24 can only be accessed by bit operation instructions. Any interrupt (such as \$\overline{INTn}\$) may be accepted while IE and its own enable flag (such as IEn) were set. The interrupt request flag (such as IRQn) will only be set by its interrupt signal (a negative-edge signal). Yet this request flag can be cleared by system RESET or software. #### Interrupt Enabled (IE) The interrupt-enable bit, IE, enables all interrupt requests when it is set. Also, it can be enabled by instruction RETI and will be reset during entering the interrupt service routine automatically. Once the program enters the interrupt service routine, IE will be reset by CPU itself so that other interrupt (if any) would be pending with its execution priority. That is the reason why only one level of interrupt service can be performed in general. However, multi-level interrupt service can be achieved by reset IE within the interrupt service routine. For multi-level interrupt programming, please refer to the Timing diagram of interrupt events. Actually, it is the gate for all interrupt requests. No interrupt service would be done until IE is set. Any two different interrupts occurred in the same instruction cycle would be treated as collision of interrupt when IE=1. The interrupt service with higher priority will come first while the other is pending. Any two different interrupts occurred whatever in the same or different instruction cycle would also be treated as collision of interrupt when IE=0. Both interrupts would be pending until IE is set. Once IE is set, the interrupt service with higher priority will come first while the other is pending. #### Individual Interrupt Enabled (IEn, IETn, IESI, IECD) The interrupt-enable bit (such as IEn) enables a specific interrupt request (such as IRQn) when it is set. In other words, it is the gate for its own interrupt request only. ### **General Interrupts** #### INTO, INT1: Interrupt request flag, IRQ0/IRQ1, will be set while interrupt input, $\overline{\text{INT0}}$ / $\overline{\text{INT1}}$ , has received any negative edge signal. The program will enter the service routine of $\overline{\text{INT0}}$ / $\overline{\text{INT1}}$ provided that both IE and IE0/IE1 were set. Also, $\overline{\text{INT0}}$ or $\overline{\text{INT1}}$ (P1.0 or P1.1) can be programmed as an external clock input of Timer0 or Timer1 by the register, TMOD0 or TMOD1, respectively. #### INT2: Interrupt request flag, IRQ2, will be set while any one of the interrupt inputs, $\overline{\text{INT2}}$ (Port2.0-3/Port3.0-3), has received a negative edge signal. Generally, it is used as a keyboard interrupt. Port3 can not be used as interrupt when 1/16 duty of LCD has been selected. #### INT3 Interrupt request flag, IRQ3, will be set while interrupt input INT3 has received any negative edge signal. ### **Timer Interrupts** Interrupt request flag, IRQTn, will be set by the output signal of Timer n (n = 0, 1, 2, 3). Details should be referred to the section of Timer. ### Serial communication port interrupt Interrupt request flag, IRQSI, will be set by the internal serial interface signal. Details should be referred to the section of Serial Communication port. ### Ring detected interrupt Interrupt request flag, IRQRT, will be set by the internal signal from Ring detector provided that Ring detector has been enabled (ENRD = 1). Details should be referred to the section of Ring detector. #### Carrier detected interrupt Interrupt request flag, IRQCD, will be set in NORMAL mode by the internal signal from Carrier detector provided that FSK demodulator has been turned on (PWDN = 0 & ENOSC = 1). Note that it does not work in STOP mode. ### Interrupt Vector Address and execution priority | Interrupt | Signal | Priority | Issued by | Condition | Vector | |-----------|----------|------------------|-----------|-----------------------------------------------------------|--------| | RESET | External | 1 <sup>st</sup> | Reset pin | Reset pin RESET PIN = 1 for at least 2 instruction cycles | | | ĪNT0 | External | 2 <sup>nd</sup> | IRQ0 | IRQ0 | | | ĪNT1 | External | 3 <sup>rd</sup> | IRQ1 | IE = IE1 = IRQ1 = 1 | \$04 | | ĪNT2 | External | 4 <sup>th</sup> | IRQ2 | IE = IE2 = IRQ2 = 1 | \$06 | | ĪNT3 | External | 5 <sup>th</sup> | IRQ3 | IE = IE3 = IRQ3 = 1 | \$08 | | TIMER0 | Internal | 6 <sup>th</sup> | IRQT0 | IE = IET0 = IRQT0 = 1 | \$0A | | TIMER1 | Internal | 7 <sup>th</sup> | IRQT1 | IE = IET1 = IRQT1 = 1 | \$0C | | TIMER2 | Internal | 8 <sup>th</sup> | IRQT2 | IE = IET2 = IRQT2 = 1 | \$0E | | TIMER3 | Internal | 9 <sup>th</sup> | IRQT3 | IE = IET3 = IRQT3 = 1 | \$10 | | SERIAL | Internal | 10 <sup>th</sup> | IRQSI | IE = IESI = IRQSI = 1 | \$12 | | RT | Internal | 11 <sup>th</sup> | IRQRT | IE = IERT = ENRD = 1 | \$14 | | CD | Internal | 12 <sup>th</sup> | IRQCD | IE = IECD = ENOSC = 1 & PWDN = 0 | \$16 | ### Timing of interrupt sequence ### Hardware structure of interrupt control unit ### **Example of Timing of interrupt events** #### **Input/Output Port** There are 36 I/O pins, which are divided into 9 groups. Each I/O pin contains a pull-up resistor that can be controlled by software. The pull-up resistor will be enabled if it is configured as an input pin with a data '1'. For example, the pull-up resistor of P0.3 would be enabled by the following procedure: ITMD :1110, PMODA ;set P0 as I/P port ITMD :1000, P0 ;enable pull-up resistor of P0.3 Do not let any unconnected pin floating because it may cause the large current problem to the chip. All the I/O pins would be reset to the default status (input with pull-up resistor enabled) after system reset. In case there is an internal pull-up resistor of input pin have been disabled, an external pull-up/pull-down resistor (100 K $\Omega$ typically) must be connected. | Port Mode Register | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Мо | de | |--------------------|----------|----------|----------|----------|----------|-----------| | PMODA (\$010) | PORT3 | PORT2 | Reserved | PORT0 | 0: Input | 1: Output | | PMODB (\$011) | PORT7 | PORT6 | PORT5 | Reserved | 0: Input | 1: Output | | PMODC (\$012) | Reserved | Reserved | Reserved | PORT8 | 0: Input | 1: Output | | PMODE (\$014) | PORT1.3 | PORT1.2 | PORT1.1 | PORT1.0 | 0: Input | 1: Output | | PMODF (\$015) | PORT4.3 | PORT4.2 | PORT4.1 | PORT4.0 | 0: Input | 1: Output | ### **Serial Interface** The serial interface is basically an 8-bit Half-duplex Serial Transmitter/Receiver, which consists of two data registers (SIOL, SIOH), one serial mode register (SIOM) and an internal octal counter. During execution of STS instruction, the octal counter would be reset first and then it will increment by one at the rising edge of the transfer clock (SCK). However, the octal counter would be reset and the serial interrupt flag will also be set after the eighth transfer clocks (SCK) has been sent or the octal counter has been reset during transferring data. Note that Port0 must be set up as an input port before the serial interface function is enabled. #### Serial Data Register (SIOL(\$00A), SIOH(\$00B)) This 8-bit read/write serial data register consists of a lower nibble (SIOL) and an upper nibble (SIOH). The data stored in serial data register can be shifted out through the SO pin. Similarly, the external data stream can be shifted in and stored in SIOL & SIOH via SI pin. The output bit stream is synchronized by the falling edge of the transfer clock (SCK) while the input bit stream will be extracted by the rising edge of SCK. Read/write operation of the serial data register must be performed after completion of data transfer. Otherwise, the data cannot be guaranteed. #### Serial Mode Register (SIOM (\$00C)) It is a 4-bit write-only register, which determines what the speed or the source of transferring clock (SCK) is. It may be reset by RESET instruction. Be ware that writing data to SIOM will initialize the data transfer operation whatever it is being data transfer or not. It means that the transfer clock will stop, octal counter will be reset to zero. During data transferring, serial interrupt request (IRQSI) will also be set after writing SIOM. Furthermore, data transferring will not be start up until the STS instruction has been executed. Note that PMODA.0 must be reset, and do not let any input pin (SI, SCK-input or P0.3) floating (Internal or external pull-up resistor can be utilized). Serial Mode Register (SIOM, \$00C) (PMODA.0 = 0) (Fcyc = 1/Tcyc = Fmain/4 or Fmain/8 or Fmain/16) | SIOM.3 | SIOM.2 | SIOM.1 | SIOM.0 | SCK | Clock Source | Serial I/O | P0.0~2 | |--------|--------|--------|--------|--------|----------------|------------|----------| | 0 | Х | Х | Х | - | - | Disabled | Enabled | | 1 | 0 | 0 | 0 | Input | External Clock | Enabled | Disabled | | 1 | 0 | 0 | 1 | Output | Fcyc | Enabled | Disabled | | 1 | 0 | 1 | 0 | Output | Fcyc / 4 | Enabled | Disabled | | 1 | 0 | 1 | 1 | Output | Fcyc / 16 | Enabled | Disabled | | 1 | 1 | 0 | 0 | Output | Fcyc / 64 | Enabled | Disabled | | 1 | 1 | 0 | 1 | Output | Fcyc / 256 | Enabled | Disabled | | 1 | 1 | 1 | 0 | Output | Fcyc / 1024 | Enabled | Disabled | | 1 | 1 | 1 | 1 | Output | Fcyc / 4096 | Enabled | Disabled | #### **Serial Data Format** | so | | В0 | В1 | B2 | ВЗ | B4 | B5 | В6 | B7 | В0 | B1 | B2 | В3 | B4 | B5 | В6 | В7 | | |-----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--| | SI | _ | В0 | В1 | B2 | ВЗ | B4 | B5 | В6 | В7 | В0 | В1 | B2 | ВЗ | B4 | B5 | В6 | В7 | | | SCK | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | | #### **Timing of Serial Data Transfer** #### **Oscillators** This is a typical dual oscillator system such that low power idle state with real time clock can be guaranteed even if the CPU has been stopped. Also, a simple RC delay circuit that co-operates with an I/O pin, the Timer0 and suitable software routine can give out a practical Watch-dog Timer. As shown in the following figure, the main oscillation circuit should be connected to an external crystal or ceramic oscillator. To ensure that these two oscillators can work well, a feedback resistor and 4 auxiliary capacitors should be employed. The recommendation for the value of these components is: | Component | RANGE | RECOMMENDED | |-----------|-----------|-------------| | Rf | 1ΜΩ~5ΜΩ | 1ΜΩ | | CX1 | 22pF~30pF | 22pF | | CX2 | 22pF~30pF | 22pF | | CT1 | 22pF~30pF | 22pF | | CT2 | 22pF~30pF | 22pF | To ensure the oscillation quality of the real time clock, there is a recommendation for the PC board layout that can be help for improving the noise immunity. In addition, any micro-strip that cross over the oscillation signal would cause unexpected high-frequency noise to the watch oscillator. As shown in the following figure, the oscillation signal is easily be shielded by such simple ground plane for one-layer or two-layer design. Similarly, this method can be applied for the main oscillator in some noisy environment. 18 #### **Timers** There are 4 Timers (Timer 0~3), in which prescaler and clock selection circuits have been built. By programming timer mode registers TMOD0~TMOD3, different clock source and speed can be selected. Yet Timer 0 can be set up as a real time clock for the watch oscillator would never stop after power up. ### 1) Operation of Timer 0: 8-bit Watch Timer Timer 0 is an 8-bit timer, which consists of two 4-bit write-only timer load registers (TL00, TL01) and two 4-bit read-only counter registers (TC00, TC01). Besides the internal clock source, Fmain, an external clock source, INT0, is also provided. To write this load register, the lower nibble, TL00, must be written first, then the upper nibble, TL01. To read the data of this counter register, the upper nibble, TC01, must be read out first, then the lower nibble, TC00. The order of data reading and writing must be followed otherwise unexpected counting may be occurred. There are three kinds of clock source can be selected by controlling the timer mode register 0 (TMOD0, \$004): - The first one is the system clock, which can be programmed to Fmain/4, Fmain/8 or Fmain/16 by writing 00, 01 or 10 to CKS.1-0 respectively. - The second one is the standard watch oscillator, 32768Hz. - The Last one is the external source, INTO. Interrupt request flag (IRQT0) will be set when its 8-bit up counter has been overflowed (IRQT0 will be set during the transition from \$FF, the counter value, to \$00) For the clock speed value, please refer the following table. ### **Timer 0 Block Diagram** Timer Mode 0 Register (TMOD0, \$004) (Fcyc = 1/Tcyc = Fmain/4 or Fmain/8 or Fmain/16) | TMOD0.3 | TMOD0.2 | TMOD0.1 | TMOD0.0 | Clock speed | Clock Source | |---------|---------|---------|---------|---------------|-----------------------| | 0 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | | 0 | 0 | 0 | 1 | Fcyc / 512 | Main oscillator | | 0 | 0 | 1 | 0 | Fcyc / 128 | Main oscillator | | 0 | 0 | 1 | 1 | Fcyc / 32 | Main oscillator | | 0 | 1 | 0 | 0 | Fcyc / 8 | Main oscillator | | 0 | 1 | 0 | 1 | Fcyc / 4 | Main oscillator | | 0 | 1 | 1 | 0 | Fcyc / 2 | Main oscillator | | 0 | 1 | 1 | 1 | • | External source, INT0 | | 1 | 0 | 0 | 0 | 32768Hz / 256 | Watch oscillator | | 1 | 0 | 0 | 1 | 32768Hz / 128 | Watch oscillator | | 1 | 0 | 1 | 0 | 32768Hz / 64 | Watch oscillator | | 1 | 0 | 1 | 1 | 32768Hz / 16 | Watch oscillator | | 1 | 1 | Χ | Χ | - | Reserved | #### 2) Operation of Timer 1: 8-bit Timer Auto-reload function has been implemented in Timer 1. User can select different clock speed with or without auto-reload by putting the appropriate value into the timer mode register 1, TMOD1. Besides the internal clock source, Fmain, an external clock source, INT1, is also provided. To write this load register, the lower nibble, TL10, must be written first, then the upper nibble, TL11. To read the data of this counter register, the upper nibble, TC11, must be read out first, then the lower nibble, TC10. The order of data reading and writing must be followed otherwise unexpected counting may be occurred. Interrupt request flag (IRQT1) will be set when its 8-bit up counter has been overflowed (IRQT1 will be set during the transition from \$FF, the counter value, to \$00) For the clock speed value, please refer the following table. ### **Timer 1 Block Diagram** ### Timer Mode Register 1: (TMOD1 \$005) (Fcyc = 1/Tcyc = Fmain/4 or Fmain/8 or Fmain/16) | TMOD1.3 | TMOD1.2 | TMOD1.1 | TMOD1.0 | Clock speed | Clock Source | Auto-Reload | |---------|---------|---------|---------|-------------|-----------------|-------------| | 0 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | No | | 0 | 0 | 0 | 1 | Fcyc / 1024 | Main oscillator | No | | 0 | 0 | 1 | 0 | Fcyc / 512 | Main oscillator | No | | 0 | 0 | 1 | 1 | Fcyc / 32 | Main oscillator | No | | 0 | 1 | 0 | 0 | Fcyc / 16 | Main oscillator | No | | 0 | 1 | 0 | 1 | Fcyc / 8 | Main oscillator | No | | 0 | 1 | 1 | 0 | Fcyc / 2 | Main oscillator | No | | 0 | 1 | 1 | 1 | - | External, INT1 | No | | 1 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | Yes | | 1 | 0 | 0 | 1 | Fcyc / 1024 | Main oscillator | Yes | | 1 | 0 | 1 | 0 | Fcyc / 512 | Main oscillator | Yes | | 1 | 0 | 1 | 1 | Fcyc / 32 | Main oscillator | Yes | | 1 | 1 | 0 | 0 | Fcyc / 16 | Main oscillator | Yes | | 1 | 1 | 0 | 1 | Fcyc / 8 | Main oscillator | Yes | | 1 | 1 | 1 | 0 | Fcyc / 2 | Main oscillator | Yes | | 1 | 1 | 1 | 1 | - | External, INT1 | Yes | ### 3) Operation of Timer 2: 8-bit Timer Auto-reload function has been implemented in Timer 2. User can select different clock speed with or without auto-reload by putting the appropriate value into the timer mode register 2, TMOD2. Only the internal clock source, Fmain, is provided for Timer 2. To write this load register, the lower nibble, TL20, must be written first, then the upper nibble, TL21. To read the data of this counter register, the upper nibble, TC21, must be read out first, then the lower nibble, TC20. The order of data reading and writing must be followed otherwise unexpected counting may be occurred. Interrupt request flag (IRQT2) will be set when its 8-bit up counter has been overflowed (IRQT2 will be set during the transition from \$FF, the counter value, to \$00). For the clock speed value, please refer the following table. ### Timer 2 Block Diagram #### Timer Mode Register 2: (TMOD2 \$0025) (Fcyc = 1/Tcyc = Fmain/4 or Fmain/8 or Fmain/16) | TMOD2.3 | TMOD2.2 | TMOD2.1 | TMOD2.0 | Clock speed | Clock Source | Auto-Reload | |---------|---------|---------|---------|-------------|-----------------|-------------| | 0 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | No | | 0 | 0 | 0 | 1 | Fcyc / 1024 | Main oscillator | No | | 0 | 0 | 1 | 0 | Fcyc / 512 | Main oscillator | No | | 0 | 0 | 1 | 1 | Fcyc / 128 | Main oscillator | No | | 0 | 1 | 0 | 0 | Fcyc / 32 | Main oscillator | No | | 0 | 1 | 0 | 1 | Fcyc / 16 | Main oscillator | No | | 0 | 1 | 1 | 0 | Fcyc / 8 | Main oscillator | No | | 0 | 1 | 1 | 1 | Fcyc / 2 | Main oscillator | No | | 1 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | Yes | | 1 | 0 | 0 | 1 | Fcyc / 1024 | Main oscillator | Yes | | 1 | 0 | 1 | 0 | Fcyc / 512 | Main oscillator | Yes | | 1 | 0 | 1 | 1 | Fcyc / 128 | Main oscillator | Yes | | 1 | 1 | 0 | 0 | Fcyc / 32 | Main oscillator | Yes | | 1 | 1 | 0 | 1 | Fcyc / 16 | Main oscillator | Yes | | 1 | 1 | 1 | 0 | Fcyc / 8 | Main oscillator | Yes | | 1 | 1 | 1 | 1 | Fcyc / 2 | Main oscillator | Yes | ### 4) Operation of Timer 3: 12-bit Timer Auto-reload function has also been implemented in Timer 3. User can select different clock speed with or without auto-reload by putting the appropriate value into the timer mode register 3, TMOD3. Only the internal clock source, Fmain, is provided for Timer 3. To write this load register, the lower nibble, TL30, must be written first, then the middle nibble, TL31, and finally the upper nibble, TL32. To read the data of this counter register, the upper nibble, TC32, must be read out first, then the TC31, and finally the TC30. The order of data reading and writing must be followed otherwise unexpected counting may be occurred. Interrupt request flag (IRQT3) will be set when its 12-bit up counter has been overflowed (IRQT3 will be set during the transition from \$FFF, the counter value, to \$000). For the clock speed value, please refer the following table. ### **Timer 3 Block Diagram** Timer Mode Register 3: (TMOD3, \$013) (Fcyc = 1/Tcyc = Fmain/4 or Fmain/8 or Fmain/16) | TMOD3.3 | TMOD3.2 | TMOD3.1 | TMOD3.0 | Clock speed | Clock Source | Auto-Reload | |---------|---------|---------|---------|-------------|-----------------|-------------| | 0 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | No | | 0 | 0 | 0 | 1 | Fcyc / 1024 | Main oscillator | No | | 0 | 0 | 1 | 0 | Fcyc / 512 | Main oscillator | No | | 0 | 0 | 1 | 1 | Fcyc / 128 | Main oscillator | No | | 0 | 1 | 0 | 0 | Fcyc / 32 | Main oscillator | No | | 0 | 1 | 0 | 1 | Fcyc / 16 | Main oscillator | No | | 0 | 1 | 1 | 0 | Fcyc / 8 | Main oscillator | No | | 0 | 1 | 1 | 1 | Fcyc / 2 | Main oscillator | No | | 1 | 0 | 0 | 0 | Fcyc / 2048 | Main oscillator | Yes | | 1 | 0 | 0 | 1 | Fcyc / 1024 | Main oscillator | Yes | | 1 | 0 | 1 | 0 | Fcyc / 512 | Main oscillator | Yes | | 1 | 0 | 1 | 1 | Fcyc / 128 | Main oscillator | Yes | | 1 | 1 | 0 | 0 | Fcyc / 32 | Main oscillator | Yes | | 1 | 1 | 0 | 1 | Fcyc / 16 | Main oscillator | Yes | | 1 | 1 | 1 | 0 | Fcyc / 8 | Main oscillator | Yes | | 1 | 1 | 1 | 1 | Fcyc / 2 | Main oscillator | Yes | ### **Liquid Crystal Display (LCD)** This chip can directly drive a LCD panel of up to 896 dots (16 commons x 56 segments). LCD driver contains: - LCD controller/driver - Display RAM for storing display data (\$100~\$1FF) (some of them are empty space (no memory cell)) - 16 common output pins (COM0~COM15) - 56 segment output pins (SEG0~SEG55) - 16-level contrast control LCD control register, LCON, is used to turn the LCD display on and off so as to save energy in some cases. Also, it can control the LCD bias voltage to accommodate different type of LCD. LCD mode register 0, LMOD0, is in charge of controlling the frame frequency of LCD and the display modes. Users can select 1/8 or 1/16 duty for LCD by setting or resetting the bit, LMOD1.0. When it is reset to zero, for example, 1/8 duty will be performed and COM8~COM15 will also be recovered to be the normal I/O ports, Port3, Port4. In addition, LMOD1.1~LMOD1.3 offers 5 choices of I/O combination. When LCON.0 is set, the LCD would always be enabled even in STOP or HALT mode. ### LCD Control Register: LCON (\$017) | LCON.3 | LCON.2 | LCON.1 | LCON.0 | Function | |--------|--------|--------|--------|-------------------------| | 0 | 0 | | 0 | Disable LCD (Power off) | | 0 | 0 | | 1 | Enable LCD (Power on) | | 0 | 0 | 0 | | 1/5 bias | | 0 | 0 | 1 | | 1/4 bias | ### LCD Mode Register 0: LMOD0 (\$018) | LMOD0.3 | LMOD0.2 | LMOD0.1 | LMOD0.0 | Function | |---------|---------|---------|---------|--------------------------| | | | 0 | 0 | All LCD dots off (Blank) | | | | 0 | 1 | All LCD dots on | | | | 1 | 0 | Normal display | | | | 1 | 1 | Normal display | | 0 | 0 | | | Frame Frequency = 32Hz | | 0 | 1 | | | Frame Frequency = 64Hz | | 1 | 0 | | | Frame Frequency = 128Hz | | 1 | 1 | | | Frame Frequency = 256Hz | #### LCD Mode Register 1: LMOD1 (\$019) | LMOD1.3 | LMOD1.2 | LMOD1.1 | LMOD1.0 | Pin30~33 | Pin34~37 | Pin38~41 | Pin42~45 | Pin82~85 | Pin86~89 | Duty | |---------|---------|---------|---------|-----------|-----------|-----------|-----------|-----------|-----------|------| | 0 | 0 | 0 | | SEG40~43 | SEG44~47 | SEG48~51 | SEG52~55 | | | | | 0 | 0 | 1 | | SEG40~43 | SEG44~47 | SEG48~51 | Port5.3~0 | | | | | 0 | 1 | 0 | | SEG40~43 | SEG44~47 | Port6.3~0 | Port5.3~0 | | | | | 0 | 1 | 1 | | SEG40~43 | Port7.3~0 | Port6.3~0 | Port5.3~0 | | | | | 1 | Х | Х | | Port8.3~0 | Port7.3~0 | Port6.3~0 | Port5.3~0 | | | | | | | | 0 | | | | | Port3.0~3 | Port4.0~3 | 1/8 | | | | | 1 | | | | | COM8~11 | COM12~15 | 1/16 | ### **LCD RAM Mapped Address** LCD data RAM (\$100-\$1FF) is a dual port RAM that data can be transferred without any software restriction. Each bit represents a segment value, SEGn, corresponding to a COMn and can be set (LCD dot on) or reset (LCD dot off) by bit or nibble operation instructions. The following diagram shows the configuration of the RAM Mapped of LCD. ### **LCD RAM Area Configuration** | | | СОМО | | | | | COM1 | | | | | COM15 | | | |-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----------|-------|-------|-------|-------| | Addr | В3 | B2 | B1 | В0 | Addr | В3 | B2 | B1 | В0 | <br>Addr | В3 | B2 | B1 | В0 | | \$100 | SEG3 | SEG2 | SEG1 | SEG0 | \$110 | SEG3 | SEG2 | SEG1 | SEG0 | <br>\$1F0 | SEG3 | SEG2 | SEG1 | SEG0 | | \$101 | SEG7 | SEG6 | SEG5 | SEG4 | \$111 | SEG7 | SEG6 | SEG5 | SEG4 | <br>\$1F1 | SEG7 | SEG6 | SEG5 | SEG4 | | \$102 | SEG11 | SEG10 | SEG9 | SEG8 | \$112 | SEG11 | SEG10 | SEG9 | SEG8 | <br>\$1F2 | SEG11 | SEG10 | SEG9 | SEG8 | | \$103 | SEG15 | SEG14 | SEG13 | SEG12 | \$113 | SEG15 | SEG14 | SEG13 | SEG12 | <br>\$1F3 | SEG15 | SEG14 | SEG13 | SEG12 | | \$104 | SEG19 | SEG18 | SEG17 | SEG16 | \$114 | SEG19 | SEG18 | SEG17 | SEG16 | <br>\$1F4 | SEG19 | SEG18 | SEG17 | SEG16 | | \$105 | SEG23 | SEG22 | SEG21 | SEG20 | \$115 | SEG23 | SEG22 | SEG21 | SEG20 | <br>\$1F5 | SEG23 | SEG22 | SEG21 | SEG20 | | \$106 | SEG27 | SEG26 | SEG25 | SEG24 | \$116 | SEG27 | SEG26 | SEG25 | SEG24 | <br>\$1F6 | SEG27 | SEG26 | SEG25 | SEG24 | | \$107 | SEG31 | SEG30 | SEG29 | SEG28 | \$117 | SEG31 | SEG30 | SEG29 | SEG28 | <br>\$1F7 | SEG31 | SEG30 | SEG29 | SEG28 | | \$108 | SEG35 | SEG34 | SEG33 | SEG32 | \$118 | SEG35 | SEG34 | SEG33 | SEG32 | <br>\$1F8 | SEG35 | SEG34 | SEG33 | SEG32 | | \$109 | SEG39 | SEG38 | SEG37 | SEG36 | \$119 | SEG39 | SEG38 | SEG37 | SEG36 | <br>\$1F9 | SEG39 | SEG38 | SEG37 | SEG36 | | \$10A | SEG43 | SEG42 | SEG41 | SEG40 | \$11A | SEG43 | SEG42 | SEG41 | SEG40 | <br>\$1FA | SEG43 | SEG42 | SEG41 | SEG40 | | \$10B | SEG47 | SEG46 | SEG45 | SEG44 | \$11B | SEG47 | SEG46 | SEG45 | SEG44 | <br>\$1FB | SEG47 | SEG46 | SEG45 | SEG44 | | \$10C | SEG51 | SEG50 | SEG49 | SEG48 | \$11C | SEG51 | SEG50 | SEG49 | SEG48 | <br>\$1FC | SEG51 | SEG50 | SEG49 | SEG48 | | \$10D | SEG55 | SEG54 | SEG53 | SEG52 | \$11D | SEG55 | SEG54 | SEG53 | SEG52 | <br>\$1FD | SEG55 | SEG54 | SEG53 | SEG52 | | \$10E | - | - | - | - | \$11E | - | - | - | - | \$1FE | - | - | - | - | | \$10F | - | - | - | - | \$11F | - | - | - | - | \$1FF | - | - | - | - | Note: FAM space without name that listed above is empty space (no memory cell existed). ### **LCD Contrast Control** LCD contrast can easily be adjusted by software. The simplified LCD power supply circuit below illustrates the idea of how the LCD contrast ratio can be adjusted by software programming. Because the VR is connected between VP and VLCD, the required contrast ratio can be set by the value of register CVAR (\$03E). On the table below, it listed all the VR values according to different programming value of register, CVAR. Note that the default value of CVAR is zero. | CVAR.3 | CVAR.2 | CVAR.1 | CVAR.0 | VR | |--------|--------|--------|--------|------| | 0 | 0 | 0 | 0 | 35ΚΩ | | 0 | 0 | 0 | 1 | 30ΚΩ | | 0 | 0 | 1 | 0 | 25ΚΩ | | 0 | 0 | 1 | 1 | 20ΚΩ | | 0 | 1 | 0 | 0 | 15ΚΩ | | 0 | 1 | 0 | 1 | 10ΚΩ | | 0 | 1 | 1 | 0 | 5ΚΩ | | 0 | 1 | 1 | 1 | 0ΚΩ | | 1 | 0 | 0 | 0 | 40ΚΩ | | 1 | 0 | 0 | 1 | 45ΚΩ | | 1 | 0 | 1 | 0 | 50ΚΩ | | 1 | 0 | 1 | 1 | 55ΚΩ | | 1 | 1 | 0 | 0 | 60ΚΩ | | 1 | 1 | 0 | 1 | 65ΚΩ | | 1 | 1 | 1 | 0 | 70ΚΩ | | 1 | 1 | 1 | 1 | 75ΚΩ | #### **Low Power Consumption Modes** To save power, user can issue one of the Low Power consumption modes by instructions, STOP or HALT. Both of these modes can make the CPU going sleep. It means that CPU does nothing anyway until an external interrupt or a reset signal comes up. STOP mode will save more power than that of the others (HALT or NORMAL), however, it takes a little bit longer to wake up the CPU due to the settling time for main oscillator. | Operation mode | Issued by instruction | Main<br>oscillator | Watch<br>oscillator | RAM<br>Data | Registers<br>& Flags | I/O<br>Pins | Released by | |----------------|-----------------------|--------------------|---------------------|-------------|----------------------|-------------|----------------------------------| | Stop Mode | STOP | Stop | Alive | Hold | Hold | Hold | Reset, IRQ0~3, IRQT0 or IRQRT | | Halt Mode | HALT | Alive | Alive | Hold | Hold | Hold | Reset or any available interrupt | ### **Battery-low Detection** To monitor power consumption, the function of battery-low detection is enabled by setting ENBAT (\$01F.2) to one. The Battery-low detection table shows what the 3 bits, BAT.2-0 (\$03D.2-0), would respond while the battery power drops to a certain rank of voltage level. ENBAT should be reset to zero while it is not in use. #### n x m Optional Keyboard (n = 8, m = 4) To expand the number of keypads, sharing the keyboard scan-line with LCD drivers (COM0-n) may be the best way to do so. It means the LCD drivers (COM0-n) serve not only the LCD, but keyboard scanning. Furthermore, Port2 (INT2) is chosen for detecting the key pressed signal. Port2 behaves like a normal I/O port with interrupt function while KPAD = 0. After setting bit KPAD to 1, the built-in keyboard circuit will automatically scan and sample the keyboard all the time. The sampling data would then be reflected to Keyboard registers (\$028 to \$02F). If there is any one of the 32 bits going low (normal high), the KPRS bit will go high right away. Otherwise, KPRS will go low. However, keyboard de-bounce function is not offered for this version. #### **Battery-low detection table** | Power Supply Level | BAT.2 | BAT.1 | BAT.0 | |-----------------------|-------|-------|-------| | 4.4V < VDD | 0 | 0 | 0 | | $3.6V < VDD \le 4.4V$ | 1 | 0 | 0 | | 2.8V < VDD ≤ 3.6V | 1 | 1 | 0 | | VDD ≤ 2.8V | 1 | 1 | 1 | To prevent affecting the display quality from pressing key(s), there are two recommended methods: - 1. Disable Port2 internal pull-high resistors. Using external pull-high resistors ( $\sim 330 \mathrm{K}\Omega$ ) for Port2, and LCD must be enabled while using this keyboard scanning function. - 2. An inverting buffer may be added to isolate LCD driver signal. In this case, the sampling timing must be shifted to the reversed frame by setting bit KRVS to 1. In addition, Port2 must be set to input mode with data \$F so as to activate the pull-high resistors, and LCD must be enabled while using this keyboard scanning function. #### Watch-Dog Timer This Timer is designed to prevent the system from going into the deadlock or any unexpected shutdown condition. It shares the clock source of the watch oscillator, so that it can work properly even in the stop mode. The WDT is default disabled and can be enabled by means of wiring WDTEN pin to $V_{DD}$ . The WDT must be cleared by reset the bit WDRST (\$0D.3) before time-out (2 or 4 seconds selected by mask option; default is 4 seconds). Otherwise the WDT will send out a pulse signal (pulse width is about 1/64 msec) to reset the whole system. #### **DTMF Generation Circuit** This chip provides a dual tone multi-frequency (DTMF) generation circuit. The DTMF signal consists of two sine waves with which to access the switching system. The following figure shows the relationship between the key pressed and its dual tone frequencies. The DTMF generator employs 2 dedicate D/A converters, which can generate two separate single-tone signals, low-frequency group for Row and high-frequency group for Column. These two signals would finally mix together producing a Dual Tone Frequency Signal. Each single-tone signal consists of 32-level waveform that guarantees low distortion signal quality. This DTMF is basically controlled by a 4-bit write-only Tone Generator Control register, TGC, and the signal data would be prepared by programming another 4-bit write-only register called Tone Generator Data register, TGD. These two registers, TGC & TGD, would be cleared to zero while system is reset. Single Tone signal can also be generated for quality checking by means of programming TGC.1 or TGC.2. | COL | 1209Hz | 1336Hz | 1477Hz | 1633Hz | |-------|--------|--------|--------|--------| | 697Hz | 1 | 2 | 3 | Α | | 770Hz | 4 | 5 | 6 | В | | 852Hz | 7 | 8 | 9 | С | | 941Hz | # | 0 | * | D | #### Tone Generator Control Register: TGC (\$01A) | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Function | | | | |-------|-------|-------|-------|---------------|------------|------------|--| | Dit 3 | Dit 2 | Dit 1 | Bit 0 | Column signal | Row signal | DTMF power | | | | X | X | 0 | Disable | Disable | OFF | | | | 0 | 0 | 1 | Disable | Disable | ON | | | | 0 | 1 | 1 | Disable | Enable | ON | | | | 1 | 0 | 1 | Enable | Disable | ON | | | | 1 | 1 | 1 | Enable | Enable | ON | | ### Tone Generator Data Register: TGD (\$01B) | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Output Frequency | Digit | |-------|-------|-------|-------|------------------|--------| | 0 | 1 | 1 | 1 | 941 + 1336Hz | ″0 ″ | | 0 | 0 | 0 | 0 | 697 + 1209Hz | ″1 ″ | | 0 | 1 | 0 | 0 | 697 + 1336Hz | ″2 ″ | | 1 | 0 | 0 | 0 | 697 + 1477Hz | ″3 ″ | | 0 | 0 | 0 | 1 | 770 + 1209Hz | ″4 ″ | | 0 | 1 | 0 | 1 | 770 + 1336Hz | ″5 ″ | | 1 | 0 | 0 | 1 | 770 + 1477Hz | ″6 ″ | | 0 | 0 | 1 | 0 | 852 + 1209Hz | ″7 ″ | | 0 | 1 | 1 | 0 | 852 + 1336Hz | ″8 ″ | | 1 | 0 | 1 | 0 | 852 + 1477Hz | ″9 ″ | | 0 | 0 | 1 | 1 | 941 + 1209Hz | //* // | | 1 | 0 | 1 | 1 | 941 + 1477Hz | ″# ″ | | 1 | 1 | 0 | 0 | 697 + 1633Hz | ″A ″ | | 1 | 1 | 0 | 1 | 770 + 1633Hz | ″B ″ | | 1 | 1 | 1 | 0 | 852 + 1633Hz | "C " | | 1 | 1 | 1 | 1 | 941 + 1633Hz | ″D ″ | ### Clock Selection Register: CKS (\$00D) CKS.0~1 is in charge of controlling the speed of CPU. After the value of CKS.0~1 has been changed, the speed of CPU will be changed on the next instruction without any additional delay. ENOSC (CKS.2) is such a bit for controlling the clock source for FSK demodulator and Frequency counter for Ring detection. For Caller-ID application, it is recommended that ENOSC should be set to one during initialization. | Bit3 | Bit2 | Bit1 | Bit0 | Description | |------|------|------------------------------|------|---------------------------------------------------------------------------------| | | | 0 | 0 | System Clock = Fmain / 16 | | | | 0 1 System Clock = Fmain / 8 | | System Clock = Fmain / 8 | | | | | 0 | System Clock = Fmain / 4 | | | | 1 | 1 | Inhibited | | | 0 | | | Disable the clock for FSK demodulator | | | 1 | | | Enable the clock for FSK demodulator (Must be set to one during initialization) | ### **Beeper Output Circuit** The beep output circuit can be selected by setting the RAM-mapped register bit, BEEP (\$03D.0) to one. The beep mode register (BPM) is the register used to specify operation mode of the beep output circuit. This circuit can also be implement as a key-tone generator by software programming so that different key-tone may indicate different key operation message, such as, acceptance or error message. ### Beep Mode Register, BPM | BEEP (\$03D.0) | | BPM ( | (\$00E) | | P0.3 | BUZ | | | | |----------------|-------|-------|---------|-------|---------|------------------------------|------------------------------|------------------------------|--| | | врм.3 | ВРМ.2 | BPM.1 | ВРМ.0 | | CKS = xx10<br>(Tcyc = 1.1μs) | CKS = xx01<br>(Tcyc = 2.2μs) | CKS = xx00<br>(Tcyc = 4.4μs) | | | 0 | Х | X | Х | X | Enable | Disable | Disable | Disable | | | 1 | 0 | X | Х | X | Disable | Low | Low | Low | | | 1 | 1 | X | 0 | 0 | Disable | 7KHz | 3.5KHz | 1.7KHz | | | 1 | 1 | Х | 0 | 1 | Disable | 3.5KHz | 1.7KHz | 874Hz | | | 1 | 1 | X | 1 | 0 | Disable | 1.7KHz | 874Hz | 437Hz | | | 1 | 1 | Х | 1 | 1 | Disable | 874Hz | 437Hz | 219Hz | | #### **Built-in FSK Demodulator, Carrier Detector and Ring Detector** A FSK demodulator, Carrier detector and Ring detector are employed to serve the Calling Identification. These circuits are merged to a 4-bit CPU by several interface signals, which are described below: Fmain: System clock from main oscillator ENRD: Enable the internal Ring Detector PWDN: Switch off/on the FSK demodulator only RP: Ring pulse signal RT: Ring time signal XRT: Ring detected output signal RD: Ring detected signal (signal confirmed) CD: Carrier detected signal DOUT: Data output stream If there is any part of the Ring Detector has to be utilized, bit ENRD must be set to 1 first. $\overline{\text{CD}}$ or $\overline{\text{RD}}$ will be available only if ENOSC = 1. It is recommended that bit ENOSC should be set to one during initialization. Details should be referred to the section of Timing Description. ### Timing Diagram (ENRD = ENOSC = 1) #### **Timing description** #### A. Hardware detection with internal Ring Detector (ENRD=1) - Step 1: After power up initialization, CPU should enters into stop mode, and also FSK demodulator should enters into power down mode for saving power. - Step 2: During ringing, the internal Ring Detector will sense the ring-in signal and will send out an interrupt request, IRQRT, to CPU. After receiving such request, CPU will then activate the main oscillator, so as to enter into normal operation mode. - Step 3: Afterwards, CPU should keep on watching the bit RD (\$3C.2) until time out. If RD goes low (signal has been has been confirmed by internal ring detector), CPU should check the bit RT until it goes high. At this moment, #### B. Software detection with internal Ring Detector (ENRD=1) - Step 1: After power up initialization, CPU should enters into stop mode, and also FSK demodulator should enters into power down mode for saving power. - Step 2: During ringing, the internal Ring Detector will sense the ring-in signal and will send out an interrupt request, IRQRT, to CPU. After receiving such request, CPU will then activate the main oscillator, so as to enter into normal operation mode. - Step 3: Afterwards, CPU should check the bit RP (\$3D.3) bit if it is ring-in signal until time out. (Notes that checking the ringing frequency by software needs a relative complicate programming sequence!) If this RP signal has been confirmed by software, CPU should CPU should reset bit PWDN (\$3D.2) in order to turn on the FSK demodulator for detecting carrier. Otherwise, CPU should return to STOP mode until next. - Step 4: Once the FSK demodulator senses the FSK signal, the bit CD (\$3C.1) would go low and an interrupt request, IRQCD, would be issued. This interrupt request starts up the service routine for sampling out the data stream from the bit DOUT. - Step 5: CD and DOUT will go back to high after FSK signal disappeared. Also CPU should then return to STOP mode and prepares for another Ringing. - check the bit RT until it goes high. At this moment, CPU should reset bit PWDN (\$3D.2) in order to turn on the FSK demodulator for detecting carrier. Otherwise, CPU should return to STOP mode until next. - Step 4: Once the FSK demodulator senses the FSK signal, the bit CD (\$3C.1) would go low and an interrupt request, IRQCD, would be issued. This interrupt request starts up the service routine for sampling out the data stream from the bit DOUT. - Step 5: CD and DOUT will go back to high after FSK signal disappeared. Also CPU should then return to STOP mode and prepares for another Ringing. ### C. Software detection with external Ring Detector (ENRD=0, and IRQn is employed) - Step 1: After power up initialization, CPU should enters into stop mode, and also FSK demodulator should enters into power down mode for saving power. - Step 2: During ringing, the external Ring Detector will sense the ring-in signal and should send out a negative-edge signal to pin INTn/P1.n, so as to trigger IRQn. After receiving such request, CPU will then activate the main oscillator, so as to enter into normal operation mode. - Step 3: Afterwards, CPU should keep on watching the pin P1.n until it goes high. At this moment, CPU should reset bit PWDN - (\$3D.2) in order to turn on the FSK demodulator for detecting carrier. Otherwise, CPU should return to STOP mode until next. - Step 4: Once the FSK demodulator senses the FSK signal, the bit CD (\$3C.1) would go low and an interrupt request, IRQCD, would be issued. This interrupt request starts up the service routine for sampling out the data stream from the bit DOUT. - Step 5: CD and DOUT will go back to high after FSK signal disappeared. Also CPU should then return to STOP mode and prepares for another Ringing. ### Pin definition with its structure ### **RESET** To reset this chip, the reset pin should be held high at least two execution cycles. The following table shows the initial conditions for different operation mode after RESET. ### **RAM Mapped Register Initial Value in Normal mode** | Name | Address | Initial | R/W/s/r/t | No | ote | |-------------------------------------------------|------------|--------------|-------------|------------------------------|----------------------------| | Program Counter (PC) | - | \$0000 | R/W/s/r/t | Refer to section of Stack | pointer | | Stack Pointer (SP) | \$20~\$22 | \$023F | R/t | Refer to section of Stack | pointer | | Status Flag (SF) | _ | :1 | By software | Refer to section of Stack | pointer | | Carry Flag (CY) | _ | Retained | By software | Data will be loss (unknow | | | General register (A, B, V, X, Y, EX, EY) | _ | Retained | By software | Data will be loss (unknow | | | Data RAM | _ | Retained | R/W/s/r/t | Data will be loss (unknow | | | Interrupt | _ | retained | 10/0/3/1/0 | Data will be loss (drikilow) | IT Value / When VDD \ V1 | | - Interrupt enable (IE) | | :0 | s/r/t | 0 = Interrupt disabled | 1 = Interrupt enabled | | - All Request enable flags | | :0 | s/r/t | 0 = Request disabled | 1 = Request enabled | | - All Interrupt request flags | | :0 | r/t | 0 = No request | 1 = With request | | I/O Port | - | | | | | | - I/O mode of any port<br>- Data on any I/O pin | | :0<br>:1 | W<br>R/W/t | 0: Input | 1: Output | | - Pull-up resistor | | Enabled | 10,007 | | | | Timer | | | | Refer to section of RAM n | napped | | - Mode register (TMODn) | - | \$00 | W | | · · · · · | | - Counter register (TCnx) | | \$00 / \$000 | R | | | | - Load register (TLnx) | | \$00 / \$000 | W | | | | Serial Interface - Mode register (SIOM) | \$0C | \$0 | R/W | Refer to section of Serial | interface | | - Internal octal counter | \$0C | \$0<br>\$0 | F/VV | | | | - Serial data register (SIOH,SIOL) | \$0A,\$0B | Retained | R/W/t | | | | LCD | | | | Refer to section of LCD | | | - Control register (LCON) | \$17 | \$0 | W/s/r | | | | - Mode register (LMOD0-1) | \$18, \$19 | \$0 | W | | | | CKS.1.0 | \$0D.1,0 | :00 | W | :00 = Fmain/16 :01 = F | | | ENOSC (CKS.2) | \$0D.2 | :0 | W | It must be set to one durir | | | BPM | \$0E | :0000 | W | Refer to section of BEEPE | | | TGC | \$1A | :0000 | W | Refer to section of DTMF | | | TGD | \$1B | :0000 | W | Refer to section of DTMF | | | KRVS | \$1F.0 | :0 | W/t | 0 = Non inverted | 1 = Inverted | | KPAD | \$1F.1 | :0 | W/t | 0 = Disable | 1 Enable | | ENBAT | \$1F.2 | :0 | W | 0 = Disable | 1 = Enable | | KPRS | \$1F.3 | :0 | R/t | 0 = Any key released | 1 = Any key pressed | | KREG0~7 | \$28~\$2F | :1111 | R/W/t | 0 = Key pressed | 1 = Key released | | DOUT | \$3C.0 | :1 | R/t | Data output stream | T | | CD | \$3C.1 | :1 | R/t | 0 = Carrier detected | 1 = No carrier | | RD | \$3C.2 | :1 | R/t | 0 = Ring detected | 1 = No Ring | | RT | \$3C.3 | :1 | R/t | 0 = Ring time detected | 1 = No Ring time signal | | PWDN | \$3D.2 | :1 | W | 0 = FSK power up | 1 = FSK power down | | ENRD | \$3D.1 | :1 | W | 0 = Disable ring | 1 = Enable ring detector | | BEEP | \$3D.0 | :0 | W | 0 = I/O Enabled | 1 = Beeper enabled | | BAT.0 | \$3D.0 | :1 | R/t | 0 = VDD > 2.8V | 1 = V <sub>DD</sub> ≤ 2.8V | | BAT.1 | \$3D.1 | :1 | R/t | 0 = VDD > 3.6V | 1 = V <sub>DD</sub> ≤ 3.6V | | BAT.2 | \$3D.2 | :1 | R/t | 0 = VDD > 4.4V | 1 = V <sub>DD</sub> ≤ 4.4V | | RP | \$3D.3 | :0 | R/t | Refer to section of RING | DETECTOR | | CVAR.0-3 | \$3E.0-3 | :0000 | W | Refer to section of LCD C | | **Note:** n = 0, 1, 2, 3; x = 0, 1, 2 \$data = Hexadecimal data, :data = Binary data, $V_T$ = Retention voltage ### **Addressing Mode** As shown below, there are 3 kinds of RAM addressing modes and 5 kinds of ROM addressing modes. #### **RAM Addressing Mode** 1. Register indirect addressing: | Bit location | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | RAM address | V3 | V2 | V1 | V0 | Х3 | X2 | X1 | X0 | Y3 | Y2 | Y1 | Y0 | 2. Direct addressing: | Bit location | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | RAM address | 0 | 0 | d9 | d8 | d7 | d6 | d5 | d4 | d3 | d2 | d1 | d0 | 3. Memory register addressing: | Bit location | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | RAM address | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | m3 | m2 | m1 | m0 | #### **ROM** addressing mode 1. Direct addressing: | Bit location | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | ROM address | k3 | k2 | k1 | k0 | d9 | d8 | d7 | d6 | d5 | d4 | d3 | d2 | d1 | d0 | Example: LBR label ;label is an absolute address complied by the assembler 2. Zero page addressing: | Bit location | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | ROM address | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | а5 | a4 | а3 | a2 | a1 | a0 | Example: CAL addr ;addr = a0~5 3. Short branch addressing: | Bit location | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | ROM address | | | | | | | х7 | х6 | х5 | x4 | х3 | x2 | x1 | x0 | Example: Lab1: BR addr ;addr = x0~7, local page address (256 addresses per page). ;If Lab1 is the last address of that page (Lab1 = \$XXFF), ;the branch address will be pointer to that address (x0~7) of the next page. 4. Table jump addressing: | Bit location | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | ROM address | 0 | 0 | р3 | p2 | p1 | р0 | В3 | B2 | B1 | B0 | A3 | A2 | A1 | Α0 | Example: TJMP p ;p = p0~3, A0~3 = content of A register, B0~3 = content of B register 5. Table data addressing: | Bit location | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | ROM address | 0 | 0 | р3 | p2 | p1 | p0 | В3 | B2 | B1 | B0 | A3 | A2 | A1 | A0 | Let ROM data = M9, M8, M7, M6, M5, M4, M3, M2, M1, M0 If R08 = 1, then Register B $\leftarrow$ M4~7 and Register A $\leftarrow$ M0~3 If R09 = 1, then Port3 $\leftarrow$ M4~7 and Port2 $\leftarrow$ M0~3 Example: T p ;p = $p0\sim3$ , $A0\sim3$ = content of A register, $B0\sim3$ = content of B register #### **Instruction Set** #### 1. Transfer instruction - 1a. Immediate instruction - 1b. Register to register instruction - 1c. RAM address instruction - 1d. RAM register instruction ### 2. Bit operation instruction ### 3. Compare instruction ### 4. Arithmetic and logical instruction ### 5. Control instruction - 5a. Branch instruction - 5b. Subroutine stack control instruction - 5c. CPU control instruction - 5d. Table data generation instruction | Symbol | Descrip | otions | |-------------------|-------------------------------------------------------------------------------|--------------------------------------------------| | CY | Carry Flag | | | SF | Status Flag | | | PC | Program Counter | | | NZ | Virtual Flag for non zero result (result ≠ 0) | ─ ✓ Virtual Flag is not a real one, but would | | NB | Virtual Flag for result without borrowed (result $\geq 0$ ) | reflect a 1 to Status Flag in some | | OVF | Virtual Flag for overflowed result (result > 15) | operations. | | W/C | Word / Execution Cycle | | | $\leftarrow$ | Transfer to (Copy to) | | | $\leftrightarrow$ | Exchange with | | | k | 4-bit block address (1 block = 1024 memory address | ·) | | р | 4-bit page address (1 page = 256 memory address) | | | а | 6-bit address | | | Х | 8-bit address | | | d | 10-bit address | | | i | Immediate data | | | m | Memory register index (0~15)<br>e.g. RTA 12 ;Store the data of R12 to A | register | | n | 2-bit data that indicates the bit location of a memory | data or register | | М | A specific memory bit representation | | | N | The current no of level of subroutine | | | M.n | A specific memory bit representation e.g. \$2.3 ;represents the 4th bit of da | ata of memory \$2 | | \$data | Hexadecimal data | Data without '\$' sign or ':' sign is assumed to | | :data | Binary data | be decimal data | # Descriptions ## 1. Transfer instruction: ## 1a. Immediate Instructions | Operation | Mnemonic | Code | SF | W/C | Function | |----------------------------------------|-----------|--------------|----|-----|---------------------| | Store immediate to A | ITA i | 130 + i | | 1/1 | A ← i | | Store immediate to B | ITB i | 100 + i | | 1/1 | B ← i | | Store immediate to memory, Increment Y | ITMIY i | 190 + i | NZ | 1/1 | M ← i,<br>Y ← Y + 1 | | Store immediate to direct memory | ITMD i, d | 2A0 + i<br>d | | 2/2 | M (direct) ← i | ## 1b. Register to register instructions | Operation | Mnemonic | Code | SF | W/C | Function | |-------------------|----------|------------|----|-----|-------------------------| | Store B to A | ВТА | 044 | | 1/1 | $A \leftarrow \ B$ | | Store V to A | VTA | 200<br>000 | | 2/2 | $A \leftarrow V$ | | Store Y to A | YTA | 0AF | | 1/1 | $A \leftarrow Y$ | | Store EX to A | EXTA | 064 | | 1/1 | $A \leftarrow EX$ | | Store EY to A | EYTA | 054 | | 1/1 | $A \leftarrow EY$ | | Store Rm to A | RTA m | 170 + m | | 1/1 | $A \leftarrow Rm$ | | Store A to B | ATB | 0C4 | | 1/1 | $B \leftarrow A$ | | Exchange A and Rm | XAR m | 1F0 + m | | 1/1 | $A \leftrightarrow Rm$ | ## 1c. RAM address instructions | Operation | Mnemonic | Code | SF | W/C | Function | |------------------------------|-------------------|------------|-----|-----|----------------------------------------------| | Store immediate to V | ITV i | 0F0 + i | | 1/1 | V ← i | | Store immediate to X | ITX i | 120 + i | | 1/1 | X ← i | | Store immediate to Y | ITY i | 110 + i | | 1/1 | Y←i | | Store A to X | ATX | 0E4 | | 1/1 | $X \leftarrow A$ | | Store A to Y | ATY | 0D4 | | 1/1 | $Y \leftarrow A$ | | Store A to V | ATV | 210<br>000 | | 2/2 | V ← A | | Increment Y | IY | 05C | NZ | 1/1 | Y ← Y + 1 | | Decrement Y | DY | 0DF | NB | 1/1 | Y ← Y - 1 | | Y add A | YAA | 058 | OVF | 1/1 | $Y \leftarrow Y + A$ | | Subtract A from Y | YSA | 0D8 | NB | 1/1 | Y ← Y - A | | Exchange X and EX | XEX | 001 | | 1/1 | $X \leftrightarrow EX$ | | Exchange Y and EY | ange Y and EY XEY | | | 1/1 | $Y \leftrightarrow EY$ | | Exchange (X, Y) and (EX, EY) | XEXY | 003 | | 1/1 | $X \leftrightarrow EX, Y \leftrightarrow EY$ | ## 1. Transfer instruction: (continued) ## 1d. RAM Register instructions | Operation | Mnemonic | Code | SF | W/C | Function | |---------------------------------------------------------------|-----------|----------|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Store memory to A | MTA | 090 | | 1/1 | $A \leftarrow M$ | | Store memory to A,<br>Exchange X and EX | MTAX | 091 | | 1/1 | $\begin{array}{c} A \leftarrow M, \\ X \leftrightarrow EX \end{array}$ | | Store memory to A,<br>Exchange Y and EY | MTAY | 092 | | 1/1 | $\begin{array}{c} A \leftarrow M, \\ Y \leftrightarrow EY \end{array}$ | | Store memory to A,<br>Exchange X and EX,<br>Exchange Y and EY | MTAXY | 093 | | 1/1 | $\begin{array}{l} A \leftarrow M, \\ X \leftrightarrow EX, \\ Y \leftrightarrow EY \end{array}$ | | Store direct memory to A | MTAD addr | 290<br>d | | 2/2 | A ← M (direct) | | Store memory to B | MTB | 040 | | 1/1 | $B \leftarrow M$ | | Store memory to B,<br>Exchange X and EX | MTBX | 041 | | 1/1 | $\begin{array}{c} B \leftarrow M, \\ X \leftrightarrow EX \end{array}$ | | Store memory to B,<br>Exchange Y and EY | MTBY | 042 | | 1/1 | $\begin{array}{c} B \leftarrow M, \\ Y \leftrightarrow E Y \end{array}$ | | Store memory to B,<br>Exchange X and EX,<br>Exchange Y and EY | MTBXY | 043 | | 1/1 | $\begin{aligned} B &\leftarrow M, \\ X &\leftrightarrow EX, \\ Y &\leftrightarrow EY \end{aligned}$ | | Store A to memory | ATM | 098 | | 1/1 | $M \leftarrow A$ | | Store A to memory<br>Exchange X and EX | ATMX | 099 | | 1/1 | $\begin{array}{l} M \leftarrow A, \\ X \leftrightarrow EX \end{array}$ | | Store A to memory<br>Exchange Y and EY | ATMY | 09A | | 1/1 | $\begin{array}{c} M \leftarrow A, \\ Y \leftrightarrow E Y \end{array}$ | | Store A to memory,<br>Exchange X and EX,<br>Exchange Y and EY | ATMXY | 09B | | 1/1 | $\begin{aligned} \mathbf{M} &\leftarrow \mathbf{A}, \\ \mathbf{X} &\leftrightarrow \mathbf{E}\mathbf{X}, \\ \mathbf{Y} &\leftrightarrow \mathbf{E}\mathbf{Y} \end{aligned}$ | | Store A to direct memory | ATMD addr | 298<br>d | | 2/2 | M (direct) ← A | | Store A to memory,<br>Increment Y | ATMIY | 050 | NZ | 1/1 | M ← A,<br>Y ← Y + 1 | | Store A to memory,<br>Increment Y,<br>Exchange X and EX | ATMIYX | 051 | NZ | 1/1 | $\begin{aligned} M &\leftarrow A, \\ Y &\leftarrow Y + 1, \\ X &\leftrightarrow EX \end{aligned}$ | | Store A to memory,<br>Decrement Y | ATMDY | 0D0 | NB | 1/1 | M ← A,<br>Y ← Y - 1 | | Store A to memory,<br>Decrement Y,<br>Exchange X and EX | ATMDYX | 0D1 | NB | 1/1 | $\begin{aligned} M &\leftarrow A, \\ Y &\leftarrow Y - 1, \\ X &\leftrightarrow EX \end{aligned}$ | ### 1. Transfer instruction: (continued) ## 1d. RAM Register Instructions (continued) | Operation | Mnemonic | Code | SF | W/C | Function | |-------------------------------------------------------------------|-----------|----------|----|-----|--------------------------------------------------------------------------------------------------------| | Exchange A and memory | XAM | 080 | | 1/1 | $A \leftrightarrow M$ | | Exchange A and memory,<br>Exchange X and EX | XAMX | 081 | | 1/1 | $\begin{array}{c} A \leftrightarrow M, \\ X \leftrightarrow EX \end{array}$ | | Exchange A and memory,<br>Exchange Y and EY | XAMY | 082 | | 1/1 | $\begin{array}{c} A \leftrightarrow M, \\ Y \leftrightarrow E Y \end{array}$ | | Exchange A and memory,<br>Exchange X and EX,<br>Exchange Y and EY | XAMXY | 083 | | 1/1 | $\begin{array}{l} A \leftrightarrow M, \\ X \leftrightarrow EX, \\ Y \leftrightarrow EY \end{array}$ | | Exchange A and direct memory | XAMD addr | 280<br>d | | 2/2 | $A \leftrightarrow M$ (direct) | | Exchange B and memory | XBM | 0C0 | | 1/1 | $B \leftrightarrow M$ | | Exchange B and memory,<br>Exchange X and EX | XBMX | 0C1 | | 1/1 | $\begin{array}{c} B \leftrightarrow M, \\ X \leftrightarrow E X \end{array}$ | | Exchange B and memory,<br>Exchange Y and EY | XBMY | 0C2 | | 1/1 | $\begin{array}{c} B \leftrightarrow M, \\ Y \leftrightarrow E Y \end{array}$ | | Exchange B and memory,<br>Exchange X and EX,<br>Exchange Y and EY | XBMXY | 0C3 | | 1/1 | $\begin{array}{l} B \leftrightarrow M, \\ X \leftrightarrow E X, \\ Y \leftrightarrow E Y \end{array}$ | ## 2. Bit Operation Instructions | Operation | Mnen | nonic | Code | SF | W/C | Function | |-------------------------|------|---------|--------------|-----|-----|-----------------------------| | Set Memory Bit | SM | n | 088 + n | | 1/1 | M.n ← 1 | | Set direct Memory Bit | SMD | n, addr | 288 + n<br>d | | 2/2 | M.n (direct) ← 1 | | Reset Memory Bit | RM | n | 084 + n | | 1/1 | M.n ← 0 | | Reset direct Memory Bit | RMD | n, addr | 284 + n<br>d | | 2/2 | M.n (direct) $\leftarrow$ 0 | | Test Memory Bit | TM | n | 08C + n | M.n | 1/1 | SF ← M.n | | Test direct Memory Bit | TMD | n, addr | 28C + n<br>d | M.n | 2/2 | SF ← M.n (direct) | ## 3. Compare Instructions | Operation | Mnemo | onic | Code | SF | W/C | Function | | |---------------------------------------------------|-------|---------|--------------|----|-----|-------------------------------------------------------------------------------------------------------------------------|--| | Immediate does not equal to Memory | INEM | i | 020 + i | NZ | 1/1 | If i $\neq$ M then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | Immediate does not equal to direct Memory | INEMD | i, addr | 020 + i<br>d | NZ | 2/2 | If i $\neq$ M (direct) then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | A does not equal to Memory | ANEM | | 008 | NZ | 1/1 | If A $\neq$ M then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | A does not equal to direct Memory | ANEMD | addr | 208<br>d | NZ | 2/2 | If A $\neq$ M (direct) then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | B does not equal to Memory | BNEM | | 048 | NZ | 1/1 | If B $\neq$ M then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | Y does not equal to Immediate | YNEI | i | 070 + i | NZ | 1/1 | If Y $\neq$ I then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | Immediate is less than or equals to Memory | ILEM | i | 030 + i | NZ | 1/1 | $\begin{array}{l} \text{If i} \leq M \text{ then SF} \leftarrow 1 \\ \text{else SF} \leftarrow 0 \end{array}$ | | | Immediate is less than or equals to direct Memory | ILEMD | i, addr | 230 + i<br>d | NZ | 2/2 | $\begin{array}{l} \text{If } i \leq M \text{ (direct) then SF} \leftarrow 1 \\ \text{else SF} \leftarrow 0 \end{array}$ | | | A is less than or equals to Memory | ALEM | | 018 | NZ | 1/1 | If A $\leq$ M then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | A is less than or equals to direct<br>Memory | ALEMD | addr | 218<br>d | NZ | 2/2 | If A $\leq$ M (direct) then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | A is less than or equals to<br>Immediate | ALEI | i | 1B0 + i | NZ | 1/1 | If A $\leq$ I then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | | B is less than or equals to Memory | BLEM | | 0C8 | NZ | 1/1 | If B $\leq$ M then SF $\leftarrow$ 1 else SF $\leftarrow$ 0 | | ## 4. Arithmetic and Logical Instructions | Operation | Mnemonic | Code | SF | W/C | Function | | |---------------------------------------|------------|----------|-----|-----|------------------------------------------------------------------------------------------|--| | Add immediate to A | AAI i | 180 + i | OVF | 1/1 | A ← A + i | | | Increment B | IB | 04C | NZ | 1/1 | B ← B + 1 | | | Decrement B | DB | 0CF | NB | 1/1 | B ← B - 1 | | | Decimal Adjust for Addition | DAA | 0A6 | | 1/1 | See instruction manual | | | Decimal Adjust for Subtraction | DAS | 0AA | | 1/1 | See instruction manual | | | Negative of A | NEGA | 060 | | 1/1 | $A \leftarrow \overline{A} + 1$ | | | Complement of B | NOTB | 240 | | 1/1 | $B \leftarrow \overline{B}$ | | | Rotate A to right with CY | RORC | 0A0 | | 1/1 | Rotate A to right with CY | | | Rotate A to left with CY | ROLC | 0A1 | | 1/1 | Rotate A to left with CY | | | Set CY | SC | 0EF | | 1/1 | CY ← 1 | | | Reset CY | RC | 0EC | | 1/1 | CY ← 0 | | | Test CY | TC | 06F | CY | 1/1 | SF ← CY | | | Add Memory to A | AAM | 004 | OVF | 1/1 | A ← A + M | | | Add direct Memory to A | AAMD addr | 204<br>d | OVF | 2/2 | A ← A + M (direct) | | | Add Memory to A with CY | AAMC | 014 | OVF | 1/1 | $\begin{aligned} A \leftarrow A + M + CY, \\ CY \leftarrow OVF \end{aligned}$ | | | Add direct Memory to A with CY | AAMCD addr | 214<br>d | OVF | 2/2 | $\begin{aligned} A \leftarrow A + M & (direct) + CY, \\ CY \leftarrow OVF \end{aligned}$ | | | Subtract A from Memory with CY | MSAC | 094 | NB | 1/1 | $\begin{array}{c} A \leftarrow M - A - \overline{CY}, \\ CY \leftarrow NB \end{array}$ | | | Subtract A from direct Memory with CY | MSACD | 294<br>d | NB | 2/2 | $A \leftarrow M \text{ (direct)} - A - \overline{CY},$<br>$CY \leftarrow NB$ | | | OR A with B | ORB | 248 | | 1/1 | A ← A OR B | | | AND A with Memory | ANDM | 09C | NZ | 1/1 | $A \leftarrow A \; AND \; M$ | | | AND A with direct Memory | ANDMD addr | 29C<br>d | NZ | 2/2 | A ← A AND M (direct) | | | OR A with Memory | ORM | 00C | NZ | 1/1 | A ← A OR M | | | OR A with direct Memory | ORMD addr | 20C<br>d | NZ | 2/2 | A ← A OR M (direct) | | | XOR A with Memory | XORM | 01C | NZ | 1/1 | $A \leftarrow A XOR M$ | | | XOR A with direct Memory | XORMD addr | 21C<br>d | NZ | 2/2 | A ← A XOR M (direct) | | ### 5. Control Instructions ## 5a. Branch Instruction | Operation | Mnemonic | | eration Mnemonic | | Code | SF | W/C | Function | |---------------------------------|----------|------|------------------|---|------|-----------------------------------------------------------------------------------|-----|----------| | Short branch on status flag = 1 | BR | addr | 300 + x | 1 | 1/1 | if SF = 0 then PC $\leftarrow$ PC + 1 else PC $\leftarrow$ ((PC+1) & 3F00) + x | | | | Long branch on status flag = 1 | LBR | addr | 270 + k<br>d | 1 | 2/2 | Branch if status = 1 | | | | Long jump | JMP | addr | 250 + k<br>d | | 2/2 | Unconditional jump for long distant | | | | Table jump | TJMP | р | 0B0 + p | | 1/1 | Unconditional jump with variable address assigned by register A, B and constant p | | | ### 5b. Subroutine Stack Control Instruction | Operation | Mnen | nonic | Code | SF | W/C | Function | | |-------------------------------------|------|-------|--------------|-------------------|-----|--------------------------------------------------------------------------------------------------------------------------|--| | Zero-page subroutine call on status | CAL | addr | 2C0 + a | 1 | 1/2 | Call subroutine if SF = 1 | | | (Please refer to ROM MAP) | | | | | 1/1 | Next instruction if SF = 0 | | | Subroutine call on status | CALL | addr | 260 + k<br>d | 1 | 2/2 | Call subroutine if SF = 1 | | | Return from subroutine | RET | | 010 | | 1/3 | Recovers the previous address (PCN-1) from stack and return to the upper level routine | | | Return from interrupt service | RETI | | 011 | SF <sub>N-1</sub> | 1/3 | IE ← 1, recovers the previous CY, SF and address (CYN-1, SFN-1 & PCN-1) from stack and return to the upper level routine | | ## 5c. CPU Control Instruction | Operation | Mnemonic | Code | SF | W/C | Function | | |---------------------------|----------|------|----|-----|---------------------------|--| | No operation | NOP | 000 | | 1/1 | No operation | | | HALT mode | HALT | 24C | | 1/1 | Enter Halt Mode | | | STOP mode | STOP | 24D | | 1/1 | Enter Stop Mode | | | Start serial transmission | STS | 244 | | 1/1 | Enter Serial Transmission | | ### 5d. Table Data Generation Instruction | Operation | Mnemonic | Code | SF | W/C | Function | |--------------------------|----------|---------|----|-----|--------------------------------------------------------------------------------| | Table pattern generation | Т р | 2B0 + p | | 1/2 | Extract the ROM data from the address assigned by register A, B and constant p | 40 # Application Circuit (for reference only) ### **Ordering Information** | Part No. | Package | |-----------|-----------| | SH93420AH | CHIP FORM | | SH93420AF | 100L QFP | #### **Bonding Diagram** Chip size (X \* Y) = (132 mils \* 132 mils)Pad pitch (min, max) = $(119, 130 \mu\text{m})$ Pad size = $90 \mu\text{m} * 90 \mu\text{m}$ Chip thickness = 20 mils or 25 milsSubstrate polarity = GROUND **Note:** For pad assignment, please refer to the following page. | D = -1 # | Duimanus | V as andinate | V as sudingto | D- 4 # | D.: | V as andinata | V an audimete | |----------|--------------|---------------|--------------------------|----------|------------|--------------------------|---------------| | Pad # | Primary name | X co-ordinate | Y co-ordinate<br>1530.27 | Pad # | | X co-ordinate<br>1265.22 | Y co-ordinate | | 1 | SEG11 | -1265.22 | | 51 | VDD | | -1530.27 | | 2 | SEG12 | -1395.27 | 1530.27 | 52<br>53 | XOUT | 1395.27 | -1530.27 | | 3 | SEG13 | -1530.27 | 1530.27 | 53 | XIN | 1530.27 | -1530.27 | | 4 | SEG14 | -1530.27 | 1395.27 | 54 | TEST | 1530.27 | -1395.27 | | 5 | SEG15 | -1530.27 | 1265.22 | 55 | XTOUT | 1530.27 | -1265.22 | | 6 | SEG16 | -1530.27 | 1135.17 | 56 | XTIN | 1530.27 | -1135.17 | | 7 | SEG17 | -1530.27 | 1010.16 | 57 | REST | 1530.27 | -1010.16 | | 8 | SEG18 | -1530.27 | 885.15 | 58 | PORT0.0 | 1530.27 | -885.15 | | 9 | SEG19 | -1530.27 | 766.12 | 59 | PORT0.1 | 1530.27 | -766.13 | | 10 | SEG20 | -1530.27 | 647.1 | 60 | PORT0.2 | 1530.27 | -647.1 | | 11 | SEG21 | -1530.27 | 528.07 | 61 | PORT0.3 | 1530.27 | -528.08 | | 12 | SEG22 | -1530.27 | 409.05 | 62 | PORT1.0 | 1530.27 | -409.05 | | 13 | SEG23 | -1530.27 | 290.02 | 63 | PORT1.1 | 1530.27 | -290.03 | | 14 | SEG24 | -1530.27 | 174.01 | 64 | PORT1.2 | 1530.27 | -174.02 | | 15 | SEG25 | -1530.27 | 58 | 65 | PORT1.3 | 1530.27 | -58.01 | | 16 | SEG26 | -1530.27 | -58.01 | 66 | AVDD | 1530.27 | 58 | | 17 | SEG27 | -1530.27 | -174.02 | 67 | TIP | 1530.27 | 174.01 | | 18 | SEG28 | -1530.27 | -290.03 | 68 | RING | 1530.27 | 290.02 | | 19 | SEG29 | -1530.27 | -409.05 | 69 | AGND | 1530.27 | 409.05 | | 20 | SEG30 | -1530.27 | -528.08 | 70 | RDET | 1530.27 | 528.07 | | 21 | SEG31 | -1530.27 | -647.1 | 71 | XRT | 1530.27 | 647.1 | | 22 | SEG32 | -1530.27 | -766.13 | 72 | DTMF | 1530.27 | 766.12 | | 23 | SEG33 | -1530.27 | -885.15 | 73 | GND | 1530.27 | 885.15 | | 24 | SEG34 | -1530.27 | -1010.16 | 74 | COM0 | 1530.27 | 1010.16 | | 25 | SEG35 | -1530.27 | -1135.17 | 75 | COM1 | 1530.27 | 1135.17 | | 26 | SEG36 | -1530.27 | -1265.22 | 76 | COM2 | 1530.27 | 1265.22 | | 27 | SEG37 | -1530.27 | -1395.27 | 77 | COM3 | 1530.27 | 1395.27 | | 28 | SEG38 | -1530.27 | -1530.27 | 78 | COM4 | 1530.27 | 1530.27 | | 29 | SEG39 | -1395.27 | -1530.27 | 79 | COM5 | 1395.27 | 1530.27 | | 30 | SEG40/P8.3 | -1265.22 | -1530.27 | 80 | COM6 | 1265.22 | 1530.27 | | 31 | SEG41/P8.2 | -1135.17 | -1530.27 | 81 | COM7 | 1135.17 | 1530.27 | | 32 | SEG42/P8.1 | -1010.16 | -1530.27 | 82 | COM8/P3.0 | 1010.16 | 1530.27 | | 33 | SEG43/P8.0 | -885.15 | -1530.27 | 83 | COM9/P3.1 | 885.15 | 1530.27 | | 34 | SEG44/P7.3 | -766.13 | -1530.27 | 84 | COM10/P3.2 | 766.12 | 1530.27 | | 35 | SEG45/P7.2 | -647.1 | -1530.27 | 85 | COM11/P3.3 | 647.1 | 1530.27 | | 36 | SEG46/P7.1 | -528.08 | -1530.27 | 86 | COM12/P4.0 | 528.07 | 1530.27 | | 37 | SEG47/P7.0 | -409.05 | -1530.27 | 87 | COM13/P4.1 | 409.05 | 1530.27 | | 38 | SEG48/P6.3 | -290.03 | -1530.27 | 88 | COM14/P4.2 | 290.02 | 1530.27 | | 39 | SEG49/P6.2 | -174.02 | -1530.27 | 89 | COM15/P4.3 | 174.01 | 1530.27 | | 40 | SEG50/P6.1 | -58.01 | -1530.27 | 90 | SEG0 | 58 | 1530.27 | | 41 | SEG51/P6.0 | 58 | -1530.27 | 91 | SEG1 | -58.01 | 1530.27 | | 42 | SEG52/P5.3 | 174.01 | -1530.27 | 92 | SEG2 | -174.02 | 1530.27 | | 43 | SEG53/P5.2 | 290.02 | -1530.27 | 93 | SEG3 | -290.03 | 1530.27 | | 44 | SEG54/P5.1 | 409.05 | -1530.27 | 94 | SEG4 | -409.05 | 1530.27 | | 45 | SEG55/P5.0 | 528.07 | -1530.27 | 95 | SEG5 | -528.08 | 1530.27 | | 46 | PORT2.3 | 647.1 | -1530.27 | 96 | SEG6 | -647.1 | 1530.27 | | 47 | PORT2.2 | 766.12 | -1530.27 | 97 | SEG7 | -766.13 | 1530.27 | | 48 | PORT2.1 | 885.15 | -1530.27 | 98 | SEG8 | -885.15 | 1530.27 | | 49<br>50 | PORT2.0 | 1010.16 | -1530.27 | 99 | SEG9 | -1010.16 | 1530.27 | | 50 | WDTEN | 1135.17 | -1530.27 | 100 | SEG10 | -1135.17 | 1530.27 | | - | TEST | 1130.67 | -1405.15 | | | | | ### **Package Information** QFP 100L Outline Dimensions unit: inches/mm | Symbol | Dimensions in inches | Dimensions in mm | |------------------|------------------------|---------------------| | Α | 0.130 Max | 3.30 Max | | $A_1$ | 0.004 Min | 0.10 Min | | $A_2$ | $0.112 \pm 0.005$ | 2.85 ± 0.13 | | b | 0.012 +0.004<br>-0.002 | 0.30 +0.10<br>-0.05 | | С | 0.006 +0.004<br>-0.002 | 0.15 +0.10<br>-0.05 | | D | 0.551 ± 0.005 | 14.00 ± 0.13 | | Е | $0.787 \pm 0.005$ | 20.00 ± 0.13 | | e | $0.026 \pm 0.006$ | 0.65 ± 0.15 | | F | 0.742 NOM | 18.85 NOM | | $G_{\mathtt{D}}$ | 0.693 NOM | 17.60 NOM | | $G_E$ | 0.929 NOM | 23.60 NOM | | H <sub>D</sub> | $0.740 \pm 0.012$ | 18.80 ± 0.31 | | H <sub>E</sub> | $0.976 \pm 0.012$ | 24.79 ± 0.31 | | L | $0.047 \pm 0.008$ | 1.19 ± 0.20 | | L <sub>1</sub> | $0.095 \pm 0.008$ | 2.41 ± 0.20 | | у | 0.006 Max | 0.15 Max | | θ | 0° ~ 12° | 0° ~ 12° | #### Note: - Dimensions D & E do not include resin fins. - The dimensions GD & GE are for the reference of surface mount PC Board design only. # **Revision History** ## Version 1.0 ■ Preliminary specification ## Version 1.01 ■ Block Diagram