

# SH79F1616

# Enhanced 8051 Microcontroller with 10bit ADC

# 1. Features

- 8bits micro-controller with Pipe-line structured 8051 compatible instruction set
- Flash ROM: 16K Bytes
- RAM: internal 256 Bytes, external 256 Bytes, LCD RAM 19 Bytes
- EEPROM-like: 1K Bytes
- Operation Voltage: V<sub>DD</sub> = 2V - 5.5V, f<sub>OSC</sub> = 2MHz - 12MHz
- Oscillator (code option)
   Crystal oscillator: 2MHz 12MHz
   Ceramic oscillator: 2MHz 12MHz
  - Ceramic oscillator: 2MHz 1 - Internal RC: 12MHz
  - 30 CMOS bi-directional I/O pins
- 30 CMOS bi-directional I/O
   8 Large-current drive ports
- Built-in pull-up resistor for input pin
- One 12-bit PWM
- Four 16-bit timer/counters T2, T3, T4 and T5
- Powerful interrupt sources:
  - Timer2, 3, 4, 5
  - INT2, 3
  - INT40, INT41, INT42, INT43
  - ADC, SCM, LPD, EUART
  - PWM

- EUART
- 8channels 10-bits Analog Digital Converter (ADC), with comparator function built-in
- Buzzer
  - LED Driver - 8 COM X 5 SEG (1/8 DUTY)
    - 4 COM X 5 SEG (1/4 DUTY)
- LCD Driver
   8 COM X 10 SEG (1/8 DUTY, 1/4 BIAS)
   4 COM X 10 SEG (1/4 DUTY, 1/3 BIAS)
- Low Voltage Reset (LVR) function (enabled by code option)
   LVR voltage level 1: 4.3V
  - LVR voltage level 2: 2.1V
- CPU Machine cycle: 1 oscillator clock
- Watch Dog Timer (WDT)
- Warm-up Timer
- Support Low power operation modes:
   Idle Mode
  - Power-Down Mode
- Flash Type
- Package: LQFP32

# 2. General Description

The SH79F1616 is a high performance 8051 compatible micro-controller, regard to its build-in Pipe-line instruction fetch structure, that helps the SH79F1616 can perform more fast operation speed and higher calculation performance, if compare SH79F1616 with standard 8051 at same clock speed.

The SH79F1616 retains most features of the standard 8051. These features include internal 256 bytes RAM, UART and INT2 and INT3. In addition, the SH79F1616 provides external 256 bytes RAM, Four 16-bit timer/counters T2-T5. It also contains 16K bytes Flash memory block both for program and data.

Also the ADC, LCD Driver and PWM timer functions are incorporated in SH79F1616.

For high reliability and low cost issues, the SH79F1616 builds in Watchdog Timer, Low Voltage Reset function. And SH79F1616 also supports two power saving modes to reduce power consumption.



# 3. Block Diagram







# 4. Pin Configuration

LQFP32



### **Pin Configuration Diagram**

### Note:

The out most pin function has the highest priority, and the inner most pin function has the lowest priority (Refer to Pin Configuration Diagram. This means when one pin is occupied by a higher priority function (if enabled) cannot be used as the lower priority functional pin, even when the lower priority function is also enabled. Until the higher priority function is closed by software, can the corresponding pin be released for the lower priority function use.



# 5. Pin Description

| Pin No.                | Туре | Description                                                                                                                                                                                                |
|------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O PORT               |      |                                                                                                                                                                                                            |
| P0.2, P0.3, P0.6, P0.7 | I/O  | 4 bit General purpose CMOS I/O                                                                                                                                                                             |
| P1.0 - P1.4            | I/O  | 5 bit General purpose CMOS I/O                                                                                                                                                                             |
| P2.0, P2.1, P2.5, P2.6 | I/O  | 4 bit General purpose CMOS I/O                                                                                                                                                                             |
| P3.0 - P3.7            | I/O  | 8 bit General purpose CMOS I/O                                                                                                                                                                             |
| P4.0 - P4.4            | I/O  | 5 bit General purpose CMOS I/O                                                                                                                                                                             |
| P5.0 - P5.3            | I/O  | 4 bit General purpose CMOS I/O                                                                                                                                                                             |
| Timer                  |      |                                                                                                                                                                                                            |
| Т3                     | I    | Timer3 external input                                                                                                                                                                                      |
| T4                     | I/O  | Timer4 external input/output                                                                                                                                                                               |
| PWM                    |      |                                                                                                                                                                                                            |
| PWM0                   | 0    | Output pin for 12-bit PWM timer                                                                                                                                                                            |
| PWM01                  | 0    | Output pin for 12-bit PWM timer with fixed phase relationship of PWM0                                                                                                                                      |
| FLT                    | I    | PWM Fault Detect input                                                                                                                                                                                     |
| EUART                  | 1    |                                                                                                                                                                                                            |
| RXD                    | I    | EUART0 data input                                                                                                                                                                                          |
| TXD                    | 0    | EUARTO data output                                                                                                                                                                                         |
| ADC                    | Ū    |                                                                                                                                                                                                            |
| AN0 - AN7              | I    | ADC input channel                                                                                                                                                                                          |
| AVREF                  |      | External ADC reference voltage input                                                                                                                                                                       |
| LCD                    | •    |                                                                                                                                                                                                            |
| COM1 - COM8            | 0    | Common signal output for LCD display                                                                                                                                                                       |
| SEG1 - SEG19           | 0    | Segment signal output for LCD display                                                                                                                                                                      |
| LED                    | U    | Segment signal output for LOD display                                                                                                                                                                      |
| LED_C1 - LED_C8        | 0    | Common signal output for LED display                                                                                                                                                                       |
| LED_S1 - LED_S5        | 0    | Segment signal output for LED display                                                                                                                                                                      |
| Interrupt & Reset & Cl |      |                                                                                                                                                                                                            |
| INT2 - INT3            |      |                                                                                                                                                                                                            |
| INT2 - INT3            |      | External interrupt 2-3 input source<br>External interrupt 40-43 input source                                                                                                                               |
| RST                    | I    | The device will be reset by A low voltage on this pin longer than 10us, an internal resistor about $30k\Omega$ to V <sub>DD</sub> , So using only an external capacitor to GND can cause a power-on reset. |
| XTAL1                  | I    | Oscillator input                                                                                                                                                                                           |
| XTAL2                  | 0    | Oscillator output                                                                                                                                                                                          |
| V <sub>SS</sub>        | Р    | Ground                                                                                                                                                                                                     |
| V <sub>DD</sub>        | Р    | Power supply (2.0 - 5.5V)                                                                                                                                                                                  |
| Buzzer                 | •    |                                                                                                                                                                                                            |
| BUZ                    | 0    | Buzzer output pin                                                                                                                                                                                          |
| Programmer             |      |                                                                                                                                                                                                            |
| TDO (P1.0)             | 0    | Debug interface: Test data out                                                                                                                                                                             |
| TMS (P1.1)             |      | Debug interface: Test mode select                                                                                                                                                                          |
| TDI (P1.2)             | I    | Debug interface: Test data in                                                                                                                                                                              |
| TCK (P1.3)             | 1    | Debug interface: Test clock in                                                                                                                                                                             |
|                        | •    | bug interface, functions of P1.0-1.3 are blocked.                                                                                                                                                          |



# 6. SFR Mapping

The SH79F1616 provides 256 bytes of internal RAM to contain general-purpose data memory and Special Function Register (SFR). The SFR of the SH79F1616 fall into the following categories:

| CPU Core Registers:                | ACC, B, PSW, SP, DPL, DPH                                                                            |
|------------------------------------|------------------------------------------------------------------------------------------------------|
| Enhanced CPU Core Registers:       | AUXC, DPL1, DPH1, INSCON, XPAGE                                                                      |
| Power and Clock Control Registers: | PCON, SUSLO                                                                                          |
| Flash Registers:                   | IB_OFFSET, IB_DATA, IB_CON1, IB_CON2, IB_CON3, IB_CON4, IB_CON5, FLASHCON                            |
| Data Memory Register:              | XPAGE                                                                                                |
| Hardware Watchdog Timer Registers: | RSTSTAT                                                                                              |
| System Clock Control Register:     | CLKCON                                                                                               |
| Interrupt System Registers:        | IEN0, IEN1, IENC, IPH0, IPL0, IPH1, IPL1, EXF0, EXF1                                                 |
| I/O Port Registers:                | P0, P1, P2, P3, P4, P5, P0CR, P1CR, P2CR, P3CR, P4CR, P5CR, P0PCR, P1PCR, P2PCR, P3PCR, P4PCR, P5PCR |
| Timer Registers:                   | T2CON, T2MOD, TH2, TL2, RCAP2L, RCAP2H, T3CON, TH3, TL3, T4CON, TH4, TL4, SWTHL, T5CON, TH5, TL5     |
| EUART Registers:                   | SCON, SBUF, SADEN, SADDR, PCON, RXCON                                                                |
| ADC Registers:                     | ADCON, ADT, ADCH, ADDL, ADDH                                                                         |
| LCD Registers :                    | DISPCON, DISPCON1, DISPCLK0, DISPCLK1, P0SS, P1SS, P2SS, P3SS                                        |
| LED Registers :                    | DISPCON, DISPCLK0, DISPCLK1, P1SS, P3SS                                                              |
| Buzzer Registers:                  | BUZCON                                                                                               |
| PWM Registers:                     | PWMEN, PWMEN1, PWMLO, PWM0C, PWM0PL, PWM0PH, PWM0DL, PWM0DH                                          |
| LPD Registers:                     | LPDCON                                                                                               |



SH79F1616

# Table 6.1 CPU Core SFRs

| Mnem   | Add | Name                     | POR/WDT/LVR<br>/PIN Reset Value | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|--------|-----|--------------------------|---------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| ACC    | E0H | Accumulator              | 00000000                        | ACC.7  | ACC.6  | ACC.5  | ACC.4  | ACC.3  | ACC.2  | ACC.1  | ACC.0  |
| В      | F0H | B Register               | 00000000                        | B.7    | B.6    | B.5    | B.4    | B.3    | B.2    | B.1    | B.0    |
| AUXC   | F1H | C Register               | 00000000                        | C.7    | C.6    | C.5    | C.4    | C.3    | C.2    | C.1    | C.0    |
| PSW    | D0H | Program Status Word      | 00000000                        | CY     | AC     | F0     | RS1    | RS0    | OV     | F1     | Р      |
| SP     | 81H | Stack Pointer            | 00000111                        | SP.7   | SP.6   | SP.5   | SP.4   | SP.3   | SP.2   | SP.1   | SP.0   |
| DPL    | 82H | Data Pointer Low byte    | 00000000                        | DPL0.7 | DPL0.6 | DPL0.5 | DPL0.4 | DPL0.3 | DPL0.2 | DPL0.1 | DPL0.0 |
| DPH    | 83H | Data Pointer High byte   | 00000000                        | DPH0.7 | DPH0.6 | DPH0.5 | DPH0.4 | DPH0.3 | DPH0.2 | DPH0.1 | DPH0.0 |
| DPL1   | 84H | Data Pointer 1 Low byte  | 00000000                        | DPL1.7 | DPL1.6 | DPL1.5 | DPL1.4 | DPL1.3 | DPL1.2 | DPL1.1 | DPL1.0 |
| DPH1   | 85H | Data Pointer 1 High byte | 00000000                        | DPH1.7 | DPH1.6 | DPH1.5 | DPH1.4 | DPH1.3 | DPH1.2 | DPH1.1 | DPH1.0 |
| INSCON | 86H | Data pointer select      | -000-0                          | -      | BKS0   | -      | -      | DIV    | MUL    | -      | DPS    |

# Table 6.2 Power and Clock control SFRs

| Mnem  | Add | Name                 | POR/WDT/LVR<br>/PIN Reset Value | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|-------|-----|----------------------|---------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| PCON  | 87H | Power Control        | 000000                          | SMOD    | SSTAT   | -       | -       | GF1     | GF0     | PD      | IDL     |
| SUSLO | 8EH | Suspend Mode Control | 00000000                        | SUSLO.7 | SUSLO.6 | SUSLO.5 | SUSLO.4 | SUSLO.3 | SUSLO.2 | SUSLO.1 | SUSLO.0 |



# SH79F1616

# Table 6.3 Flash control SFRs

| Mnem          | Add          | Name                                               | POR/WDT/LVR<br>/PIN Reset Value | Bit7            | Bit6            | Bit5            | Bit4            | Bit3            | Bit2            | Bit1            | Bit0            |
|---------------|--------------|----------------------------------------------------|---------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| IB_OFF<br>SET | FBH<br>Bank0 | Low byte offset of flash memory<br>for programming | 00000000                        | IB_OFF<br>SET.7 | IB_OFF<br>SET.6 | IB_OFF<br>SET.5 | IB_OFF<br>SET.4 | IB_OFF<br>SET.3 | IB_OFF<br>SET.2 | IB_OFF<br>SET.1 | IB_OFF<br>SET.0 |
| IB_DATA       | FCH<br>Bank0 | Data Register for programming<br>flash memory      | 00000000                        | IB_DATA.7       | IB_DATA.6       | IB_DATA.5       | IB_DATA.4       | IB_DATA.3       | IB_DATA.2       | IB_DATA.1       | IB_DATA.0       |
| IB_CON1       | F2H<br>Bank0 | Flash Memory Control Register 1                    | 00000000                        | IB_CON1.7       | IB_CON1.6       | IB_CON1.5       | IB_CON1.4       | IB_CON1.3       | IB_CON1.2       | IB_CON1.1       | IB_CON1.0       |
| IB_CON2       | F3H<br>Bank0 | Flash Memory Control Register 2                    | 0000                            | -               | -               | -               | -               | IB_CON2.3       | IB_CON2.2       | IB_CON2.1       | IB_CON2.0       |
| IB_CON3       | F4H<br>Bank0 | Flash Memory Control Register 3                    | 0000                            | -               | -               | -               | -               | IB_CON3.3       | IB_CON3.2       | IB_CON3.1       | IB_CON3.0       |
| IB_CON4       | F5H<br>Bank0 | Flash Memory Control Register 4                    | 0000                            | -               | -               | -               | -               | IB_CON4.3       | IB_CON4.2       | IB_CON4.1       | IB_CON4.0       |
| IB_CON5       | F6H<br>Bank0 | Flash Memory Control Register 5                    | 0000                            | -               | -               | -               | -               | IB_CON5.3       | IB_CON5.2       | IB_CON5.1       | IB_CON5.0       |
| XPAGE         | F7H<br>Bank0 | Memory Page                                        | 000000                          | -               | -               | XPAGE.5         | XPAGE.4         | XPAGE.3         | XPAGE.2         | XPAGE.1         | XPAGE.0         |
| FLASHCON      | A7H<br>Bank0 | Flash access control                               | 0                               | -               | -               | -               | -               | -               | -               | -               | FAC             |

# Table 6.4 WDT SFR

| Mnem    | Add          | Name                   | POR/WDT/LVR<br>/PIN Reset Value | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2  | Bit1  | Bit0  |
|---------|--------------|------------------------|---------------------------------|------|------|------|------|------|-------|-------|-------|
| RSTSTAT | B1H<br>Bank0 | Watchdog Timer Control | 0-000000*                       | WDOF | -    | PORF | LVRF | CLRF | WDT.2 | WDT.1 | WDT.0 |

\*Note: RSTSTAT initial value is determined by different RESET.

Table 6.5 CLKCON SFR

| Mnem   | Add          | Name                          | POR/WDT/LVR<br>/PIN Reset Value | Bit7 | Bit6  | Bit5  | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|--------|--------------|-------------------------------|---------------------------------|------|-------|-------|-------|------|------|------|------|
| CLKCON | B2H<br>Bank0 | System Clock Control Register | -110                            | -    | CLKS1 | CLKS0 | SCMIF | -    | -    | -    | -    |





# Table 6.6 Interrupt SFRs

| Mnem  | Add          | Name                               | POR/WDT/LVR<br>/PIN Reset Value | Bit7      | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|-------|--------------|------------------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|-------|
| IEN0  | A8H<br>Bank0 | Interrupt Enable Control 0         | 0000-000                        | EA        | EADC  | ET2   | ES    | -     | EX1   | ET5   | EX0   |
| IEN1  | A9H<br>Bank0 | Interrupt Enable Control 1         | 000000-                         | ESCM/ELPD | ET4   | EPWM  | ET3   | EX4   | EX3   | EX2   | -     |
| IENC  | BAH<br>Bank0 | Interrupt 4channel enable control  | 0000                            | -         | -     | -     | -     | EXS43 | EXS42 | EXS41 | EXS40 |
| IENC1 | BBH<br>Bank0 | Interrupt channel enable control 1 | 00                              | -         | -     | -     | -     | -     | -     | ESCM  | ELPD  |
| IPH0  | B4H<br>Bank0 | Interrupt Priority Control High 0  | -0000-                          | -         | PADCH | PT2H  | PSH   | -     | -     | PT5H  | -     |
| IPL0  | B8H<br>Bank0 | Interrupt Priority Control Low 0   | -0000-                          | -         | PADCL | PT2L  | PSL   | -     | -     | PT5L  | -     |
| IPH1  | B5H<br>Bank0 | Interrupt Priority Control High 1  | 000000-                         | PSCMH     | PT4H  | PPWMH | PT3H  | PX4H  | РХ3Н  | PX2H  | -     |
| IPL1  | B9H<br>Bank0 | Interrupt Priority Control Low 1   | 000000-                         | PSCML     | PT4L  | PPWML | PT3L  | PX4L  | PX3L  | PX2L  | -     |
| EXF0  | E8H<br>Bank0 | External interrupt Control 0       | 00000000                        | IT4.1     | IT4.0 | IT3.1 | IT3.0 | IT2.1 | IT2.0 | IE3   | IE2   |
| EXF1  | D8H<br>Bank0 | External interrupt Control 1       | 0000                            | -         | -     | -     | -     | IF43  | IF42  | IF41  | IF40  |





# Table 6.7 Port SFRs

| Mnem  | Add          | Name                                 | POR/WDT/LVR<br>/PIN Reset Value | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|-------|--------------|--------------------------------------|---------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| P0    | 80H<br>Bank0 | 4-bit Port 0                         | 0000                            | P0.7    | P0.6    | -       | -       | P0.3    | P0.2    | -       | -       |
| P1    | 90H<br>Bank0 | 5-bit Port 1                         | 00000                           | -       | -       | -       | P1.4    | P1.3    | P1.2    | P1.1    | P1.0    |
| P2    | A0H<br>Bank0 | 4-bit Port 2                         | -0000                           | -       | P2.6    | P2.5    | -       | -       | -       | P2.1    | P2.0    |
| P3    | B0H<br>Bank0 | 8-bit Port 3                         | 00000000                        | P3.7    | P3.6    | P3.5    | P3.4    | P3.3    | P3.2    | P3.1    | P3.0    |
| P4    | C0H<br>Bank0 | 5-bit Port 4                         | 00000                           | -       | -       | -       | P4.4    | P4.3    | P4.2    | P4.1    | P4.0    |
| P5    | 80H<br>Bank1 | 4-bit Port 5                         | 0000                            | -       | -       | -       | -       | P5.3    | P5.2    | P5.1    | P5.0    |
| P0CR  | E1H<br>Bank0 | Port0 input/output direction control | 0000                            | P0CR.7  | P0CR.6  | -       | -       | P0CR.3  | P0CR.2  | -       | -       |
| P1CR  | E2H<br>Bank0 | Port1 input/output direction control | 00000                           | -       | -       | -       | P1CR.4  | P1CR.3  | P1CR.2  | P1CR.1  | P1CR.0  |
| P2CR  | E3H<br>Bank0 | Port2 input/output direction control | -0000                           | -       | P2CR.6  | P2CR.5  | -       | -       | -       | P2CR.1  | P2CR.0  |
| P3CR  | E4H<br>Bank0 | Port3 input/output direction control | 00000000                        | P3CR.7  | P3CR.6  | P3CR.5  | P3CR.4  | P3CR.3  | P3CR.2  | P3CR.1  | P3CR.0  |
| P4CR  | E5H<br>Bank0 | Port4 input/output direction control | 00000                           | -       | -       | -       | P4CR.4  | P4CR.3  | P4CR.2  | P4CR.1  | P4CR.0  |
| P5CR  | E1H<br>Bank1 | Port5 input/output direction control | 0000                            | -       | -       | -       | -       | P5CR.3  | P5CR.2  | P5CR.1  | P5CR.0  |
| P0PCR | E9H<br>Bank0 | Internal pull-high enable for Port0  | 0000                            | P0PCR.7 | P0PCR.6 | -       | -       | P0PCR.3 | P0PCR.2 | -       | -       |
| P1PCR | EAH<br>Bank0 | Internal pull-high enable for Port1  | 00000                           | -       | -       | -       | P1PCR.4 | P1PCR.3 | P1PCR.2 | P1PCR.1 | P1PCR.0 |
| P2PCR | EBH<br>Bank0 | Internal pull-high enable for Port2  | -0000                           | -       | P2PCR.6 | P2PCR.5 | -       | -       | -       | P2PCR.1 | P2PCR.0 |
| P3PCR | ECH<br>Bank0 | Internal pull-high enable for Port3  | 0000000                         | P3PCR.7 | P3PCR.6 | P3PCR.5 | P3PCR.4 | P3PCR.3 | P3PCR.2 | P3PCR.1 | P3PCR.0 |
| P4PCR | EDH<br>Bank0 | Internal pull-high enable for Port4  | 00000                           | -       | -       | -       | P4PCR.4 | P4PCR.3 | P4PCR.2 | P4PCR.1 | P4PCR.0 |
| P5PCR | E9H<br>Bank1 | Internal pull-high enable for Port5  | 0000                            | -       | -       | -       | -       | P5PCR.3 | P5PCR.2 | P5PCR.1 | P5PCR.0 |





# Table 6.8 Timer SFRs

| Mnem   | Add          | Name                                         | POR/WDT/LVR<br>/PIN Reset Value | Bit7     | Bit6     | Bit5     | Bit4     | Bit3     | Bit2     | Bit1     | Bit0     |
|--------|--------------|----------------------------------------------|---------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|
| T2CON  | C8H<br>Bank0 | Timer/Counter 2 Control                      | 00000000                        | TF2      | EXF2     | RCLK     | TCLK     | EXEN2    | TR2      | C/T 2    | CP/RL2   |
| T2MOD  | C9H<br>Bank0 | Timer/Counter 2 Mode                         | 00                              | -        | -        | -        | -        | -        | -        | T2OE     | DCEN     |
| RCAP2L | CAH<br>Bank0 | Timer/Counter 2 Reload<br>/Caprure Low Byte  | 00000000                        | RCAP2L.7 | RCAP2L.6 | RCAP2L.5 | RCAP2L.4 | RCAP2L.3 | RCAP2L.2 | RCAP2L.1 | RCAP2L.0 |
| RCAP2H | CBH<br>Bank0 | Timer/Counter 2 Reload<br>/Caprure High Byte | 00000000                        | RCAP2H.7 | RCAP2H.6 | RCAP2H.5 | RCAP2H.4 | RCAP2H.3 | RCAP2H.2 | RCAP2H.1 | RCAP2H.0 |
| TL2    | CCH<br>Bank0 | Timer/Counter 2 Low Byte                     | 00000000                        | TL2.7    | TL2.6    | TL2.5    | TL2.4    | TL2.3    | TL2.2    | TL2.1    | TL2.0    |
| TH2    | CDH<br>Bank0 | Timer/Counter 2 High Byte                    | 00000000                        | TH2.7    | TH2.6    | TH2.5    | TH2.4    | TH2.3    | TH2.2    | TH2.1    | TH2.0    |
| T3CON  | 88H<br>Bank1 | Timer/Counter 3 Control                      | 0-00-000                        | TF3      | -        | T3PS.1   | T3PS.0   | -        | TR3      | T3CLKS.1 | T3CLKS.0 |
| SWTHL  | 89H<br>Bank1 | Timer/Counter data switch                    | 00                              | -        | -        | -        | -        | -        | -        | T5HLCON  | T3HLCON  |
| TL3    | 8CH<br>Bank1 | Timer/Counter 3 Low Byte                     | 00000000                        | TL3.7    | TL3.6    | TL3.5    | TL3.4    | TL3.3    | TL3.2    | TL3.1    | TL3.0    |
| TH3    | 8DH<br>Bank1 | Timer/Counter 3 High Byte                    | 00000000                        | TH3.7    | TH3.6    | TH3.5    | TH3.4    | TH3.3    | TH3.2    | TH3.1    | TH3.0    |
| T4CON  | C8H<br>Bank1 | Timer/Counter 4 Control                      | 00000000                        | TF4      | TC4      | T4PS1    | T4PS0    | T4M1     | T4M0     | TR4      | T4CLKS   |
| TL4    | CCH<br>Bank1 | Timer/Counter 4 Low Byte                     | 00000000                        | TL4.7    | TL4.6    | TL4.5    | TL4.4    | TL4.3    | TL4.2    | TL4.1    | TL4.0    |
| TH4    | CDH<br>Bank1 | Timer/Counter 4 High Byte                    | 00000000                        | TH4.7    | TH4.6    | TH4.5    | TH4.4    | TH4.3    | TH4.2    | TH4.1    | TH4.0    |
| T5CON  | C0H<br>Bank1 | Timer/Counter 5 Control                      | 0-000-                          | TF5      | -        | T5PS1    | T5PS0    | -        | -        | TR5      | -        |
| TL5    | CEH<br>Bank1 | Timer/Counter 5 Low Byte                     | 00000000                        | TL5.7    | TL5.6    | TL5.5    | TL5.4    | TL5.3    | TL5.2    | TL5.1    | TL5.0    |
| TH5    | CFH<br>Bank1 | Timer/Counter 5 High Byte                    | 00000000                        | TH5.7    | TH5.6    | TH5.5    | TH5.4    | TH5.3    | TH5.2    | TH5.1    | TH5.0    |





# Table 6.9 EUART SFRs

| Mnem  | Add          | Name                            | POR/WDT/LVR<br>/PIN Reset Value | Bit7    | Bit6     | Bit5      | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|-------|--------------|---------------------------------|---------------------------------|---------|----------|-----------|---------|---------|---------|---------|---------|
| SCON  | 98H<br>Bank0 | Serial Control                  | 00000000                        | SM0/FE  | SM1/RXOV | SM2/TXCOL | REN     | TB8     | RB8     | TI      | RI      |
| SBUF  | 99H<br>Bank0 | Serial Data Buffer              | 00000000                        | SBUF.7  | SBUF.6   | SBUF.5    | SBUF.4  | SBUF.3  | SBUF.2  | SBUF.1  | SBUF.0  |
| SADEN | 9BH<br>Bank0 | Slave Address Mask              | 00000000                        | SADEN.7 | SADEN.6  | SADEN.5   | SADEN.4 | SADEN.3 | SADEN.2 | SADEN.1 | SADEN.0 |
| SADDR | 9AH<br>Bank0 | Slave Address                   | 00000000                        | SADDR.7 | SADDR.6  | SADDR.5   | SADDR.4 | SADDR.3 | SADDR.2 | SADDR.1 | SADDR.0 |
| PCON  | 87H<br>Bank0 | Power & serial Control          | 000000                          | SMOD    | SSTAT    | -         | -       | GF1     | GF0     | PD      | IDL     |
| RxCON | 9FH<br>Bank0 | Rxd pin Schmidt voltage Control | 00                              | -       | -        | -         | -       | -       | -       | RxCON1  | RxCON0  |

### Table 6.10 ADC SFRs

| Mnem  | Add          | Name                      | POR/WDT/LVR<br>/PIN Reset Value | Bit7  | Bit6  | Bit5  | Bit4 | Bit3 | Bit2 | Bit1 | Bit0    |
|-------|--------------|---------------------------|---------------------------------|-------|-------|-------|------|------|------|------|---------|
| ADCON | 93H<br>Bank0 | ADC Control               | 00000000                        | ADON  | ADCIF | EC    | REFC | SCH2 | SCH1 | SCH0 | GO/DONE |
| ADT   | 94H<br>Bank0 | ADC Time Configuration    | 000-0000                        | TADC2 | TADC1 | TADC0 | -    | TS3  | TS2  | TS1  | TS0     |
| ADCH  | 95H<br>Bank0 | ADC Channel Configuration | 00000000                        | CH7   | CH6   | CH5   | CH4  | CH3  | CH2  | CH1  | CH0     |
| ADDL  | 96H<br>Bank0 | ADC Data Low Byte         | 00                              | -     | -     | -     | -    | -    | -    | A1   | A0      |
| ADDH  | 97H<br>Bank0 | ADC Data High Byte        | 00000000                        | A9    | A8    | A7    | A6   | A5   | A4   | A3   | A2      |

# Table 6.11 Buzzer SFR

| Mnem   | Add          |                       | POR/WDT/LVR<br>/PIN Reset Value |   | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|--------|--------------|-----------------------|---------------------------------|---|------|------|------|------|------|------|------|
| BUZCON | BDH<br>Bank0 | Buzzer output control | 0000                            | - | -    | -    | -    | BCA2 | BCA1 | BCA0 | BZEN |





# Table 6.12 LCD SFRs

| Mnem     | Add          | Name                | POR/WDT/LVR<br>/PIN Reset Value | Bit7    | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|----------|--------------|---------------------|---------------------------------|---------|--------|--------|--------|--------|--------|--------|--------|
| DISPCON  | ABH<br>Bank0 | LCD control         | 00000000                        | DISPSEL | LCDON  | ELCC   | DUTY   | VOL3   | VOL2   | VOL1   | VOL0   |
| DISPCON1 | ADH<br>Bank0 | LCD control 1       | 00000                           | -       | -      | -      | RLCD   | FCCTL1 | FCCTL0 | MOD1   | MOD0   |
| DISPCLK0 | ACH<br>Bank0 | LCD clock control 0 | 0000000                         | DCK0.7  | DCK0.6 | DCK0.5 | DCK0.4 | DCK0.3 | DCK0.2 | DCK0.1 | DCK0.0 |
| DISPCLK1 | AAH<br>Bank0 | LCD clock control 1 | 0                               | -       | -      | -      | -      | -      | -      | -      | DCK1.0 |
| P0SS     | B6H<br>Bank0 | P0 mode Select      | 0                               | -       | -      | -      | -      | -      | P0S2   | -      | -      |
| P1SS     | 9CH<br>Bank0 | P1 mode Select      | 00000                           | -       | -      | -      | P1S4   | P1S3   | P1S2   | P1S1   | P1S0   |
| P2SS     | 9DH<br>Bank0 | P2 mode Select      | -0000                           | -       | P2S6   | P2S5   | -      | -      | -      | P2S1   | P2S0   |
| P3SS     | 9EH<br>Bank0 | P3 mode Select      | 0000000                         | P3S7    | P3S6   | P3S5   | P3S4   | P3S3   | P3S2   | P3S1   | P3S0   |

# Table 6.13 LED SFRs

| Mnem     | Add          | Name           | POR/WDT/LVR<br>/PIN Reset Value | Bit7    | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|----------|--------------|----------------|---------------------------------|---------|--------|--------|--------|--------|--------|--------|--------|
| DISPCON  | ABH<br>Bank0 | LED Control    | 00-0                            | DISPSEL | LEDON  | -      | DUTY   | -      | -      | -      | -      |
| DISPCLK0 | ACH<br>Bank0 | LED clock 0    | 00000000                        | DCK0.7  | DCK0.6 | DCK0.5 | DCK0.4 | DCK0.3 | DCK0.2 | DCK0.1 | DCK0.0 |
| DISPCLK1 | AAH<br>Bank0 | LED clock 1    | 0                               | -       | -      | -      | -      | -      | -      | -      | DCK1.0 |
| P1SS     | 9CH<br>Bank0 | P1 mode Select | 00000                           | -       | -      | -      | P1S4   | P1S3   | P1S2   | P1S1   | P1S0   |
| P3SS     | 9EH<br>Bank0 | P3 mode Select | 00000000                        | P3S7    | P3S6   | P3S5   | P3S4   | P3S3   | P3S2   | P3S1   | P3S0   |





# Table 6.14 PWM SFRs

| Mnem   | Add          | Name                                | POR/WDT/LVR<br>/PIN Reset Value | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|--------|--------------|-------------------------------------|---------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| PWMEN  | CFH<br>Bank0 | PWM timer enable                    | -000                            | -       | EFLT    | -       | -       | EPWM01  | -       | -       | EPWM0   |
| PWMEN1 | B7H<br>Bank0 | PWM output enable                   | 0                               | -       | -       | -       | -       | -       | -       | -       | PWM0    |
| PWMLO  | E7H<br>Bank0 | PWM register Lock                   | 00000000                        | PWMLO.7 | PWMLO.6 | PWMLO.5 | PWMLO.4 | PWMLO.3 | PWMLO.2 | PWMLO.1 | PWMLO.0 |
| PWM0C  | D2H<br>Bank0 | 12-bit PWM Control                  | 00-00000                        | PWM0IE  | PWM0IF  | -       | FLTS    | FLTC    | PWM0S   | TnCK01  | TnCK00  |
| PWM0PL | D3H<br>Bank0 | 12-bit PWM Period Control low byte  | 00000000                        | PP0.7   | PP0.6   | PP0.5   | PP.4    | PP0.3   | PP0.2   | PP0.1   | PP0.0   |
| PWM0PH | D4H<br>Bank0 | 12-bit PWM Period Control high byte | 0000                            | -       | -       | -       | -       | PP0.11  | PP0.10  | PP0.9   | PP0.8   |
| PWM0DL | D5H<br>Bank0 | 12-bit PWM Duty Control low byte    | 00000000                        | PD0.7   | PD0.6   | PD0.5   | PD0.4   | PD0.3   | PD0.2   | PD0.1   | PD0.0   |
| PWM0DH | D6H<br>Bank0 | 12-bit PWM Duty Control high byte   | 0000                            | -       | -       | -       | -       | PD0.11  | PD0.10  | PD0.9   | PD0.8   |
| PWM0DT | D1H<br>Bank0 | PWM01 Dead time control             | 00000000                        | DT0.7   | DT0.6   | DT0.5   | DT0.4   | DT0.3   | DT0.2   | DT0.1   | DT0.0   |

# Table 6.15 LPD SFR

| Mnem   | Add          | Name        | POR/WDT/LVR<br>/PIN Reset Value | Bit7  | Bit6 | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|--------|--------------|-------------|---------------------------------|-------|------|-------|-------|-------|-------|-------|-------|
| LPDCON | B3H<br>Bank0 | LPD control | 00000000                        | LPDEN | LPDF | LPDMD | LPDIF | LPDS3 | LPDS2 | LPDS1 | LPDS0 |

Note: - : Unimplemented



### SFR Map Bank0

|     | Bit<br>addressable |         |          | Non       | Bit address | able     |         |          |     |
|-----|--------------------|---------|----------|-----------|-------------|----------|---------|----------|-----|
|     | 0/8                | 1/9     | 2/A      | 3/B       | 4/C         | 5/D      | 6/E     | 7/F      |     |
| F8H |                    |         |          | IB_OFFSET | IB_DATA     |          |         |          | FFH |
| F0H | В                  | AUXC    | IB_CON1  | IB_CON2   | IB_CON3     | IB_CON4  | IB_CON5 | XPAGE    | F7H |
| E8H | EXF0               | P0PCR   | P1PCR    | P2PCR     | P3PCR       | P4PCR    |         |          | EFH |
| E0H | ACC                | P0CR    | P1CR     | P2CR      | P3CR        | P4CR     |         | PWMLO    | E7H |
| D8H | EXF1               |         |          |           |             |          |         |          | DFH |
| D0H | PSW                | PWM0DT  | PWM0C    | PWM0PL    | PWM0PH      | PWM0DL   | PWM0DH  |          | D7H |
| C8H | T2CON              |         | RCAP2L   | RCAP2H    | TL2         | TH2      |         | PWMEN    | CFH |
| C0H | P4                 |         |          |           |             |          |         |          | C7H |
| B8H | IPL0               | IPL1    | IENC     | IENC1     |             | BUZCON   |         |          | BFH |
| B0H | P3                 | RSTSTAT | CLKCON   | LPDCON    | IPH0        | IPH1     | POSS    | PWMEN1   | B7H |
| A8H | IEN0               | IEN1    | DISPCLK1 | DISPCON   | DISPCLK0    | DISPCON1 |         |          | AFH |
| A0H | P2                 |         |          |           |             |          |         | FLASHCON | A7H |
| 98H | SCON               | SBUF    | SADDR    | SADEN     | P1SS        | P2SS     | P3SS    |          | 9FH |
| 90H | P1                 |         |          | ADCON     | ADT         | ADCH     | ADDL    | ADDH     | 97H |
| 88H |                    |         |          |           |             |          | SUSLO   |          | 8FH |
| 80H | P0                 | SP      | DPL      | DPH       | DPL1        | DPH1     | INSCON  | PCON     | 87H |
|     | 0/8                | 1/9     | 2/A      | 3/B       | 4/C         | 5/D      | 6/E     | 7/F      |     |

### Bank1

|     | Bit<br>addressable |       |     | Νοι | n Bit address | able |        |       |     |
|-----|--------------------|-------|-----|-----|---------------|------|--------|-------|-----|
|     | 0/8                | 1/9   | 2/A | 3/B | 4/C           | 5/D  | 6/E    | 7/F   |     |
| F8H |                    |       |     |     |               |      |        |       | FFH |
| F0H | В                  | AUXC  |     |     |               |      |        | XPAGE | F7H |
| E8H |                    | P5PCR |     |     |               |      |        |       | EFH |
| E0H | ACC                | P5CR  |     |     |               |      |        |       | E7H |
| D8H |                    |       |     |     |               |      |        |       | DFH |
| D0H | PSW                |       |     |     |               |      |        |       | D7H |
| C8H | T4CON              |       |     |     | TL4           | TH4  | TL5    | TH5   | CFH |
| C0H | T5CON              |       |     |     |               |      |        |       | C7H |
| B8H | IPL0               | IPL1  |     |     |               |      |        |       | BFH |
| B0H |                    |       |     |     | IPH0          | IPH1 |        |       | B7H |
| A8H | IEN0               | IEN1  |     |     |               |      |        |       | AFH |
| A0H |                    |       |     |     |               |      |        |       | A7H |
| 98H |                    |       |     |     |               |      |        |       | 9FH |
| 90H |                    |       |     |     |               |      |        |       | 97H |
| 88H | T3CON              | SWTHL |     |     | TL3           | TH3  | SUSLO  |       | 8FH |
| 80H | P5                 | SP    | DPL | DPH | DPL1          | DPH1 | INSCON | PCON  | 87H |
|     | 0/8                | 1/9   | 2/A | 3/B | 4/C           | 5/D  | 6/E    | 7/F   |     |

Note: The unused addresses of SFR are not available.



### 7. Normal Function

### 7.1 CPU

# 7.1.1 CPU Core SFR

### Feature

■ CPU core registers: ACC, B, PSW, SP, DPL, DPH

### Accumulator

ACC is the Accumulator register. The mnemonics for accumulator-specific instructions, however, refer to the Accumulator simply as A.

# **B** Register

The B register is used during multiply and divide operations. For other instructions it can be treated as another scratch pad register.

### Stack Pointer (SP)

The Stack Pointer Register is 8 bits wide, It is incremented before data is stored during PUSH, CALL executions and it is decremented after data is out of stack during POP, RET, RETI executions. The stack may reside anywhere in on-chip internal RAM (00H-FFH). On reset, the Stack Pointer is initialized to 07H causing the stack to begin at location 08H.

### Program Status Word Register (PSW)

The PSW register contains program status information.

### Data Pointer Register (DPTR)

DPTR consists of a high byte (DPH) and a low byte (DPL). Its intended function is to hold a 16-bit address, but it may be manipulated as a 16-bit register or as two independent 8-bit registers.

Table 7.1 PSW Register

| D0H                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| PSW                              | CY   | AC   | F0   | RS1  | RS0  | OV   | F1   | Р    |
| R/W                              | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                             |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | CY           | Carry flag bit<br>0: no carry or borrow in an arithmetic or logic operation<br>1: a carry or borrow in an arithmetic or logic operation                                 |
| 6          | AC           | Auxiliary Carry flag bit<br>0: an auxiliary carry or borrow in an arithmetic or logic operation<br>1: an auxiliary carry or borrow in an arithmetic or logic operation  |
| 5          | F0           | F0 flag bit<br>Available to the user for general purposes                                                                                                               |
| 4-3        | RS[1:0]      | R0-R7 Register bank select bits<br>00: Bank0 (Address to 00H-07H)<br>01: Bank1 (Address to 08H-0FH)<br>10: Bank2 (Address to 10H-17H)<br>11: Bank3 (Address to 18H-1FH) |
| 2          | ov           | Overflow flag bit<br>0: no overflow happen<br>1: an overflow happen                                                                                                     |
| 1          | F1           | F1 flag bit<br>Available to the user for general purposes                                                                                                               |
| 0          | Р            | Parity flag bit<br>0: an even number of "one" bits in the Accumulator<br>1: an odd number of "one" bits in the Accumulator                                              |



### 7.1.2 Enhanced CPU Core SFRs

Extended 'MUL' and 'DIV' instructions: 16bit\*8bit, 16bit/8bit

- Dual Data Pointer
- Enhanced CPU core registers: AUXC, DPL1, DPH1, INSCON

The SH79F1616 has modified 'MUL' and 'DIV' instructions. These instructions support 16 bit operand. A new register - the register is applied to hold the upper part of the operand/result.

The AUXC register is used during 16 bit operand multiply and divide operations. For other instructions it can be treated as another scratch pad register.

After reset, the CPU is in standard mode, which means that the 'MUL' and 'DIV' instructions are operating like the standard 8051 instructions. To enable the 16 bit mode operation, the corresponding enable bit in the INSCON register must be set.

|     | Operation                 |              |                   | Result      |                    |
|-----|---------------------------|--------------|-------------------|-------------|--------------------|
|     | Operation                 |              | Α                 | В           | AUXC               |
| MUL | INSCON.2 = 0; 8 bit mode  | (A)*(B)      | Low Byte          | High Byte   |                    |
| MOL | INSCON.2 = 1; 16 bit mode | (AUXC A)*(B) | Low Byte          | Middle Byte | High Byte          |
| DIV | INSCON.3 = 0; 8 bit mode  | (A)/(B)      | Quotient Low Byte | Remainder   |                    |
| DIV | INSCON.3 = 1; 16 bit mode | (AUXC A)/(B) | Quotient Low Byte | Remainder   | Quotient High Byte |

### **Dual Data Pointer**

Using two data pointers can accelerate data memory moves. The standard data pointer is called DPTR and the new data pointer is called DPTR1.

DPTR1 is the same with DPTR, which consists of a high byte (DPH1) and a low byte (DPL1). Its intended function is to hold a 16-bit address, but it may be manipulated as a 16-bit register or as two independent 8-bit registers.

The DPS bit in INSTCON register is used to choose the active pointer. The user can switch data pointers by toggling the DPS bit. And all DPTR-related instructions will use the currently selected data pointer.

### 7.1.3 Register

 Table 7.2 Data Pointer Select Register

| 86H                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| INSCON                           | -    | BKS0 | -    | -    | DIV  | MUL  | -    | DPS  |
| R/W                              | -    | R/W  | -    | -    | R/W  | R/W  | -    | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | 0    | -    | -    | 0    | 0    | -    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                           |
|------------|--------------|---------------------------------------------------------------------------------------|
| 6          | BKS0         | SFR Bank Selection Bit<br>0: SFR Bank0 selected<br>1: SFR Bank1 selected              |
| 3          | DIV          | <b>16 bit/8 bit Divide Selection Bit</b><br>0: 8 bit Divide<br>1: 16 bit Divide       |
| 2          | MUL          | <b>16 bit/8 bit Multiply Selection Bit</b><br>0: 8 bit Multiply<br>1: 16 bit Multiply |
| 0          | DPS          | Data Pointer Selection Bit<br>0: Data pointer<br>1: Data pointer1                     |



# 7.2 RAM

### 7.2.1 Features

SH79F1616 provides both internal RAM and external RAM for random data storage. The internal data memory is mapped into four separated segments:

- The Lower 128 bytes of RAM (addresses 00H to 7FH) are directly and indirectly addressable.
- The Upper 128 bytes of RAM (addresses 80H to FFH) are indirectly addressable only.
- The Special Function Registers (SFR, addresses 80H to FFH) are directly addressable only.
- The 256 bytes of external RAM(addresses 00H to FFH) are indirectly accessed by MOVX instructions.

The Upper 128 bytes occupy the same address space as SFR, but they are physically separate from SFR space. When an instruction accesses an internal location above address 7FH, the CPU can distinguish whether to access the upper 128 bytes data RAM or to access SFR by different addressing mode of the instruction.

Note: the unused address is unavailable in SFR.



The Internal and External RAM Configuration

The SH79F1616 provides traditional method for accessing of external RAM. Use MOVX A, @Ri or MOVX @Ri, A; to access external low 256 bytes RAM; MOVX A, @DPTR or MOVX @DPTR, A also to access external 275 bytes RAM.

### Note:

In SH79F1616 the user can also use XPAGE register to access external RAM only with MOVX A, @Ri or MOVX@Ri, A instructions. The user can use XPAGE to represent the high byte address of RAM above 256 Bytes.



### 7.3 Flash Program Memory

### 7.3.1 Features

- The program memory consists 16 X 1KB sectors, total 16KB
- Programming and erase can be done over the full operation voltage range
- Write, read and erase operation are all supported by In-Circuit Programming (ICP)
- Support / sector erase and programming, each sector erase time <3ms, programming time per byte <30us
- Minimum program/erase cycles: Program area:1000
  - EEPROM-like area:100,000
- Minimum years data retention: 10
- Low power consumption



The SH79F1616 embeds 16K flash program memory for program code. The flash program memory provides electrical erasure and programming and supports In-Circuit Programming (ICP) mode and Self-Sector Programming (SSP) mode. Each sector of 1024 bytes.

The SH79F1616 also embeds 1024 bytes EEPROM-LIKE area.Each sector of 256 bytes.

Flash operation defined:

ICP mode: Flash programming of the Flash memory erase, read and write operations.

SSP mode: The user program code to run in the Program Memory, Flash memory erase, read and write operations.



### Flash memory supports the following operating:

#### (1) Code-Protect Control mode Programming

SH79F1616implements code-protect function to offer high safeguard for customer code. Two modes are available for each sector.

Code-protect control mode 0: Used to enable/disable the write/read operation (except mass erase) from any programmer.

**Code-protect control mode 1:** Used to enable/disable the read operation through MOVC instruction from other sectors; or the sector erase/write operation through **SSP** Function.

To enable the wanted protect mode, the user must use the Flash Programmer to set the corresponding protect bit.

#### (2) Mass Erase

The mass erase operation will erase all the contents of program code, code option, code protect bit and customer code ID, regardless the status of code-protect control mode. (The Flash Programmer supplies customer code ID setting function for customer to distinguish their product.)

Mass erase is only available in Flash Programmer.

#### (3) Sector Erase

The sector erase operation will erase the contents of program code of selected sector . This operation can be done by Flash Programmer or the user's program.

If done by the Flash Programmer, the code-protect control mode 0 of the selected sector must be disabled.

### (4) EEPROM-Like Erase

The EEPROM-Like erase operation will erase the contents of program code of EEPROM-Like. This operation can be done by Flash Programmer or the user's program.

#### (5) Write/Read Code

The Write/Read Code operation will write the customer code into the Flash Programming Memory or read the customer code from the Flash Programming Memory. This operation can be done by Flash Programmer or the user's program. If done by the user's program, the code-protect control mode 1 of the selected sector must be disabled. But the program can read/write its own sector regardless of its security bit.

If done by the Flash Programmer, the code-protect control mode 0 of the selected sector must be disabled.

### (6) Write/Read EEPROM-Like

The Write/Read EEPROM-Like operation will write the customer data into the EEPROM-Like or read the customer data from the EEPROM-Like. This operation can be done by Flash Programmer or the user's program.

| Operation              | ICP                           | SSP                                             |  |  |
|------------------------|-------------------------------|-------------------------------------------------|--|--|
| Code Protection        | Yes                           | No                                              |  |  |
| Sector Erase           | Yes<br>(without security bit) | Yes<br>(without security bit)                   |  |  |
| Mass Erase             | Yes                           | No                                              |  |  |
| EEPROM-like Erase      | Yes                           | Yes                                             |  |  |
| Write/Read             | Yes<br>(without security bit) | Yes<br>(without security bit or its own sector) |  |  |
| EEPROM-like Write/Read | Yes                           | Yes                                             |  |  |





### 7.3.2 Flash Operation in ICP Mode

ICP mode by Flash programmer to program the MCU, the MCU welding program after the user board. ICP mode, the user system must be shut down after a Flash programmer to Flash memory by ICP programming interface refresh. ICP programming interfaces, including a 6-pin (VDD, GND, TCK, TDI, TMS, TDO).

The programmer uses four JTAG pins (TDO, TDI, TCK, TMS) to enter the programming mode. Only specific waveform input 4-pin CPU to enter the programming mode. For detailed instructions, please refer to the Flash Programmer User's Guide.

ICP mode, 6-wire interface programmer complete all Flash operations. Programming signal is very sensitive, so the programmer programming the user needs to first with six jumper chip programming pin (VDD, GND, TCK, TDI, TMS, TDO) is separated from the application circuit as shown below .



The recommended steps are as following:

- (1) The jumpers must be open to separate the programming pins from the application circuit before programming.
- (2) Connect the programming interface with programmer and begin programming.
- (3) Disconnect programmer and short these jumpers after programming is complete.



# 7.4 SSP Function

The SH79F1616 provides SSP function, each sector can be sector erased or programmed by the user's code if the selected sector is not be protected. But once sector has been programmed, it cannot be reprogrammed before sector erase.

The SH79F1616 builds in a complex control flow to prevent the code from carelessly modification. If the dedicated conditions are not met (IB\_CON2-5), the SSP will be terminated.

# 7.4.1 SSP Register

Table 7.3 Memory Page Register for Programming (For Flash memory, one sector is 1024 bytes)

| F7H                              | Bit7 | Bit6 | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|----------------------------------|------|------|---------|---------|---------|---------|---------|---------|
| XPAGE                            | -    | -    | XPAGE.5 | XPAGE.4 | XPAGE.3 | XPAGE.2 | XPAGE.1 | XPAGE.0 |
| R/W                              | -    | -    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | 0       | 0       | 0       | 0       | 0       | 0       |
|                                  |      |      |         |         |         |         |         |         |

| Bit Number | Bit Mnemonic | Description                                                                |
|------------|--------------|----------------------------------------------------------------------------|
| 5-2        | XPAGE[5:2]   | Sector of the flash memory to be programmed, 0000means sector 0, and so on |
| 1-0        | XPAGE[1:0]   | High Address of Offset of the flash memory sector to be programmed         |

 Table 7.4 Memory Page Register for Programming (For EEPROM-like memory, one sector is 256 bytes)

| F7H                              | Bit7 | Bit6 | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|----------------------------------|------|------|---------|---------|---------|---------|---------|---------|
| XPAGE                            | -    | -    | XPAGE.5 | XPAGE.4 | XPAGE.3 | XPAGE.2 | XPAGE.1 | XPAGE.0 |
| R/W                              | -    | -    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | 0       | 0       | 0       | 0       | 0       | 0       |

| Bit Number | Bit Mnemonic | Description                                                              |
|------------|--------------|--------------------------------------------------------------------------|
| 5-2        | XPAGE[5:2]   | Reserved                                                                 |
| 1-0        | XPAGE[1:0]   | Sector of the flash memory to be programmed, 00means sector 0, and so on |

Table 7.5 Offset of Flash Memory for Programming

| FBH, Bank0                       | Bit7            | Bit6            | Bit5            | Bit4            | Bit3            | Bit2            | Bit1            | Bit0            |
|----------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| IB_OFFSET                        | IB_OFF<br>SET.7 | IB_OFF<br>SET.6 | IB_OFF<br>SET.5 | IB_OFF<br>SET.4 | IB_OFF<br>SET.3 | IB_OFF<br>SET.2 | IB_OFF<br>SET.1 | IB_OFF<br>SET.0 |
| R/W                              | R/W             | R/W             | R/W             | R/W             | R/W             | R/W             | R/W             | R/W             |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               |

 Bit Number
 Bit Mnemonic
 Description

 7-0
 IB\_OFFSET[7:0]
 Low Address of Offset of the flash memory sector to be programmed

Table 7.6 Data Register for Programming

| 0                               | 8         | 9         |           |           |             |           |           |           |
|---------------------------------|-----------|-----------|-----------|-----------|-------------|-----------|-----------|-----------|
| FCH, Bank0                      | Bit7      | Bit6      | Bit5      | Bit4      | Bit3        | Bit2      | Bit1      | Bit0      |
| IB_DATA                         | IB_DATA.7 | IB_DATA.6 | IB_DATA.5 | IB_DATA.4 | IB_DATA.3   | IB_DATA.2 | IB_DATA.1 | IB_DATA.0 |
| R/W                             | R/W       | R/W       | R/W       | R/W       | R/W         | R/W       | R/W       | R/W       |
| Reset Value<br>(POR/WDT/LVR/PIN | 0         | 0         | 0         | 0         | 0           | 0         | 0         | 0         |
| Bit Number Bit                  | Mnemonic  |           |           |           | Description |           |           |           |

| Bit Number | Bit Mnemonic | Description           |
|------------|--------------|-----------------------|
| 7-0        | IB_DATA[7:0] | Data to be programmed |



# Table 7.7 SSP Type select Register

| F2H, Bank0                  | )     | Bit7      | Bit6                               | Bit5         | Bit4                          | Bit3                 | Bit2      | Bit1      | Bit0      |
|-----------------------------|-------|-----------|------------------------------------|--------------|-------------------------------|----------------------|-----------|-----------|-----------|
| IB_CON1                     |       | IB_CON1.7 | IB_CON1.6                          | IB_CON1.5    | IB_CON1.4                     | IB_CON1.3            | IB_CON1.2 | IB_CON1.1 | IB_CON1.0 |
| R/W                         |       | R/W       | R/W                                | R/W          | R/W                           | R/W                  | R/W       | R/W       | R/W       |
| Reset Value<br>(POR/WDT/LVR | -     | 0         | 0                                  | 0            | 0                             | 0                    | 0         | 0         | 0         |
| Bit Number                  | Bit N | Inemonic  |                                    |              |                               | Description          |           |           |           |
| 7-0                         | IB_C  | ON1[7:0]  | SSP Type s<br>0xE6: Se<br>0x6E: Se | ctor Erase(e | rase time < 3<br>nming(progra | 3ms)<br>am time < 30 | us)       |           |           |

Table 7.8 SSP Flow Control Register1

| F3H, Bank0                          |                                                                  | Bit7 | Bit6 | Bit5 | Bit4 | Bit3      | Bit2      | Bit1      | Bit0      |
|-------------------------------------|------------------------------------------------------------------|------|------|------|------|-----------|-----------|-----------|-----------|
| IB_CON2                             |                                                                  | -    | -    | -    | -    | IB_CON2.3 | IB_CON2.2 | IB_CON2.1 | IB_CON2.0 |
| R/W                                 |                                                                  | -    | -    | -    | -    | R/W       | R/W       | R/W       | R/W       |
| Reset Value<br>(POR/WDT/LVR/I       |                                                                  | -    | -    | -    | -    | 0         | 0         | 0         | 0         |
| Bit Number Bit Mnemonic Description |                                                                  |      |      |      |      |           |           |           |           |
| 2.0                                 | IP. CON2[2:0] Must be 05H, also Elect Drogramming will terminate |      |      |      |      |           | oto       |           |           |

**3-0 IB\_CON2[3:0]** Must be 05H, else Flash Programming will terminate

# Table 7.9 SSP Flow Control Register2

| F4H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3      | Bit2      | Bit1      | Bit0      |
|----------------------------------|------|------|------|------|-----------|-----------|-----------|-----------|
| IB_CON3                          | -    | -    | -    | -    | IB_CON3.3 | IB_CON3.2 | IB_CON3.1 | IB_CON3.0 |
| R/W                              | -    | -    | -    | -    | R/W       | R/W       | R/W       | R/W       |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | 0         | 0         | 0         | 0         |

| Bit Number | Bit Mnemonic | Description                                       |
|------------|--------------|---------------------------------------------------|
| 3-0        | IB_CON3[3:0] | Must be 0AH else Flash Programming will terminate |

# Table 7.10 SSP Flow Control Register3

| F5H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3      | Bit2      | Bit1      | Bit0      |
|----------------------------------|------|------|------|------|-----------|-----------|-----------|-----------|
| IB_CON4                          | -    | -    | -    | -    | IB_CON4.3 | IB_CON4.2 | IB_CON4.1 | IB_CON4.0 |
| R/W                              | -    | -    | -    | -    | R/W       | R/W       | R/W       | R/W       |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | 0         | 0         | 0         | 0         |

| Bit Number | Bit Mnemonic | Description                                        |
|------------|--------------|----------------------------------------------------|
| 3-0        | IB_CON4[3:0] | Must be 09H, else Flash Programming will terminate |

Table 7.11 SSP Flow Control Register4

| F6H, Bank(                  | )     | Bit7     | Bit6                                               | Bit5 | Bit4 | Bit3      | Bit2      | Bit1      | Bit0      |
|-----------------------------|-------|----------|----------------------------------------------------|------|------|-----------|-----------|-----------|-----------|
| IB_CON5                     |       | -        | -                                                  | -    | -    | IB_CON5.3 | IB_CON5.2 | IB_CON5.1 | IB_CON5.0 |
| R/W                         |       | -        | -                                                  | -    | -    | R/W       | R/W       | R/W       | R/W       |
| Reset Value<br>(POR/WDT/LVR | -     | -        | -                                                  | -    | -    | 0         | 0         | 0         | 0         |
| Bit Number                  | Bit N | Inemonic | Description                                        |      |      |           |           |           |           |
| 3-0                         | IB_C  | ON5[3:0] | Must be 06H, else Flash Programming will terminate |      |      |           |           |           |           |



# 7.4.2 Flash Control Flow







### 7.4.3 SSP Programming Notice

To successfully complete SSP programming, the user's software must following the steps below:

### (1) For Code/Data Programming:

- 1. Disable interrupt;
- 2. Fill in the XPAGE, IB\_OFFSET for the corresponding address;
- 3. Fill in IB\_DATA if programming is wanted;
- 4. Fill in IB\_CON1-5 sequentially;
- 5. Add 4 nops for more stable operation;
- 6. Code/Data programming, CPU will be in IDLE mode;
- 7. Go to Step 2 if more data are to be programmed;
- 8. Clear XPAGE; enable interrupt if necessary.

### (2) For Sector Erase:

- 1. Disable interrupt;
- 2. Fill in the XPAGE for the corresponding sector;
- 3. Fill in IB\_CON1-5 sequentially;
- 4. Add 4 NOPs for more stable operation;
- 5. Sector Erase, CPU will be in IDLE mode;
- 6. Go to step 2 if more sectors are to be erased;
- 7. Clear XPAGE; enable interrupt if necessary.

### (3) For Code Reading:

Just Use "MOVC A, @A+DPTR" or "MOVC A, @A+PC".

### (4) For EEPROM-Like:

Steps is same as code programming, the diffenrences are:

1. Set FAC bit in FLASHCON register before programming or erase EEPROM-Like;

2. One sector of EEPROM-Like is 256 bytes.not 1024 bytes.

#### Note:

(1) System clock should not be less than 200KHz to insure falsh programming or sector erase successfully; (2) Clear FAC bit in FLASHCON register ,after programming or erase EEPROM-Like.

#### Table 7.12 Flash Access Control Register

| A7H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| FLASHCON                         | -    | -    | -    | -    | -    | -    | -    | FAC  |
| R/W                              | -    | -    | -    | -    | -    | -    | -    | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | -    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                         |
|------------|--------------|-----------------------------------------------------------------------------------------------------|
| 7-1        | -            | Reserved                                                                                            |
| 0          | FAC          | FAC: Flash access control<br>0: MOVC or SSP access main memory<br>1: MOVC or SSP access EEPROM-like |



### 7.5 System Clock and Oscillator

### 7.5.1 Features

- Three oscillator types: crystal oscillator, ceramic oscillator and 12MHz/128kHz internal RC
- 2 Oscillator pin (XTAL1, XTAL2)
- Built-in 12MHz Internal RC
- Built-in system clock prescaler

### 7.5.2 Clock Definition

The SH79F1616 have several internal clocks defined as below:

**OSCCLK:** the oscillator clock from one of the 3 oscillator types (crystal oscillator, ceramic oscillator and internal RC) f<sub>OSC</sub> is defined as the OSCCLK frequency. t<sub>OSC</sub> is defined as the OSCCLK period.

**WDTCLK:** the internal WDT RC clock.  $f_{WDT}$  is defined as the WDTCLK frequency.  $t_{WDT}$  is defined as the WDTCLK period. **OSCSCLK:** The input clock of the system clock frequency divider.  $f_{OSCS}$  is defined as the OSCSCLK frequency.  $t_{OSCS}$  is defined as the OSCSCLK period.

**SYSCLK:** system clock, the output of system clock prescaler. It is the CPU instruction clock.  $f_{SYS}$  is defined as the SYSCLK frequency.  $t_{SYS}$  is defined as the SYSCLK period.

### 7.5.3 Description

SH79F1616 has three oscillator types: crystal oscillator (2MHz-12MHz), ceramic Oscillator (2MHz-12MHz) and internal RC (12MHz), which is selected by code option OP\_OSC (Refer to code option section for details). The oscillator generates the basic clock pulse that provides the system clock to supply CPU and on-chip peripherals.

### 7.5.4 Register

Table 7.13 System Clock Control Register

| B2H, Bank0                       | Bit7 | Bit6  | Bit5  | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|-------|-------|-------|------|------|------|------|
| CLKCON                           | -    | CLKS1 | CLKS0 | SCMIF | -    | -    | -    | -    |
| R/W                              | -    | R/W   | R/W   | R     | -    | -    | -    | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | 1     | 1     | 0     | -    | -    | -    | -    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                      |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 6-5        | CLKS[1:0]    | SYSCLK Prescaler Register<br>00: $f_{SYS} = f_{OSCS}$<br>01: $f_{SYS} = f_{OSCS}/2$<br>10: $f_{SYS} = f_{OSCS}/4$<br>11: $f_{SYS} = f_{OSCS}/12$ |



### 7.5.5 Oscillator Type

(1) internal RC, XTAL are shared with IO



(2) OP\_OSC = 1110: 2M - 12M Crystal/Ceramic Oscillator at XTAL\*



\*: If the environment humidity is bigger, use the high frequency oscillator, advice plus 510k feedback resistance.

# 7.5.6 Capacitor Selection for Oscillator

| Ceramic Oscillator |    |  |  |  |  |  |
|--------------------|----|--|--|--|--|--|
| C1                 | C2 |  |  |  |  |  |
| -                  | -  |  |  |  |  |  |
| -                  | -  |  |  |  |  |  |
|                    |    |  |  |  |  |  |

| Crystal Oscillator |          |          |  |  |  |  |
|--------------------|----------|----------|--|--|--|--|
| Frequency          | C1       | C2       |  |  |  |  |
| 4MHz               | 8 - 15pF | 8 - 15pF |  |  |  |  |
| 12MHz              | 8 - 15pF | 8 - 15pF |  |  |  |  |

#### Notes:

### (1) Capacitor values are used for design guidance only!

- (2) These capacitors were tested with the crystals listed above for basic start-up and operation. They are not optimized.
- (3) Be careful for the stray capacitance on PCB board, the user should test the performance of the oscillator over the expected V<sub>DD</sub> and the temperature range for the application.

Before selecting crystal/ceramic, the user should consult the crystal/ceramic manufacturer for appropriate value of external component to get best performance, visit <u>http://www.sinowealth.com</u> for more recommended manufactures.





### 7.6 System Clock Monitor (SCM)

In order to enhance the system reliability, SH79F1616 contains a system clock monitor (SCM) module. If the system clock fails (for example the oscillator stops oscillating), the built-in SCM will switch the OSCCLK to the internal 32k WDTCLK and set system clock monitor bit (SCMIF) to 1. And the SCM interrupt will be generated when EA and ESCM is enabled. If the OSCCLK comes back, SCM will switch the OSCCLK back to the oscillator and clears the SCMIF automatically.

#### Notes:

The SCMIF is read only register; it can be clear to 0 or set to 1 by hardware only.

If SCMIF is cleared, the SCM switches the system clock to the state before system clock fail automatically.

If Internal RC is selected as OSCCLK by code option (Refer to code option section for detail), the SCM can not work.

| Table 7.14 Syster | n Clock Control Register |
|-------------------|--------------------------|
|-------------------|--------------------------|

| B2H                              | Bit7 | Bit6 | Bit5 | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|-------|------|------|------|------|
| CLKCON                           | -    | -    | -    | SCMIF | -    | -    | -    | -    |
| R/W                              | -    | -    | -    | R     | -    | -    | -    | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | 0     | -    | -    | -    | -    |

| Bit Number | Bit Mnemonic | Description                                                                                                                              |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | SCMIF        | System Clock Monitor bit<br>0: Clear by hardware to indicate system clock is normal<br>1: Set by hardware to indicate system clock fails |



# 7.7 I/O Port

# 7.7.1 Features

- 30 bi-directional I/O ports
- Share with alternative functions

The SH79F1616 has 30 bi-directional I/O ports. The PORT data is put in Px register. The PORT control register (PxCRy) controls the PORT as input or output. Each I/O port has an internal pull-high resistor, which is controlled by PxPCRy when the PORT is used as input (x = 0-5, y = 0-7).

For SH79F1616, some I/O pins can share with alternative functions. There exists a priority rule in CPU to avoid these functions be conflict when all the functions are enabled. (Refer to **Port Share** Section for details).

### 7.7.2 Register

Table 7.15 Port Control Register

| E1H - E5H                        | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|----------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| P0CR (E1H, Bank0)                | P0CR.7 | P0CR.6 | -      | -      | P0CR.3 | P0CR.2 | -      | -      |
| P1CR (E2H, Bank0)                | -      | -      | -      | P1CR.4 | P1CR.3 | P1CR.2 | P1CR.1 | P1CR.0 |
| P2CR (E3H, Bank0)                | -      | P2CR.6 | P2CR.5 | -      | -      | -      | P2CR.1 | P2CR.0 |
| P3CR (E4H, Bank0)                | P3CR.7 | P3CR.6 | P3CR.5 | P3CR.4 | P3CR.3 | P3CR.2 | P3CR.1 | P3CR.0 |
| P4CR (E5H, Bank0)                | -      | -      | -      | P4CR.4 | P4CR.3 | P4CR.2 | P4CR.1 | P4CR.0 |
| P5CR (E1H, Bank1)                | -      | -      | -      | -      | P5CR.3 | P5CR.2 | P5CR.1 | P5CR.0 |
| R/W                              | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

| Bit Number | Bit Mnemonic              | Description                                                                     |
|------------|---------------------------|---------------------------------------------------------------------------------|
| 7-0        | PxCRy<br>x = 0-5, y = 0-7 | Port input/output direction control Register<br>0: input mode<br>1: output mode |

### Table 7.16 Port Pull up Resistor Control Register

| E9H - ECH                        | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|----------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| P0PCR (E9H, Bank0)               | P0PCR.7 | P0PCR.6 | -       | -       | P0PCR.3 | P0PCR.2 | -       | -       |
| P1PCR (EAH, Bank0)               | -       | -       | -       | P1PCR.4 | P1PCR.3 | P1PCR.2 | P1PCR.1 | P1PCR.0 |
| P2PCR (EBH, Bank0)               | -       | P2PCR.6 | P2PCR.5 | -       | -       | -       | P2PCR.1 | P2PCR.0 |
| P3PCR (ECH, Bank0)               | P3PCR.7 | P3PCR.6 | P3PCR.5 | P3PCR.4 | P3PCR.3 | P3PCR.2 | P3PCR.1 | P3PCR.0 |
| P4PCR (EDH, Bank0)               | -       | -       | -       | P4PCR.4 | P4PCR.3 | P4PCR.2 | P4PCR.1 | P4PCR.0 |
| P5PCR (E9H, Bank1)               | -       | -       | -       | -       | P5PCR.3 | P5PCR.2 | P5PCR.1 | P5PCR.0 |
| R/W                              | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| Bit Number | Bit Mnemonic               | Description                                                                                                                                        |
|------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0        | PxPCRy<br>x = 0-5, y = 0-7 | Input Port internal pull-high resistor enable/disable control<br>0: internal pull-high resistor disabled<br>1: internal pull-high resistor enabled |



Table 7.17 Port Data Register

| 80H - C0H                        |                         | Bit7     | Bit6        | Bit5    | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
|----------------------------------|-------------------------|----------|-------------|---------|------|------|------|------|------|--|
| P0 (80H, Bank0)                  |                         | P0.7     | P0.6        | -       | -    | P0.3 | P0.2 | -    | -    |  |
| P1 (90H, Bank                    | <b>(0)</b>              | -        | -           | -       | P1.4 | P1.3 | P1.2 | P1.1 | P1.0 |  |
| P2 (A0H, Bank                    | <b>(</b> 0)             | -        | P2.6        | P2.5    | -    | -    | -    | P2.1 | P2.0 |  |
| P3 (B0H, Bank0)                  |                         | P3.7     | P3.6        | P3.5    | P3.4 | P3.3 | P3.2 | P3.1 | P3.0 |  |
| P4 (C0H, Bank0)                  |                         | -        | -           | -       | P4.4 | P4.3 | P4.2 | P4.1 | P4.0 |  |
| P5 (80H, Bank1)                  |                         | -        | -           | -       | -    | P5.3 | P5.2 | P5.1 | P5.0 |  |
| R/W                              | R/W                     |          | R/W         | R/W     | R/W  | R/W  | R/W  | R/W  | R/W  |  |
| Reset Value<br>(POR/WDT/LVR/PIN) |                         | 0        | 0           | 0       | 0    | 0    | 0    | 0    | 0    |  |
|                                  |                         |          |             |         |      |      |      |      |      |  |
| Bit Number                       | Bit Number Bit Mnemonic |          | Description |         |      |      |      |      |      |  |
| 7-0                              |                         | 7-0 Px.y |             | egister |      |      |      |      |      |  |

| <b>Note:</b> For improving reliability, please set the unused bits in PxCR ( $x = 0.5$ ), clear the unused bits in PxPCR ( $x = 0.5$ ) and Px ( $x = 0.5$ ) |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| = 0-5).Refer to the Section "8.13 Programming Note" for detailed setting.                                                                                   |

# 7.7.3 Port Diagram

x = 0.5, y = 0.7



### Note:

- (1) The input source of reading input port operation is from the input pin directly.
- (2) The input source of reading output port operation has two paths, one is from the port data Register, and the other is from the output pin directly.
- (3) The read Instruction distinguishes which path is selected: The read-modify-write instruction is for the reading of the data register in output mode, and the other instructions are for reading of the output pin directly.
- (4) The destination of writing port operation is the data register regardless the port shared as the second function or not.





# 7.7.4 Port Share

The 30 bi-directional I/O ports can also share second or third special function. But the share priority should obey the **Outer Most Inner Lest** rule:

The out most pin function in **Pin Configuration** has the highest priority, and the inner most pin function has the lowest priority. This means when one pin is occupied by a higher priority function (if enabled), it cannot be used as the lower priority functional pin, even the lower priority function is also enabled. Only until the higher priority function is closed by hardware or software, can the corresponding pin be released for the lower priority function use. Also the function that need pull up resister is also controlled by the same rule.

When port share function is enabled, the user can modify PxCR, PxPCR (x = 0.5), but these operations will have no effect on the port status until the second function was disabled.

When port share function is enabled, any read or write operation to port will only affect the data register while the port pin keeps unchanged until all the share functions are disabled.

### PORT0:

- PWM01: PWM01 output (P0.2)

- PWM0: PWM0 output (P0.3)
- INT2: external inturrupt2 (P0.6)
- INT3: external inturrupt3 (P0.7)
- T4: Timer4 reload/capture control (P0.3)

### Table 7.18 PORT0 Share Table

| Pin No. | Priority | Function | Enable bit                                                                                                              |
|---------|----------|----------|-------------------------------------------------------------------------------------------------------------------------|
| 31      | 1        | PWM01    | Set EPWM01 bit in PWMEN register                                                                                        |
| 51      | 2        | P0.2     | Above condition is not met                                                                                              |
|         | 1        | PWM0     | Set EPWM0 bit in PWMEN register                                                                                         |
| 32      | 2        | T4       | Set TR4 bit and T4CLKS bit in T4CON register (Auto Pull up) or clear T4CLKS bit and set TC4 bit or set TR4 bit in Mode2 |
|         | 3        | P0.3     | Above condition is not met                                                                                              |
| 1       | 1        | INT2     | Set EX2 bit in IEN1 Register and Port0.6 is in input mode                                                               |
|         | 2        | P0.6     | Above condition is not met                                                                                              |
| 2       | 1        | INT3     | Set EX3 bit in IEN1 Register and Port0.7 is in input mode                                                               |
| 2       | 2        | P0.7     | Above condition is not met                                                                                              |

### PORT1:

Table 7.19 PORT1 Share Table

| Pin No. | Priority | Function  | Enable bit |
|---------|----------|-----------|------------|
| 22-26   | 1        | P1.0-P1.4 | Default    |

### PORT2:

- RXD: EUART data input (P2.0)

- TXD: EUART data output (P2.1)

- FLT: Fault input pin (P2.5)

### Table 7.20 PORT2 Share Table

| Pin No. | Priority | Function | Enable bit                                  |
|---------|----------|----------|---------------------------------------------|
| 07      | 1        | RXD      | Set REN bit in SCON Register (Auto Pull up) |
| 27      | 2        | P2.0     | Above condition is not met                  |
| 20      | 1        | TXD      | Write to SBUF Register                      |
| 28      | 2        | P2.1     | Above condition is not met                  |
| 20      | 1        | FLT      | Set RFLT bit in <b>PWMEN</b> Register       |
| 29      | 2        | P2.5     | Above condition is not met                  |
| 30      | 1        | P2.6     | Default                                     |



### PORT3:

- AN4-AN7: ADC input channel (P3.4-P3.7)

Table 7.21 PORT3 Share Table

| Pin No. | Priority | Function  | Enable bit                                                                           |
|---------|----------|-----------|--------------------------------------------------------------------------------------|
| 14-17   | 1        | AN7-AN4   | Set CH7-4 bit in ADCH Register and set ADON bit in ADCON Register, and set SCH [2:0] |
|         | 2        | P3.7-P3.4 | Above condition is not met                                                           |
| 18-21   | 1        | P3.3-P3.0 | Default                                                                              |

### PORT4:

- INT40-INT43 (P4.0-P4.3): External interrupt input

- AN0-AN3 (P4.0-P4.3): ADC input channel

- AVREF (P4.4): AD reference voltage

Table 7.22 PORT4 Share Table

| Pin No. | Priority | Function    | Enable bit                                                                              |
|---------|----------|-------------|-----------------------------------------------------------------------------------------|
| 9       | 1        | AVREF       | Set REFC bit in ADCON register                                                          |
| 9       | 2        | P4.4        | Above condition is not met                                                              |
|         | 1        | AN3-AN0     | Set CH3-0 bit in ADCH Register and set ADON bit in ADCON Register, and set SCH [2:0]    |
| 10-13   | 2        | INT43-INT40 | Set EX4 bit in IEN1 register and EXS43-40 bit in IENC register, P4.3-P4.0 in input mode |
|         | 3        | P4.3-P4.0   | Above condition is not met                                                              |

### PORT5:

- XTAL1 (P5.0): XTAL input
- XTAL2 (P5.1): XTAL output

- RST (P5.2): system reset pin

- BUZ (P5.3): Buzzer output

- T3 (P5.3): Timer3 external input

Table 7.23 PORT5 Share Table

| Pin No. | Priority | Function | Enable bit                                                        |
|---------|----------|----------|-------------------------------------------------------------------|
| 4       | 1        | XTAL1    | Selected by Code Option                                           |
| 4       | 2        | P5.0     | Above condition is not met                                        |
| 5       | 1        | XTAL2    | Selected by Code Option                                           |
| 5       | 2        | P5.1     | Above condition is not met                                        |
| G       | 1        | RST      | Selected by Code Option                                           |
| 6       | 2        | P5.2     | Above condition is not met                                        |
|         | 1        | BUZ      | Set BZEN bit in BUZCON register                                   |
| 7       | 2        | Т3       | Set TR3 bit in T3CON register and T3CLKS[1:0] = 01 (Auto Pull up) |
|         | 3        | P5.3     | Above condition is not met                                        |



# 7.8 Timer

### 7.8.1 Features

- The SH79F1616 has four timers (Timer2, 3, 4, 5)
- Timer2 & Timer4 are 16-bit auto-reload timer and can be selected as a baud-rate generator
- Timer3 is a 16-bit auto-reload timer and can operate even in Power-Down mode
- Timer5 is a 16-bit auto-reload timer

### 7.8.2 Timer2

The Timer 2 is implemented as a 16-bit register accessed as two cascaded data registers: TH2 and TL2. It is controlled by the register T2CON and T2MOD. The Timer2 interrupt can be enabled by setting the ET2 bit in the IEN0 register. (Refer to Interrupt Section for details)

### **Timer2 Modes**

Timer2 has 2 operating modes: Auto-reload mode with up counter, Baud Rate Generator. These modes are selected by the combination of RCLK, TCLK and CP/RL2.

Table 7.24 Timer2 Mode select

| C/T2 | T2OE | DCEN | TR2 | CP/RL2 | RCLK | TCLK | MODE |                          |  |
|------|------|------|-----|--------|------|------|------|--------------------------|--|
| 0    | 0    | 0    | 1   | 0      | 0    | 0    | 1    | 16 bit auto-reload timer |  |
| 0    | 0    | 0    | 1   | 0      | 1    | Х    | 2    | Baud-Rate generator      |  |
| 0    | 0    | 0    | I   | 0      | Х    | 1    | 2    | Baud-Nale generator      |  |

### Mode1: 16 bit auto-reload Timer

Set the **CP/RL2 = 0**, **C/T2 = 0**, **EXEN2 = 0** and register T2MOD write zero, Timer2 is set as Auto-reload mode with up counter. Timer 2 will overflow at 0FFFFH and sets the TF2 bit, the overflow also cause the 16-bits value in RCAP2H and RCAP2L to be reloaded into TH2 and TL2, respectively. The TF2 bit can generate an interrupt if ET2 is enabled.





### Mode2: Baud-Rate Generator

Timer2 is selected as the baud rate generator by setting TCLK and/or RCLK in T2CON. The baud rates for transmit and receive can be different if Timer2 is used for the receiver or transmitter and Timer4 is used for the other.

Setting RCLK and/or TCLK will put Timer2 into its baud rate generator mode, which is similar to the auto-reload mode.

he remaining bits of the T2CON register is set to the **CP/RL2 = 0**, C/T2 = 0, **EXEN2 = 0**, and register T2MOD write zero. Over flow of Timer2 will causes the Timer2 registers to be reloaded with the 16-bit value in registers RCAP2H and RCAP2L that preset by software. But this will not generate an interrupt.

The baud rates in EUART Modes1 and 3 are determined by Timer2's overflow rate according to the following equation.

BaudRate = 
$$\frac{1}{2 \times 16} \times \frac{^{t}\text{SYS}}{65536 - [\text{RCAP2H}, \text{RCAP2L}]}$$
; C/T2 = 0



### Note:

- (1) When an event occurs, or any other time TF2 bit can be written "1" by software, only the software and hardware reset can clear TF2 bit.
- (2) When EA = 1 & ET2 = 1, set TF2 can cause Timer2 interrupt.
- (3) When Timer2 is set as baud-rate generator, to write TH2/TL2 or RCAPH2/RCAPL2 will affect the accuracy of the baud rate, it can also cause communication errors.



# Registers

Table 7.25 Timer2 Control Register

| C8H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3  | Bit2 | Bit1 | Bit0   |
|----------------------------------|------|------|------|------|-------|------|------|--------|
| T2CON                            | TF2  | EXF2 | RCLK | TCLK | EXEN2 | TR2  | C/T2 | CP/RL2 |
| R/W                              | R/W  | R/W  | R/W  | R/W  | R/W   | R/W  | R/W  | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | 0     | 0    | 0    | 0      |

| Bit Number | Bit Mnemonic | Description                                                                                                                    |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| 7          | TF2          | Timer2 overflow flag bit<br>0: No overflow<br>1: Overflow (Set by hardware if RCLK = 0 & TCLK = 0)                             |
| 6          | EXF2         | This bit must write 0                                                                                                          |
| 5          | RCLK         | EUART0 Receive Clock control bit<br>0: Timer 4 generates receiveing baud-rate<br>1: Timer 2 generates receiveing baud-rate     |
| 4          | TCLK         | EUART0 Transmit Clock control bit<br>0: Timer4 generates transmitting baud-rate<br>1: Timer 2 generates transmitting baud-rate |
| 3          | EXEN2        | This bit must write 0                                                                                                          |
| 2          | TR2          | Timer2 start/stop control bit<br>0: Stop Timer2<br>1: Start Timer2                                                             |
| 1          | C/T2         | This bit must write 0                                                                                                          |
| 0          | CP/RL2       | This bit must write 0                                                                                                          |

# Table 7.26 Timer2 Mode Control Register

| C9H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| T2MOD                            | -    | -    | -    | -    | -    | -    | T2OE | DCEN |
| R/W                              | -    | -    | -    | -    | -    | -    | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description           |
|------------|--------------|-----------------------|
| 1          | T2OE         | This bit must write 0 |
| 0          | DCEN         | This bit must write 0 |



| CAH-CDH, Bank0               |                         | Bit7     | Bit6                                      | Bit5                                   | Bit4         | Bit3     | Bit2     | Bit1     | Bit0     |  |
|------------------------------|-------------------------|----------|-------------------------------------------|----------------------------------------|--------------|----------|----------|----------|----------|--|
| RCAP2L                       |                         | RCAP2L.7 | RCAP2L.6                                  | RCAP2L.5                               | RCAP2L.4     | RCAP2L.3 | RCAP2L.2 | RCAP2L.1 | RCAP2L.0 |  |
| RCAP2H                       |                         | RCAP2H.7 | RCAP2H.6                                  | RCAP2H.5                               | RCAP2H.4     | RCAP2H.3 | RCAP2H.2 | RCAP2H.1 | RCAP2H.0 |  |
| TL2                          |                         | TL2.7    | TL2.6                                     | TL2.5                                  | TL2.4        | TL2.3    | TL2.2    | TL2.1    | TL2.0    |  |
| TH2                          |                         | TH2.7    | TH2.6                                     | TH2.5                                  | TH2.4        | TH2.3    | TH2.2    | TH2.1    | TH2.0    |  |
| R/W                          |                         | R/W      | R/W                                       | R/W                                    | R/W          | R/W      | R/W      | R/W      | R/W      |  |
| Reset Value<br>(POR/WDT/LVR/ |                         | 0        | 0                                         | 0                                      | 0            | 0        | 0        | 0        | 0        |  |
| Bit Number                   | Bit Number Bit Mnemonic |          | Description                               |                                        |              |          |          |          |          |  |
| 7.0                          | RC                      | AP2L.x   |                                           |                                        |              |          |          |          |          |  |
| 7-0                          | RC                      | AP2H.x   | Timer2 Reid                               | Timer2 Reload/Capturer Data, x = 0 - 7 |              |          |          |          |          |  |
| 7-0                          |                         | TL2.x    | Timer2 Low & High byte counter, x = 0 - 7 |                                        |              |          |          |          |          |  |
| 7-0                          | 1                       | ГН2.х    |                                           | a nign byt                             | e counter, x | - 0 - 7  |          |          |          |  |

# Table 7.27 Timer2 Reload/Capture & Data Registers



# 7.8.3 Timer3

Timer3 is a 16-bit auto-reload timer. It is accessed as two cascaded data registers: TH3 and TL3. It is controlled by the T3CON register. The Timer3 interrupt can be enabled by setting ET3 bit in IEN1 register (Refer to **Interrupt** Section for details).

Timer3 has only one operating mode: 16-bit Counter/Timer with auto-reload. Timer3 also supports the following features: selectable pre-scaler setting and Operation during CPU Power-Down mode.

Timer3 consists of a 16-bit counter/reload register (TH3, TL3). When writing to TH3 and TL3, they are used as timer load register. When reading from TH3 and TL3, they are used as timer counter register. Setting the TR3 bit enables Timer3 to count up. The Timer will overflow from 0xFFFF to 0x0000 and set the TF3 bit. This overflow also causes the 16-bit value written in timer load register to be reloaded into the timer counter register. Writing to TH3 also can cause the 16-bit value written in timer load register to be reloaded into the timer counter register.

Read or write operation to TH3 and TL3 should follow these steps:

Write operation: Low bits first, High bits followed.

Read operation: High bits first, Low bits followed.



Timer3 can operate even in Power-Down mode.

When OP\_OSC[3:0] (Refer to Code Option Section for details) is 0000 and 1110, T3CLKS [1:0] can select 00, 01. If T3CLKS[1:0] is 00, Timer3 can't work in Power Down mode. If T3CLKS[1:0] is 01 and external clock input from T3 Pin, Timer3 can work in CPU normal operating or Power Down mode. It can be described in the following table.

| OP_OSC[3:0] | T3CLKS[1:0] | Can work in normal mode | Can work in Power Down mode |
|-------------|-------------|-------------------------|-----------------------------|
| 0000 1110   | 00          | YES                     | NO                          |
| 0000, 1110  | 01          | YES                     | YES                         |

Note:

(1) When TH3 and TL3 read or written, must make sure TR3 = 0.

(2) When T3 is selected as Timer3 clock source and TR3 is set 0 to 1, the first T3 down edge will be ignored.



## Registers

Table 7.28 Timer3 Control Register

| 88H, Bank1                  |       | Bit7     | Bit6                                                                                              | Bit5                                 | Bit4                                         | Bit3        | Bit2 | Bit1     | Bit0     |  |
|-----------------------------|-------|----------|---------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------|-------------|------|----------|----------|--|
| T3CON                       |       | TF3      | -                                                                                                 | T3PS.1                               | T3PS.0                                       | -           | TR3  | T3CLKS.1 | T3CLKS.0 |  |
| R/W                         |       | R/W      | -                                                                                                 | R/W                                  | R/W                                          | -           | R/W  | R/W      | R/W      |  |
| Reset Value<br>(POR/WDT/LVR |       | 0        | -                                                                                                 | 0                                    | 0                                            | -           | 0    | 0        | 0        |  |
| Bit Number                  | Bit N | Inemonic |                                                                                                   |                                      | [                                            | Description |      |          |          |  |
| 7                           |       | TF3      | Timer3 overflow flag bit<br>0: No overflow (cleared by hardware)<br>1: Overflow (Set by hardware) |                                      |                                              |             |      |          |          |  |
| 5-4                         | Т3    | PS[1:0]  | <b>Timer3 inpu</b><br>00: 1/1<br>01: 1/8<br>10: 1/64<br>11: 1/256                                 |                                      | scaler Selec                                 | t bits      |      |          |          |  |
| 2                           |       | TR3      | <b>Timer3 start/stop control bit</b><br>0: Stop Timer3<br>1: Start Timer3                         |                                      |                                              |             |      |          |          |  |
| 1-0                         | T3C   | LKS[1:0] |                                                                                                   | em clock, T3<br>mal clock fro<br>rve | elect bits<br>pin is used a<br>m pin T3, aut |             |      |          |          |  |

Note: T3CLK[1:0] can only select 00 and 01.

 Table 7.29 Timer3 Reload/Counter Data Registers

| 8CH-8DH, Bank1                   | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| TL3                              | TL3.7 | TL3.6 | TL3.5 | TL3.4 | TL3.3 | TL3.2 | TL3.1 | TL3.0 |
| TH3                              | TH3.7 | TH3.6 | TH3.5 | TH3.4 | TH3.3 | TH3.2 | TH3.1 | TH3.0 |
| R/W                              | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                                 |  |  |  |
|------------|--------------|---------------------------------------------|--|--|--|
| 7.0        | TL3.x        | Timer 2 Levy 8 High byte counter $y = 0.7$  |  |  |  |
| 7-0        | TH3.x        | Timer3 Low & High byte counter, $x = 0 - 7$ |  |  |  |

Table 7.30 Timer3 Reload/Count Data Register

| 89H, Bank1                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1    | Bit0    |
|----------------------------------|------|------|------|------|------|------|---------|---------|
| SWTHL                            | -    | -    | -    | -    | -    | -    | T5HLCON | T3HLCON |
| R/W                              | -    | -    | -    | -    | -    | -    | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | 0       | 0       |

| Bit Number | Bit Mnemonic   | Description                                                                                          |
|------------|----------------|------------------------------------------------------------------------------------------------------|
| 0          | <b>T3HLCON</b> | 0: when read TH3, TL3, return T3 count data<br>1: when read TH3, TL3, return T3 reload register data |





### 7.8.4 Timer4

Timer4 is a 16-bit auto-reload timer. It is accessed as two cascaded data registers: TH4 and TL4. It is controlled by the T4CON register. The Timer 4 interrupt can be enabled by setting ET4 bit in IEN1 register (Refer to **interrupt** Section for details).

When writing to TH4 and TL4, they are used as timer load register. When reading from TH4 and TL4, they are used as timer counter register. Setting the TR4 bit enables Timer 4 to count up. The timer will overflow from 0xFFFF to 0x0000 and set the TF4 bit. This overflow also causes the 16-bit value written in timer load register to be reloaded into the timer counter register. Writing to TH4 also can cause the 16-bit value written in timer load register to be reloaded into the timer counter register.

Read or write operation to TH4 and TL4 should follow these steps:

Write operation: Low bits first, High bits followed.

Read operation: High bits first, Low bits followed.

#### **Timer4 Modes**

Timer4 has three operating modes: 16-bit auto-reload counter/timer, Baud Rate Generator and 16 bit auto-reload timer with T4 edge trig. These modes are selected by T4M[1:0] bits in T4CON Register.

#### Mode0: 16 bit Auto-Reload Counter/Timer

Timer4 operates as 16-bit counter/timer in Mode 0. The TH4 register holds the high eight bits of the 16-bit counter/timer, TL4 holds the low eight bits. As the 16-bit timer register increments and overflows from 0xFFFF to 0x0000, the timer overflow flag TF4 (T4CON.7) is set and the 16-bit value in timer load register are reloaded into timer counter register, and an interrupt will occur if Timer4 interrupts is enabled.

The T4CLKS bit (T4CON.0) selects the counter/timer's clock source. If T4CLKS = 1, external clock from the Pin T4 is selected as Timer4 clock, after prescaled, it will increase the Counter/Timer4 Data register. Else if T4CLKS = 0, the system clock is selected as Timer4 clock.

Setting the TR4 bit (T4CON.1) enables the timer. Setting TR4 does not force the timer to reset. The timer load register should be loaded with the desired initial value before the timer is enabled.

In Compare mode, the T4 pin is automatically set as output mode by hardware. the internal counter is constantly countered from TH4 and TL4 register value to 0xFFFF. When an overflow occurs, the T4 pin will be inverted. At the same time, interrupt flag bit of Time4 is set. Timer4 must be running in Timer mode (T4CLKS = 0) when compare function enabled.







#### Mode1: Baud-Rate Generator

By set in the T4CON register T4M[1:0] for 01 select timer 4 as baud rate generator. If Timer2 as the baud rate of the serial port to receive or send, while the timer as another baud rate, the baud rate of the transmit and receive can be different.

The mode is similar to the auto-reload mode. Overflow of Timer4 will causes the Timer4 counter register to be reloaded with the 16-bit value in timer load register. But this will not generate an interrupt.

The baud rates in EUART mode1 and mode3 are determined by Timer4's overflow rate according to the following equation.

$$\begin{split} \text{BaudRate} &= \frac{1}{2 \times 16} \times \frac{\frac{f}{T4}/\text{PRESCALER}}{65536 - [\text{TH4}, \text{TL4}]} \text{, } \text{T4CLKS} = 0 \\ \text{BaudRate} &= \frac{1}{16} \times \frac{\frac{f}{T4}/\text{PRESCALER}}{65536 - [\text{TH4}, \text{TL4}]} \text{, } \text{T4CLKS} = 1 \end{split}$$

TH4 and TL4 stand for Timer4 reload register.

#### Mode2: 16 bit Auto-Reload Timer with T4 Edge Trig

Timer4 in the way for 16-bit auto-reload timer. Bit of T4CON.0 register T4CLKS been 0, Timer 4 can only select the system clock as the clock source, consistent with the rest of the set with Mode 0.

In Mode2, T4CON.1 the TR4set. Timer4 waiting for T4 trigger signal port (by The T4M [1:0] control the rising/falling) began to count, a trigger signal to the Timer4 running. When Timer4 overflows from 0xFFFF to 0x0000, TF4 (T4CON.7) will be set and timer 4 interrupt enable, will produce Timer4 interrupt. T4CLKS bit is always 0. The Timer clock for the system clock. Timer reload register data re-TH4 and TL4 held until the next trigger signal.

In Mode2, After Setting the TR4 bit (T4CON.1), Timer4 does not start counting but waits the trig signal (rising or falling edge controlled by T4M[1:0]) from T4. An active trig signal will start the Timer4. When Timer 4 overflows from 0XFFFF to 0x0000, TF4 will be set, TH4 and TL4 will be reloaded from timer load register, and Timer4 holds and waits the next trig edge.

When Timer4 is working, an active trig signal maybe come, if TC bit equals 0, the trig signal will be ignored; if TC bit equals 1, Timer4 will be re-trigged.

Setting TR4 does not force the timer to reset. The timer register should be loaded with the desired initial value before the timer is enabled.



#### Note:

- (1) When Timer4 is running (TR4 = 1) as a timer in the baud rate generator mode, TH4 or TL4 should not be written to. Because a write might overlap a reload and cause write and/or reload errors. So, the timer 4 must be turned off (TR4 = 0) before accessing the TH4 or TL4 registers.
- (2) When Timer4 is used as a counter, the frequency of input signal of T4 pin must be less than half of system clock.



## Registers

Table 7.31 Timer4 Control Register

| C8H, Bank  | 1                               | Bit7     | Bit6                                                                                                                                                                                                                                                                                              | Bit5  | Bit4  | Bit3        | Bit2 | Bit1       | Bit0   |  |
|------------|---------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------------|------|------------|--------|--|
| T4CON      |                                 | TF4      | TC4                                                                                                                                                                                                                                                                                               | T4PS1 | T4PS0 | T4M1        | T4M0 | TR4        | T4CLKS |  |
| R/W        | R/W R/W                         |          | R/W                                                                                                                                                                                                                                                                                               | R/W   | R/W   | R/W         | R/W  | R/W        | R/W    |  |
|            | Reset Value 0 (POR/WDT/LVR/PIN) |          | 0                                                                                                                                                                                                                                                                                                 | 0     | 0     | 0           | 0    | 0          | 0      |  |
| Bit Number | Bit N                           | Inemonic |                                                                                                                                                                                                                                                                                                   |       |       | Description |      |            |        |  |
| 7          |                                 | TF4      | Timer4 overflow flag bit<br>0: No overflow (cleared by hardware)<br>1: Overflow (Set by hardware)                                                                                                                                                                                                 |       |       |             |      |            |        |  |
| 6          |                                 | TC4      | Compare function Enable bit<br>When T4M[1:0] = 00<br>0: Disable compare function of Timer4<br>1: Enable compare function of Timer4<br>When T4M[1:0] = 10 or 11<br>0: Timer4 can't be re-trigged<br>1: Timer4 can be re-trigged                                                                    |       |       |             |      |            |        |  |
| 5-4        | T4                              | PS[1:0]  | Timer4 input clock Prescale Select bits<br>00: 1/1<br>01: 1/8<br>10: 1/64<br>11: 1/256                                                                                                                                                                                                            |       |       |             |      |            |        |  |
| 3-2        | T4                              | IM[1:0]  | Timer4 Mode Select bit<br>00: Mode0, 16-bit auto-reload up counter/timer<br>01: Mode1, baud-rate generator for EUART<br>10: Mode2 with rising edge trig from pin T4 (system clock only, T4CLKS is invalid)<br>11: Mode2 with falling edge trig from pin T4 (system clock only, T4CLKS is invalid) |       |       |             |      |            |        |  |
| 1          |                                 | TR4      | Timer4 start/stop control bit<br>0: Stop Timer4<br>1: Start Timer4                                                                                                                                                                                                                                |       |       |             |      |            |        |  |
| 0          | T                               | 4CLKS    | <ul> <li>Timer4 Clock Source select bit</li> <li>0: System clock, T4 pin is used as I/O port</li> <li>1: External clock from pin T4 (On the falling edge), the internal pull-up resister i turned on</li> </ul>                                                                                   |       |       |             |      | esister is |        |  |

Table 7.32 Timer4 Reload/Counter Data Registers

| CCH-CDH, Bank1                   | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| TL4                              | TL4.7 | TL4.6 | TL4.5 | TL4.4 | TL4.3 | TL4.2 | TL4.1 | TL4.0 |
| TH4                              | TH4.7 | TH4.6 | TH4.5 | TH4.4 | TH4.3 | TH4.2 | TH4.1 | TH4.0 |
| R/W                              | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                               |
|------------|--------------|-------------------------------------------|
| 7-0        | TL4.x        | Timer 4 Low 8 High byte counter $x = 0$   |
| 7-0        | TH4.x        | Timer4 Low & High byte counter, x = 0 - 7 |



### 7.8.5 Timer5

Timer5 is a 16-bit auto-reload timer. It is accessed as two cascaded data registers: TH5 and TL5. It is controlled by the T5CON register. The interrupt can be enabled by setting ET5 bit in IEN0 register (Refer to **interrupt** Section for details).

When writing to TH5 and TL5, they are used as timer load register. When reading from TH5 and TL5, they are used as timer counter register. Setting the TR5 bit enables Timer5 to count up. The timer will overflow from 0xFFFF to 0x0000 and set the TF5 bit. This overflow also causes the 16-bit value written in timer load register to be reloaded into the timer counter register. Writing to TH4 also can cause the 16-bit value written in timer load register to be reloaded into the timer counter register.

Read or write operation to TH5 and TL5 should follow these steps:

Write operation: Low bits first, High bits followed.

Read operation: High bits first, Low bits followed.

#### **Timer5 Modes**

Timer5 has one operating modes: 16-bit auto-reload counter/timer.

#### Mode0: 16 bit Auto-Reload Counter/Timer

Timer5 operates as 16-bit counter/timer in Mode 0. The TH5 register holds the high eight bits of the 16-bit counter/timer, TL5 holds the low eight bits. As the 16-bit timer register increments and overflows from 0xFFFF to 0x0000, the timer overflow flag TF5 (T5CON.7) is set and the 16-bit value in timer load register are reloaded into timer counter register, and an interrupt will occur if Timer 5 interrupts is enabled. The T4CLKS bit (T4CON.0) selects the counter/timer's clock source.

Setting the TR5 bit (T5CON.1) enables the timer. Setting TR5 does not force the timer to reset. The timer load register should be loaded with the desired initial value before the timer is enabled.





## Registers

Table 7.33 Timer5 Control Register

| C0H, Bank1                       | Bit7 | Bit6 | Bit5  | Bit4  | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|-------|-------|------|------|------|------|
| T5CON                            | TF5  | -    | T5PS1 | T5PS0 | -    | -    | TR5  | -    |
| R/W                              | R/W  | -    | R/W   | R/W   | -    | -    | R/W  | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | -    | 0     | 0     | -    | -    | 0    | -    |

| Bit Number | Bit Mnemonic | Description                                                                                                        |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------|
| 7          | TF5          | Timer5 overflow flag bit<br>0: No overflow (cleared by hardware)<br>1: Overflow (Set by hardware)                  |
| 5-4        | T5PS[1:0]    | Timer5 input clock Prescale Select bits           00: 1/1           01: 1/8           10: 1/64           11: 1/256 |
| 1          | TR5          | Timer5 start/stop control bit<br>0: Stop Timer5<br>1: Start Timer5                                                 |

Table 7.34 Timer5 Reload/Counter Data Registers

| CEH-CFH, Bank1                   | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| TL5                              | TL5.7 | TL5.6 | TL5.5 | TL5.4 | TL5.3 | TL5.2 | TL5.1 | TL5.0 |
| TH5                              | TH5.7 | TH5.6 | TH5.5 | TH5.4 | TH5.3 | TH5.2 | TH5.1 | TH5.0 |
| R/W                              | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                                        |
|------------|--------------|----------------------------------------------------|
| 7-0        | TL5.x        | Timer E Low $\theta$ High byte counter $x = 0$ , 7 |
| 7-0        | TH5.x        | Timer5 Low & High byte counter, x = 0 - 7          |

Table 7.35 Timer5 Reload/Count Data Register

| 89H, Bank1                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1    | Bit0    |
|----------------------------------|------|------|------|------|------|------|---------|---------|
| SWTHL                            | -    | -    | -    | -    | -    | -    | T5HLCON | T3HLCON |
| R/W                              | -    | -    | -    | -    | -    | -    | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | 0       | 0       |

| Bit Number | Bit Mnemonic | Description                                                                                          |
|------------|--------------|------------------------------------------------------------------------------------------------------|
| 1          | T5HLCON      | 0: when read TH5, TL5, return T5 count data<br>1: when read TH5, TL5, return T5 reload register data |



### 7.9 Interrupt

### 7.9.1 Feature

- 12 interrupt sources
- 4 interrupt priority levels

The SH79F1616 provides total 12 interrupt sources: 3 external interrupts (INT2/3/4; INT4 including INT40-43, which share the same vector address), 4 timer interrupts (Timer2, 3, 4, 5), one EUART interrupt, ADC Interrupt, PWM interrupts, SCM interrupt and LPD interrupt.

### 7.9.2 Interrupt Enable Control

Each interrupt source can be individually enabled or disabled by setting or clearing the corresponding bit in the interrupt enable registers IEN0 or IEN1. The IEN0 register also contains global interrupt enable bit, EA, which can enable/disable all the interrupts at once. Generally, after reset, all interrupt enable bits are set to 0, which means that all the interrupts are disabled.

### 7.9.3 Register

Table 7.36 Primary Interrupt Enable Register

| A8H                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| IEN0                             | EA   | EADC | ET2  | ES0  | -    | EX1  | ET5  | EX0  |
| R/W                              | R/W  | R/W  | R/W  | R/W  | -    | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | -    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                         |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------|
| 7          | EA           | All interrupt enable bit<br>0: Disable all interrupt<br>1: Enable all interrupt                                     |
| 6          | EADC         | ADC interrupt enable bit<br>0: Disable ADC interrupt<br>1: Enable ADC interrupt                                     |
| 5          | ET2          | Timer2 overflow interrupt enable bit<br>0: Disable Timer2 overflow interrupt<br>1: Enable Timer2 overflow interrupt |
| 4          | ES0          | EUART interrupt enable bit<br>0: Disable EUART interrupt<br>1: Enable EUART interrupt                               |
| 2          | EX1          | This bit must Write 0                                                                                               |
| 1          | ET5          | Timer5 overflow interrupt enable bit<br>0: Disable Timer5 overflow interrupt<br>1: Enable Timer5 overflow interrupt |
| 0          | EX0          | This bit must Write 0                                                                                               |

Note: IEN0[0] and :IEN0[2] must write 0.



### Table 7.37 Secondary Interrupt Enable Register

| A9H                              | Bit7      | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|-----------|------|------|------|------|------|------|------|
| IEN1                             | ESCM/ELPD | ET4  | EPWM | ET3  | EX4  | EX3  | EX2  | -    |
| R/W                              | R/W       | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0         | 0    | 0    | 0    | 0    | 0    | 0    | -    |

| Bit Number | Bit Mnemonic | Description                                                                                                        |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------|
| 7          | ESCM/ELPD    | SCM/LPD interrupt enable bit<br>0: Disable SCM/LPD interrupt<br>1: Enable SCM/LPD interrupt                        |
| 6          | ET4          | Timer4 overflowinterrupt enable bit<br>0: Disable Timer4 overflow interrupt<br>1: Enable Timer4 overflow interrupt |
| 5          | EPWM         | <b>PWM interrupt enable bit</b><br>0: Disable PWM interrupt<br>1: Enable PWM interrupt                             |
| 4          | ET3          | Timer3 overflowinterrupt enable bit<br>0: Disable timer3 overflow interrupt<br>1: Enable timer3 overflow interrupt |
| 3          | EX4          | External interrupt4 enable bit<br>0: Disable external interrupt4<br>1: Enable external interrupt4                  |
| 2          | EX3          | External interrupt3 enable bit<br>0: Disable external interrupt3<br>1: Enable external interrupt3                  |
| 1          | EX2          | Enternal interrupt2 enable bit<br>0: Disable external interrupt2<br>1: Enable external interrupt2                  |

#### Note:

(1) To enable External interrupt2/3/4, the corresponding port must be set to input mode before using it.
(2) To enable PWM timer interrupt, the EPWM bit here should be set. Also, the PWMIE in PWM interrupt control register should be set.

Table 7.38 Interrupt channel Enable Register

| BAH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|------|------|------|------|-------|-------|-------|-------|
| IENC                             | -    | -    | -    | -    | EXS43 | EXS42 | EXS41 | EXS40 |
| R/W                              | -    | -    | -    | -    | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | 0     | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic       | Description                                                                                                             |
|------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 3-0        | EXS4x<br>(x = 3-0) | External interrupt4 channel select bit (x = 3-0)<br>0: Disable external interrupt 4x<br>1: Enable external interrupt 4x |



#### Table 7.39 Interrupt channel Enable Register1

| BBH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1  | Bit0 |
|----------------------------------|------|------|------|------|------|------|-------|------|
| IENC1                            | -    | -    | -    | -    | -    | -    | ESCM1 | ELPD |
| R/W                              | -    | -    | -    | -    | -    | -    | R/W   | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | 0     | 0    |

| Bit Number | Bit Mnemonic | Description                                                                     |
|------------|--------------|---------------------------------------------------------------------------------|
| 1          | ESCM1        | SCM interrupt enable bit<br>0: Disable SCM interrupt<br>1: Enable SCM interrupt |
| 0          | ELPD         | LPD interrupt enable bit<br>0: Disable LPD interrupt<br>1: Enable LPD interrupt |

### 7.9.4 Interrupt Flag

Each Interrupt source has its own interrupt flag, when interrupt occurs, corresponding flag will be set by hardware, the interrupt flag bits are listed in Table bellow.

For **external interrupt (INT2/3)**, when an external interrupt/2/3 is generated, if the interrupt was edge trigged, the flag (IE2-3) that generated this interrupt is cleared by hardware when the service routine is vectored. If the interrupt was level trigged, then the requesting external source directly controls the request flag, rather than the on-chip hardware.

When an **external interrupt4** is generated, the flag (IF4x (x = 0-3) in EXF1 register) that generated this interrupt should be cleared by user's program because the same vector entrance was used in INT4. But if INT4 is setup as level trigged, the flag can't be cleared by user's program, it only be controlled by peripheral signal level that connect to INT source pin.

The **Timer2 interrupt** is generated by the logical OR of flag TF2 and bit EXF2 in T2CON register, which is set by hardware. None of these flags can be cleared by hardware when the service routine is vectored. In fact, the service routine may have to determine whether it was TF2 or EXF2 that generated the interrupt, so the flag must be cleared by software.

The **Timer3 interrupt** is generated when they overflow, the flag TF3 in T3CON register, which is set by hardware, and will be automatically cleared by hardware when the service routine is vectored.

The **Timer4** interrupt is generated when they overflow, the flag TF4 in T4CON register, which is set by hardware, and will be automatically cleared by hardware when the service routine is vectored.

The **Timer5** interrupt is generated when they overflow, the flag TF5 in T4CON register, which is set by hardware, and will be automatically cleared by hardware when the service routine is vectored.

The **EUART interrupt** is generated by the logical OR of flag RI and TI in SCON register, which is set by hardware. Neither of these flags can be cleared by hardware when the service routine is vectored. In fact, the service routine will normally have to determine whether it was the receive interrupt flag or the transmission interrupt flag that generated the interrupt, so the flag must be cleared by software.

The **ADC interrupt** is generated by ADCIF bit in ADCON. If an interrupt is generated, the converted result in ADCDH/ADCDL will be valid. If continuous compare function in ADC module is Enable, ADCIF will not be set at each conversion, but set if converted result is larger than compare value. The flag must be cleared by software.

The **SCM interrupt** is generated by SCMIF in SCM register, which is set by hardware. And the flag can only be cleared by hardware.

The LPD interrupt is generated by LPDF in LPDCON register. And the flag can only be cleared by hardware.

The **PWM interrupts** are generated by PWM0IF in PWM0C. The flags can be cleared by software.



## Table 7.40 External Interrupt Flag Register

| E8H, Bank0                       | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1 | Bit0 |
|----------------------------------|-------|-------|-------|-------|-------|-------|------|------|
| EXF0                             | IT4.1 | IT4.0 | IT3.1 | IT3.0 | IT2.1 | IT2.0 | IE3  | IE2  |
| R/W                              | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                       |
|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-6        | IT4[1:0]     | External interrupt4 trigger mode selection bit<br>00: Low Level trigger<br>01: Trigger on falling edge<br>10: Trigger on rising edge<br>11: Trigger on both edge<br>IT4 [1:0] is effect on external interrupt 4x at the same mode |
| 5-4        | IT3[1:0]     | External interrupt3 trigger mode selection bit<br>00: Low Level trigger<br>01: Trigger on falling edge<br>10: Trigger on rising edge<br>11: Trigger on both edge                                                                  |
| 3-2        | IT2[1:0]     | External interrupt2 trigger mode selection bit<br>00: Low Level trigger<br>01: Trigger on falling edge<br>10: Trigger on rising edge<br>11: Trigger on both edge                                                                  |
| 1          | IE3          | External interrupt3 request flag bit<br>0: No interrupt pending<br>1: Interrupt is pending                                                                                                                                        |
| 0          | IE2          | External interrupt2 request flag bit<br>0: No interrupt pending<br>1: Interrupt is pending                                                                                                                                        |

Table 7.41 External Interrupt 4 Flag Register

| D8H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| EXF1                             | -    | -    | -    | -    | IF43 | IF42 | IF41 | IF40 |
| R/W                              | -    | -    | -    | -    | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic      | Description                                                                                                               |
|------------|-------------------|---------------------------------------------------------------------------------------------------------------------------|
| 3-0        | IF4x<br>(x = 3-0) | External interrupt4 request flag bit<br>0: No interrupt pending<br>1: Interrupt is pending<br>IF4x is cleared by software |



### 7.9.5 Interrupt Vector

When an interrupt occurs, the program counter is pushed onto the stack and the corresponding interrupt vector address is loaded into the program counter. The interrupt vector addresses are listed in **Interrupt Summary table**.

#### 7.9.6 Interrupt Priority

Each interrupt source can be individually programmed to one of four priority levels by setting or clearing corresponding bits in the interrupt priority control registers IPL0, IPH0, IPL1, and IPH1. The interrupt priority service is described below.

An interrupt service routine in progress can be interrupted by a higher priority interrupt, but can not by another interrupt with the same or lower priority.

The highest priority interrupt service cannot be interrupted by any other interrupt source. If two requests of different priority levels are received simultaneously, the request of higher priority level is serviced.

If requests of the same priority level are pending at the start of an instruction cycle, an internal polling sequence determines which request is serviced.

|        | Interrupt Priority |                            |  |  |  |  |  |
|--------|--------------------|----------------------------|--|--|--|--|--|
| Priori | ty bits            | Interrunt Lover Priority   |  |  |  |  |  |
| IPHx   | IPLx               | Interrupt Lever Priority   |  |  |  |  |  |
| 0      | 0                  | Level 0 (lowest priority)  |  |  |  |  |  |
| 0      | 1                  | Level 1                    |  |  |  |  |  |
| 1      | 0                  | Level 2                    |  |  |  |  |  |
| 1      | 1                  | Level 3 (highest priority) |  |  |  |  |  |

Table 7.42 Interrupt Priority Control Registers

| B8H, B4H                         |  | Bit7  | Bit6  | Bit5  | Bit4 | Bit3        | Bit2 | Bit1 | Bit0 |
|----------------------------------|--|-------|-------|-------|------|-------------|------|------|------|
| IPL0                             |  | -     | PADCL | PT2L  | PS0L | -           | -    | PT5L | -    |
| IPH0                             |  | -     | PADCH | PT2H  | PS0H | -           | -    | PT5H | -    |
| R/W                              |  | -     | R/W   | R/W   | R/W  | -           | -    | R/W  | -    |
| Reset Value<br>(POR/WDT/LVR      |  | -     | 0     | 0     | 0    | -           | -    | 0    | -    |
| B9H, B5H                         |  | Bit7  | Bit6  | Bit5  | Bit4 | Bit3        | Bit2 | Bit1 | Bit0 |
| IPL1                             |  | PSCML | PT4L  | PPWML | PT3L | PX4L        | PX3L | PX2L | -    |
| IPH1                             |  | PSCMH | PT4H  | PPWMH | PT3H | PX4H        | PX3H | PX2H | -    |
| R/W                              |  | R/W   | R/W   | R/W   | R/W  | R/W         | R/W  | R/W  | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) |  | 0     | 0     | 0     | 0    | 0           | 0    | 0    | -    |
| Bit Number Bit Mnemonic          |  |       |       |       |      | Description |      |      |      |

| 7-0 | PxxxL/H | Corresponding interrupt source xxx's priority level selection bits |
|-----|---------|--------------------------------------------------------------------|
|-----|---------|--------------------------------------------------------------------|



### 7.9.7 Interrupt Handling

The interrupt flags are sampled and polled at the fetch cycle of each machine cycle. All interrupts are sampled at the rising edge of the clock. If one of the flags was set, the CPU will find it and the interrupt system will generate a LCALL to the appropriate service routine, provided this hardware-generated LCALL is not blocked by any of the following conditions:

An interrupt of equal or higher priority is already in progress.

The current cycle is not in the final cycle of the instruction in progress. This ensures that the instruction in progress is completed before vectoring to any service routine.

The instruction in progress is RETI. This ensures that if the instruction in progress is RETI then at least one more instruction except RETI will be executed before any interrupt is vectored to; this delay guarantees that the CPU can observe the changes of the interrupt status.

#### Note:

Since priority change normally needs 2 instructions, it is recommended to disable corresponding Interrupt Enable flag to avoid interrupt between these 2 instructions during the change of priority.

If the flag is no longer active when the blocking condition is removed, the denied interrupt will not be serviced. Every polling cycle interrogates only the valid interrupt requests.

The polling cycle/LCALL sequence is illustrated below:



#### Interrupt Response Timing

The hardware-generated LCALL pushes the contents of the program counter onto the stack (but it does not save the PSW) and reloads the program counter with corresponding address that depends on the source of the interrupt being vectored too, as shown in Interrupt Summary table.

Interrupt service execution proceeds from that location until the RETI instruction is encountered. The RETI instruction informs the processor that the interrupt routine is no longer in progress, and then pops the top two bytes from the stack and reloads the program counter. Execution of the interrupted program continues from the point where it was stopped. Note that the RETI instruction is very important because it informs the processor that the program left the current interrupt service. A simple RET instruction would also have returned execution to the interrupted program, but it would have left the interrupt control system thinking an interrupt with this priority was still in progress. In this case, no interrupt of the same or lower priority level would be acknowledged.

#### 7.9.8 Interrupt Response Time

If an interrupt is recognized, its request flag is set in every machine cycle after recognize. The value will be polled by the circuitry until the next machine cycle; the CPU will generate an interrupt at the third machine cycle. If the request is active and conditions are right for it to be acknowledged, hardware LCALL to the requested service routine will be the next instruction to be executed. Else the interrupt will pending. The call itself takes 7 machine cycles. Thus a minimum of 3+7 complete machine cycles will elapse between activation and external interrupt request and the beginning of execution of the first instruction of the service routine.

A longer response time would be obtained if the request was blocked by one of the above three previously listed conditions. If an interrupt of equal or higher priority is already in progress, the additional wait time obviously depends on the nature of the other interrupt's service routine.

If the instruction in progress is not in its final cycle and the instruction in progress is RETI, the additional wait time is 8 machine cycles. For a single interrupt system, if the next instruction is 20 machine cycles long (the longest instructions DIV & MUL are 20 machine cycles long for 16 bit operation), adding the LCALL instruction 7 machine cycles the total response time is 2+8+20+7 machine cycles.

Thus interrupt response time is always more than 10 machine cycles and less than 37 machine cycles.



### 7.9.9 External Interrupt Inputs

The SH79F1616 has 3 external interrupt inputs. External interrupt 2-3 each has one vector address. External interrupt 4 has 4 inputs; all of them share one vector address. In this mode, a cycle INTx (x = 2, 3) pin continuous sampling is high while the next cycle is low, the interrupt request flag, an interrupt request. Since the external interrupt pin every machine cycle sampling time, input high or low should be kept for at least one machine cycle to ensure proper sampling.

If the external interrupt triggered low external interrupt source must hold the request active until the requested interrupt far, this process requires two system clock cycles. If the interrupt service is completed, the external interrupt still maintain, an interrupt will be generated. Should not be removed when the interrupt is level-triggered interrupt flag IEx (x = 2, 3), interrupted only related to the level of the input port.

When SH79F1616 entering idle or power-down mode, the interrupt will wake up the processor to continue to work, see the Power Management chapter.

**Note:** External interrupt 2-3 in the execution of an interrupt service routine interrupt flag is automatically cleared by hardware, but the external interrupt flag IF40-43 must be cleared by software.



#### 7.9.10 Interrupt Summary

| Source  | Vector<br>Address | Enable bits     | Flag bits  | Polling Priority | Interrupt number<br>(c language) |
|---------|-------------------|-----------------|------------|------------------|----------------------------------|
| Reset   | 0000H             | -               | -          | 0 (highest)      | -                                |
| Timer5  | 000BH             | ET5             | TF5        | 1                | 1                                |
| EUART   | 0023H             | ES              | RI+TI      | 2                | 4                                |
| Timer2  | 002BH             | ET2             | TF2        | 3                | 5                                |
| ADC     | 0033H             | EADC            | ADCIF      | 4                | 6                                |
| INT2    | 0043H             | EX2             | IE2        | 5                | 8                                |
| INT3    | 004BH             | EX3             | IE3        | 6                | 9                                |
| INT4    | 0053H             | EX4+IENC        | IF43-40    | 7                | 10                               |
| Timer3  | 005BH             | ET3             | TF3        | 8                | 11                               |
| PWM     | 0063H             | EPWM            | PWMIF      | 9                | 12                               |
| Timer4  | 006BH             | ET4             | TF4        | 10               | 13                               |
| SCM/LPD | 0073H             | ESCM+ESCM1/ELPD | SCMIF/LPDF | 11 (lowest)      | 14                               |





### 8. Enhanced Function

### 8.1 Normal Resistor LCD Driver

The LCD driver contains a controller, a duty cycle generator with 4/8 Common signal pins and 10 Segment driver pins. Segment 1-5, 9-10, 14-15, 19 and COM1-COM4 can also be used as I/O port, it is controlled by the POSS, P1SS & P3SS register.

The 28 bytes display data RAM is addressed to 1E0H-1F2H, which could be used as data memory if needed. LCD COM1-8 can also be used as LED.

The MCU consists normal display topologies with contrast adjustment which supports both 1/4 duty-1/3 bias and 1/8 duty-1/4 bias driving mode, DISPEDL (DISPCON.7) must be cleared before LCD working. When ELCC in DISPCON is set, The LCD supply power  $V_{LCD}$  is selected by VOL[3:0]. When ELCC is cleared,  $V_{LCD}$  equals to  $V_{DD}$ .

During the Power on Reset or Pin Reset or LVR Reset or Watch-dog Reset, the LCD will be turned off, and Common and Segment will output low.

The features of the LCD Normal Display Mode include the following:

- LCD clock is decided by code option OP\_OSC.
- When OP\_OSC[3:0] is 0000, LCD clock source is internal RC (12MHz), LCD clock = Internal RC (12MHz)/DISPCLK, LCD frame = LCD clock/512.
- When OP\_OSC[3:0] is 1110, LCD clock source is crystal or ceramic, LCD clock = crystal or ceramic frenquncy/DISPCLK.
- 1/4 duty-1/3 bias or 1/8 duty-1/4 bias by configuring the DUTY bit in DISPCON register.
- LCD frame = LCD clock/512.
- 16 levels contrast adjustment by configuring the VOL[3:0] bits in DISPCON register.
- LCD bias resistor (R<sub>LCD</sub>) can be selected as 20K/75K/300K in 1/3 bias mode, 15K/56K/225K in 1/4 bias mode,the sum of bias resistor are 60K/225K/900K.

The traditional resistance type LCD can be selected by the MOD[1:0] bits in DISPCON1 register. It also can select Fast Charge Mode to reduce power consumption.

The relatively high current drain through the 20k resistor will get better LCD display effect, but it may not be suitable for some low current consume application. Lowering this current is possible by configuring the OP\_RLCD[2:0] for switching the  $R_{LCD}$  value to 75/300K.

Therefore, SH79F1616 provides both the low power consumption and display effect of the display mode:fast charge mode. Set MOD[1:0] = 10 to select this mode. When refresh the display data 20k bias resistors are selected to provide larger current. When keep the display data 75/300K bias resistors are selected to save drive current. Charging time is selected as1/8, 1/16, 1/32 or 1/64 of LCD com period by FCCTL[1:0] in DISPCON1 register.







LCD Waveform (1/4 duty, 1/3 bias)





LCD Waveform (1/8 duty, 1/4 bias)



## 8.1.1 Registers

Table 8.1 LCD Control Register

| ABH, Bank                   | 0     | Bit7                                                                   | Bit6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit5                                         | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|-----------------------------|-------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------|------|------|------|------|
| DISPCON                     |       | DISPSEL                                                                | LCDON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ELCC                                         | DUTY | VOL3 | VOL2 | VOL1 | VOL0 |
| R/W                         |       | R/W                                                                    | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/W                                          | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR | -     | 0                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0                                            | 0    | 0    | 0    | 0    | 0    |
| Bit Number                  | Bit N | Inemonic                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Description                                  |      |      |      |      |      |
| 7                           | DI    | SPSEL                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ontrol bit<br>LCD driver<br>LED drive        |      |      |      |      |      |
| 6                           | L     | LCD on/off control bit<br>0: Disable LCD driver<br>1: Enable LCD drive |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                              |      |      |      |      |      |
| 5                           | E     | ELCC                                                                   | LCD contrast on/off control bit<br>0:disable contrast<br>1:enable contrast                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                              |      |      |      |      |      |
| 4                           | ſ     | DUTY                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | election bit<br>ty, 1/3 bias<br>ty, 1/4 bias |      |      |      |      |      |
| 3-0                         | Vo    | DL[3:0]                                                                | LCD contrast control bits<br>$0000: V_{LCD} = 0.531V_{DD}$<br>$0001: V_{LCD} = 0.563 V_{DD}$<br>$0010: V_{LCD} = 0.594 V_{DD}$<br>$0011: V_{LCD} = 0.625 V_{DD}$<br>$0100: V_{LCD} = 0.656 V_{DD}$<br>$0101: V_{LCD} = 0.688 V_{DD}$<br>$0110: V_{LCD} = 0.719 V_{DD}$<br>$0111: V_{LCD} = 0.750 V_{DD}$<br>$1000: V_{LCD} = 0.781 V_{DD}$<br>$1001: V_{LCD} = 0.813 V_{DD}$<br>$1010: V_{LCD} = 0.844 V_{DD}$<br>$1011: V_{LCD} = 0.875 V_{DD}$<br>$1100: V_{LCD} = 0.906 V_{DD}$<br>$1101: V_{LCD} = 0.938V_{DD}$<br>$1111/1110: V_{LCD} = 1.000 V_{DD}$ |                                              |      |      |      |      |      |

### Note:

SH79F1616 has LCD and LED driver, but can not work in the same time. When DISPSEL = 1, LCD is disable, DISPSEL = 0, LED is disable.



### Table 8.2 LCD Control Register1

| ADH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2   | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|--------|--------|------|------|
| DISPCON1                         | -    | -    | -    | RLCD | FCCTL1 | FCCTL2 | MOD1 | MOD0 |
| R/W                              | -    | -    | -    | R/W  | R/W    | R/W    | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | 0    | 0      | 0      | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                      |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0        | MOD[1:0]     | LCD Drive mode control bit<br>00: traditional mode, bias resistor sum is 225K/900K<br>01: traditional mode, bias resistor sum is 60K<br>10: fast charge mode, bias resistor sum switch between 60K and 225K/900K |
| 3-2        | FCCTL[1:0]   | Fast charge time control bit<br>00: 1/8 LCD com period<br>01: 1/16 LCD com period<br>10: 1/32 LCD com period<br>11: 1/64 LCD com period                                                                          |
| 4          | RLCD         | LCD bias resistor control bit<br>0: LCD bias resistor sum is 225K<br>1: LCD bias resistor sum is 900K                                                                                                            |

### Table 8.3 LCD CONTRAST Register

| ACH, Bank0                       | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|----------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| DISPCLK0                         | DCK0.7 | DCK0.6 | DCK0.5 | DCK0.4 | DCK0.3 | DCK0.2 | DCK0.1 | DCK0.0 |
| R/W                              | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| AAH, Bank0                       | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
| DISPCLK0                         | -      | -      | -      | -      | -      | -      | -      | DCK1.0 |
| R/W                              | -      | -      | -      | -      | -      | -      | -      | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | -      | -      | -      | -      | -      | -      | -      | 0      |

| Bit Number | Bit Mnemonic        | Description                                                                                                                  |
|------------|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0<br>7-0   | DCK1.0<br>DCK0[7:0] | LCD clock select<br>0x000: LCD clock = oscillator frequency<br>Others: LCD clock = internal RC or crystal or ceramic/DISPCLK |

### Note:

Only when OP\_OSC[3:0] is 0000, 1110, DISPCLK register is available. When [DISPCLK 1, DISPCLK 0] = 0X000, LCD clock = OSCCLK. LCD frame = LCD clock/512.

#### For example:

When LCD is COM4,  $OP_OSC[3:0] = 1110$ , oscillator is 12MHz to get 64HZ LCD frame, DISPCLK = 12M/512/64 = 0x16E, LCD frame = 12M/366/512 = 64.04Hz in fact.

When LCD is COM4, OP\_OSC[3:0] = 1110, oscillator is 2MHz to get 64HZ LCD frame, DISPCLK = 2M/512/64 = 0x03D, LCD frame = 2M/61/512 = 64.04Hz in fact.



### Table 8.4 P0 mode Select Register

| B6H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| POSS                             | -    | -    | -    | -    | -    | P0S2 | -    | -    |
| R/W                              | -    | -    | -    | -    | -    | R/W  | -    | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | 0    | -    | -    |

| Bit Number | Bit Mnemonic | Description                                               |
|------------|--------------|-----------------------------------------------------------|
| 2-0        | P0S2         | P0 mode select<br>0: P0.2 is I/O<br>1: P0.2 is Segment 19 |

Table 8.5 P1 mode Select Register

| 9CH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| P1SS                             | -    | -    | -    | P1S4 | P1S3 | P1S2 | P1S1 | P1S0 |
| R/W                              | -    | -    | -    | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | 0    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                   |
|------------|--------------|-------------------------------------------------------------------------------|
| 4-0        | P1S[4:0]     | P1 mode select<br>0: P1.0-P1.4 is I/O<br>1: P1.0-P1.4 is Segment (Segment1-5) |

## Table 8.6 P2 mode Select Register

| 9DH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| P2SS                             | -    | P2S6 | P2S5 | -    | -    | -    | P2S1 | P2S0 |
| R/W                              | -    | R/W  | R/W  | -    | -    | -    | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | 0    | 0    | -    | -    | -    | 0    | 0    |

| Bit Number | Bit Mnemonic         | Description                                                                                                          |
|------------|----------------------|----------------------------------------------------------------------------------------------------------------------|
| 6-5<br>1-0 | P2S[6:5]<br>P2S[1:0] | P2 mode select bit<br>0: P2.0-P2.1, P2.5-P2.6 is I/O<br>1: P2.0-P2.1, P2.5-P2.6 share as Segment (SEG9-10, SEG14-15) |

Table 8.7 P3 mode Select Register

| 9EH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| P3SS                             | P3S7 | P3S6 | P3S5 | P3S4 | P3S3 | P3S2 | P3S1 | P3S0 |
| R/W                              | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                  |  |  |  |  |
|------------|--------------|----------------------------------------------------------------------------------------------|--|--|--|--|
| 7-0        | P3S[7:0]     | <b>P3 mode select bit</b><br>0: P3.0-P3.7 is I/O<br>1: P3.0-P3.7 share as Common (COM1-COM8) |  |  |  |  |

**Note:** Unused bits PxSS (x = 0, 1, 2, 3) must write 0.



## 8.1.2 Configuration of LCD RAM

LCD 1/4 duty, 1/3 bias (COM1 - 4, SEG1 - 5, SEG9 - 10, SEG14 - 15, SEG19)

| A d dra e e | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|-------------|---|---|---|---|-------|-------|-------|-------|
| Address     | - | - | - | - | COM4  | COM3  | COM2  | COM1  |
| 1E0H        | - | - | - | - | SEG1  | SEG1  | SEG1  | SEG1  |
| 1E1H        | - | - | - | - | SEG2  | SEG2  | SEG2  | SEG2  |
| 1E2H        | - | - | - | - | SEG3  | SEG3  | SEG3  | SEG3  |
| 1E3H        | - | - | - | - | SEG4  | SEG4  | SEG4  | SEG4  |
| 1E4H        | - | - | - | - | SEG5  | SEG5  | SEG5  | SEG5  |
| 1E8H        | - | - | - | - | SEG9  | SEG9  | SEG9  | SEG9  |
| 1E9H        | - | - | - | - | SEG10 | SEG10 | SEG10 | SEG10 |
| 1EDH        | - | - | - | - | SEG14 | SEG14 | SEG14 | SEG14 |
| 1EEH        | - | - | - | - | SEG15 | SEG15 | SEG15 | SEG15 |
| 1F2H        | - | - | - | - | SEG19 | SEG19 | SEG19 | SEG19 |

### LCD 1/8 duty, 1/4 bias (COM1 - 8, SEG1 - 5, SEG9 - 10, SEG14 - 15, SEG19)

| Address | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address | COM8  | COM7  | COM6  | COM5  | COM4  | COM3  | COM2  | COM1  |
| 1E0H    | SEG1  |
| 1E1H    | SEG2  |
| 1E2H    | SEG3  |
| 1E3H    | SEG4  |
| 1E4H    | SEG5  |
| 1E8H    | SEG9  |
| 1E9H    | SEG10 |
| 1EDH    | SEG14 |
| 1EEH    | SEG15 |
| 1F2H    | SEG19 |



### 8.2 LED Driver

The LED driver contains a controller, a duty cycle generator with 4/8 Common signal pins and 5 Segment driver pins. Segment 1-5 can also be used as I/O port. When DISPSEL bit is set, LED function is enable, and LCD is disable. It is controlled by the POSS, P1SS register.

When MCU enters the Power-Down mode, the LED will be turned off, If 32.768kHz crystal or 128k internal RC works in Power-down mode, the LED is still working. When OP\_LEDCOM = 0 Common and Segment will output low. When OP\_LEDCOM = 1 Common and Segment will output high.

### 8.2.1 Register

Table8.8 LED Control Register

| ABH, Bank0                       | Bit7    | Bit6  | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|---------|-------|------|------|------|------|------|------|
| DISPCON                          | DISPSEL | LEDON | -    | DUTY | -    | -    | -    | -    |
| R/W                              | R/W     | R/W   | -    | R/W  | -    | -    | -    | -    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0       | 0     | -    | 0    | -    | -    | -    | -    |

| Bit Number | Bit Mnemonic | Description                                                            |
|------------|--------------|------------------------------------------------------------------------|
| 7          | DISPSEL      | LCD/LED control bit<br>0: select LCD driver<br>1: select LCD drive     |
| 6          | LEDON        | LED on/off control bit<br>0: Disable LED driver<br>1: Enable LED drive |
| 4          | DUTY         | LED duty selection bit<br>0: 1/4 duty<br>1: 1/8 duty                   |

Note:

SH79F1616 has LCD and LED driver, but can not work in the same time. When DISPSEL = 1, LCD is disable, DISPSEL = 0, LED is disable.

| ACH, Bank0                       | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|----------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| DISPCLK0                         | DCK0.7 | DCK0.6 | DCK0.5 | DCK0.4 | DCK0.3 | DCK0.2 | DCK0.1 | DCK0.0 |
| R/W                              | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| AAH, Bank0                       | Bit7   | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
| DISPCLK1                         | -      | -      | -      | -      | -      | -      | -      | DCK1.0 |
| R/W                              | -      | -      | -      | -      | -      | -      | -      | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | -      | -      | -      | -      | -      | -      | -      | 0      |

| Bit Number | Bit Mnemonic        | Description                                                                 |
|------------|---------------------|-----------------------------------------------------------------------------|
| 0<br>7-0   | DCK1.0<br>DCK0[7:0] | LED clock select<br>0x000: LED clock = OSCCLK<br>Others: LED clock /DISPCLK |

Note:

Only when OP\_OSC[2:0] is 000, 101 and 110, DISPCLK register is available.



### Table 8.10 P1 mode select register

| 9CH, Bank0                       | Bit7     | Bit6 | Bit5 | Bit4 | Bit3        | Bit2 | Bit1 | Bit0 |
|----------------------------------|----------|------|------|------|-------------|------|------|------|
| P1SS                             | -        | -    | -    | P1S4 | P1S3        | P1S2 | P1S1 | P1S0 |
| R/W                              | -        | -    | -    | R/W  | R/W         | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -        | -    | -    | 0    | 0           | 0    | 0    | 0    |
| Dit Number Dit I                 | Inomonio |      |      |      | Description |      |      |      |

| Bit Number | Bit Mnemonic | Description                                                                                    |
|------------|--------------|------------------------------------------------------------------------------------------------|
| 4-0        | P1S[4:0]     | P1 mode select (x = 0-4)<br>0: P1.0-P1.4 are I/O<br>1: P1.0-P1.4 are Segment (LED_S1 - LED_S5) |

Table 8.11 P3 mode Select Register

| 9EH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| P3SS                             | P3S7 | P3S6 | P3S5 | P3S4 | P3S3 | P3S2 | P3S1 | P3S0 |
| R/W                              | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                |  |  |  |  |  |
|------------|--------------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7-0        | P3S[7:0]     | P3 mode select (x = 0-7)<br>0: P3.0-P3.7 are I/O<br>1: P3.0-P3.7 are COM (LED_C1 - LED_C8) |  |  |  |  |  |

**Note:** Unused bits PxSS (x = 0, 1, 2, 3) must write 0.

### 8.2.2 Configuration of LED RAM

LED 1/4 duty (LED\_C1 - 4, LED\_S1 - 5)

| Add  | ress | 7 | 6 | 5 | 4    | 3    | 2    | 1    | 0    |
|------|------|---|---|---|------|------|------|------|------|
| 1E0H | COM1 | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E1H | COM2 | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E2H | COM3 | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E3H | COM4 | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |

### LED 1/8 duty (LED\_C1 - 8, LED\_S1 - 5)

| Add  | lress | 7 | 6 | 5 | 4    | 3    | 2    | 1    | 0    |
|------|-------|---|---|---|------|------|------|------|------|
| 1E0H | COM1  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E1H | COM2  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E2H | COM3  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E3H | COM4  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E4H | COM5  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E5H | COM6  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E6H | COM7  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |
| 1E7H | COM8  | - | - | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 |



# LED WAVE







### (2) OP\_LEDCOM[1] = 1



**Note:**  $t_{OL}$  is overlap time of LED Common,  $t_{OL} = 20\mu s \cdot 40\mu s$ .



### 8.3 PWM (Pulse Width Modulation)

#### 8.3.1 Feature

- 2 dead-band control complementary output
- Provided interrupt function on period
- Selectable output polarity
- Fault Detect function provided to disable PWM output immediately
- Lock register provided to avoid PWM control register to be unexpected change

The SH79F1616 has one 12-bit PWM module. Which can provide the pulse width modulation waveform with the period and the duty being controlled individually by corresponding register.

PWM timer can be turned to inactive state by the input of FLT pin automatically if EFLT is set.

PWM timer also provides 1 interrupts for PWM0. This makes it possible to change period or duty in every PWM period. They have different control and flag bits, share one interrupt vector address. This allows the user to change the next cycle of each PWM cycle period or duty.

### 8.3.2 PWM Module Enable

### Table 8.12 PWM Module Enable Register

| CFH                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2 | Bit1 | Bit0  |
|----------------------------------|------|------|------|------|--------|------|------|-------|
| PWMEN                            | -    | EFLT | -    | -    | EPWM01 | -    | -    | EPWM0 |
| R/W                              | -    | R/W  | -    | -    | R/W    | -    | -    | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | 0    | -    | -    | 0      | -    | -    | 0     |

| Bit Number | Bit Mnemonic | Description                                                                                           |
|------------|--------------|-------------------------------------------------------------------------------------------------------|
| 6          | EFLT         | FLT pin configuration:<br>0: general purpose I/O or SS pin (default)<br>1: PWM Fault Detect input pin |
| 3          | EPWM01       | PWM01 output enable<br>0: I/O port<br>1: PWM output                                                   |
| 0          | EPWM0        | Enable 12-bit PWM0<br>0: I/O port<br>1: PWM output                                                    |

PWM output will be disable at the same time when the PWM Enable register is clear to 0.

The main purpose of the FLT pin is to inactivate the PWM output signals and drive them into an inactive state. The action of the FLT is performed directly in hardware so that when a fault occurs, it can be managed quickly and the PWMs outputs are put into an inactive state to save the power devices connected to the PWMs. The FLT pin has no internal pull-high resistor. If EFLT is set to 0, it means the level on FLT pin has no effect on PWM timers.

#### Table 8.13 PWM Module Enable Register

| B7H                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| PWMEN1                           | -    | -    | -    | -    | -    | -    | -    | PWM0 |
| R/W                              | -    | -    | -    | -    | -    | -    | -    | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | -    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                    |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | PWM0         | Enable 12-bit PWM0<br>0: PWM output enable<br>1: PWM output disable, PWM0. PWM01 as I/O, but PWM timer can work normally,<br>Trigger interrupt |



### 8.3.3 PWM Timer Lock Register

This register is used to control the change of PWM timer enable register, PWM control register, PWM period register, PWM duty register and PWM dead time control register. Only when the data in this register is #55h, it is possible to change these register. Otherwise they cannot be changed.

This register is to enhance the anti-noise ability of SH79F1616.

### Table 8.14 PWM Timer Lock Register

| E7H                              | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|----------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| PWMLO                            | PWMLO.7 | PWMLO.6 | PWMLO.5 | PWMLO.4 | PWMLO.3 | PWMLO.2 | PWMLO.1 | PWMLO.0 |
| R/W                              | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |
| Dit Number Dit Massacria         |         |         |         |         |         |         |         |         |

| Bit Number | Bit Mnemonic | Description                                                                                                              |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------|
| 7-0        | PWMLO[7:0]   | <b>PWM lock register</b><br>55h: enable to change PWM related registers<br>else: disable to change PWM related registers |





### 8.3.4 12-bit PWM Timer

The SH79F1616 has one 12-bit PWM module. The PWM module can provide the pulse width modulation waveform with the period and the duty being controlled, individually. The PWMC is used to control the PWM module operation with proper clocks. The PWMP is used to control the period cycle of the PWM module output. PWMD is used to control the duty in the waveform of the PWM module output.

It is acceptable to change these 3 registers during PWM output Enable. All the change will take affect at the next PWM period. **Table 8.15** 12-bit PWM Control Register

| D2H                              | Bit7          | Bit6          | Bit5 | Bit4 | Bit3 | Bit2  | Bit1   | Bit0   |
|----------------------------------|---------------|---------------|------|------|------|-------|--------|--------|
| PWM0C                            | <b>PWM0IE</b> | <b>PWM0IF</b> | -    | FLTS | FLTC | PWM0S | TnCK01 | TnCK00 |
| R/W                              | R/W           | R/W           | -    | R/W  | R/W  | R/W   | R/W    | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0             | 0             | -    | 0    | 0    | 0     | 0      | 0      |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | PWM0IE       | PWM0 interrupt enable bit (When EPWM bit in IEN1 is set)<br>0: Disable PWM0 interrupt<br>1: Enable PWM0 interrupt                                                                                                                                          |
| 6          | PWM0IF       | <b>PWM0 interrupt flag</b><br>0: Clear by software<br>1: Set by hardware to indicate that the PWM0 period counter overflow                                                                                                                                 |
| 4          | FLTS         | FLT status bit<br>0: PWM is in normal status, cleared by software<br>1: PWM is in inactive status, set automatically by hardware                                                                                                                           |
| 3          | FLTC         | FLT pin configuration<br>0: Inactivate the PWM output when FLT is low level<br>1: Inactivate the PWM output when FLT is high level                                                                                                                         |
| 2          | PWM0S        | <ul> <li>PWM0 output normal mode of duty cycle</li> <li>0: high active, PWM0 output high during duty time, output low during remain period time</li> <li>1: low active, PWM0 output low during duty time, output high during remain period time</li> </ul> |
| 1-0        | TnCK0[1:0]   | 12-bit PWM clock selector:<br>00: Oscillator clock/2<br>01: Oscillator/4<br>10: Oscillator/8<br>11: Oscillator/16                                                                                                                                          |

Note:

(1) Inactivate PWM here means PWM0 and PWM01 outputs keep Low (if PWM0S = 0) or High (if PWM0S = 1).

(2) The PWM outputs will remain in the inactive states as soon as the high/low level of FLT pin is detected.

(3) Clearing FLTS bit when a FAULT input is coming will not success.



7-0

| D3H                            | Bit7       | Bit6  | Bit5  | Bit4     | Bit3  | Bit2  | Bit1  | Bit0  |
|--------------------------------|------------|-------|-------|----------|-------|-------|-------|-------|
| PWM0PL                         | PP0.7      | PP0.6 | PP0.5 | PP0.4    | PP0.3 | PP0.2 | PP0.1 | PP0.0 |
| R/W                            | R/W        | R/W   | R/W   | R/W      | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PI | <b>)</b> 0 | 0     | 0     | 0        | 0     | 0     | 0     | 0     |
| Bit Number B                   |            |       |       | Descript | ion   |       |       |       |

12-bit PWM period low 8 nibble registers

#### Table 8.16 PWM Period Control Register (PWM0PL)

 Table 8.17 PWM Period Control Register (PWM0PH)

PP0[7:0]

| D4H                              | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2   | Bit1  | Bit0  |
|----------------------------------|------|------|------|------|--------|--------|-------|-------|
| <b>PWM0PH</b>                    | -    | -    | -    | -    | PP0.11 | PP0.10 | PP0.9 | PP0.8 |
| R/W                              | -    | -    | -    | -    | R/W    | R/W    | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | 0      | 0      | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                               |
|------------|--------------|-------------------------------------------|
| 3-0        | PP0[11:8]    | 12-bit PWM period high 4 nibble registers |

PWM output period cycle = [PP0.11, PP0.0] X PWM clock.

When [PP0.11, PP0.0] = 000H, If PWM0S = 0, regardless of the PWM duty cycle, PWM0 output low.

When [PP0.11, PP0.0] = 000H, If PWM0S = 1, regardless of the PWM duty cycle, PWM0 output high.

 Table 8.18 PWM Duty Control Register (PWM0DL)

| D5H                              | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| PWM0DL                           | PD0.7 | PD0.6 | PD0.5 | PD0.4 | PD0.3 | PD0.2 | PD0.1 | PD0.0 |
| R/W                              | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                            |
|------------|--------------|----------------------------------------|
| 7-0        | PD0[7:0]     | 12-bit PWM duty low 8 nibble registers |

Table 8.19 PWM Duty Control Register (PWM0DH)

| D6H                                 | Bit7 | Bit6 | Bit5 | Bit4 | Bit3   | Bit2   | Bit1  | Bit0  |
|-------------------------------------|------|------|------|------|--------|--------|-------|-------|
| PWM0DH                              | -    | -    | -    | -    | PD0.11 | PD0.10 | PD0.9 | PD0.8 |
| R/W                                 | -    | -    | -    | -    | R/W    | R/W    | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PII     | J) - | -    | -    | -    | 0      | 0      | 0     | 0     |
| Bit Number Bit Mnemonic Description |      |      |      |      |        |        |       |       |

| 3-0 | D0[11:8] | 12-bit PWM duty high 4 nibble registers |
|-----|----------|-----------------------------------------|
|-----|----------|-----------------------------------------|

PWM output duty cycle = [PD0.11, PD0.0] X PWM clock.

If [PP0.11, PP0.0] ≤ [PD0.11, PD0.0], PWM0 outputs high level when the PWM0S bit is set to "0".

If [PP0.11, PP0.0] ≤ [PD0.11, PD0.0], PWM0 outputs GND level when the PWM0S bit is set to "1".



### Programming Note:

- (1) Set PWMLO register to 55H and select the PWM module system clock.
- (2) Set the PWM period/duty cycle by writing proper value to the PWM period control register (PWMP) or PWM duty control register (PWMD). First set the low Byte, then the high Byte.
- (3) Select the PWM output mode of the duty cycle by writing the PWMOS bit in the PWM control register (PWMC).
- (4) In order to output the desired PWM waveform, enable the PWM module by writing "1" to the EPWM bit in the PWM control register (PWMC).
- (5) If the PWM period cycle or duty cycle is to be changed, the writing flow should be followed as described in step b or step c. Then the revised data are loaded into the re-load counter and the PWM module starts counting at next period.
- (6) Change the data in PWMLO register not equal to 55h in order to enhance the anti-noise ability.



PWM output Period or Duty cycle changing example

#### 8.3.5 PWM01

As shown, in general, when no dead time insertion the PWM01 output waveform PWM0 output waveform complementary. When the PWM control register EPWM01 position PWM01 the output waveform hardware is automatically generated.



### PWM0 and PWM01 pin output waveform

#### Note:

(1) That even if PWM0 are not enabled, PWM01 can also work if enabled.

(2) If EFLT is set, When a valid event occurs on FLT pin, PWM01 and PWM0 are both LOW (PWMS = 0)or both HIGH (PWMS = 1).



### 8.3.6 Dead Time

The SH79F1616 provides dead time control function on-chip. When PWMOS = 0, the dead time is generated as below.



When PWM0S = 1, the dead time is generated as below.



By writing PWM01 dead time control registers, a dead time can be generated between PWM0 and PWM01. PWM01 have the same period as PWM0.

#### Note:

- (1) Dead time0 must be set before PWM outputs enabled. Otherwise, dead time will not change. So in order to change dead time, please disable PWM outputs first (while PWMLO is #55h), then change the dead time, enable PWM. Finally, change the data in PWMLO not equal to #55h in order to make sure the PWM registers would not be changed by noise.
- (2) In order to generate dead time, please make sure that (PWM0 Period PWM0 Duty) > 2\* PWM01 dead time control. Otherwise the output of PWM01 is high level when PWMS = 1 or GND when PWMS = 0.
- (3) PWMDT is to used to control Dead Time, the step value is fixed oscillator clock time, but period and duty step value is refer to TnCK0[1:0]. 2 oscillator clocks at least.
- (4) If dead time is needed, any time when PWM is disabled, before enable PWM again, dead time register must be clear to 0 at first, and then set to proper value.

| D1H                              | Bit7  | Bit6  | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| PWM0DT                           | DT0.7 | DT0.6 | DT0.5 | DT0.4 | DT0.3 | DT0.2 | DT0.1 | DT0.0 |
| R/W                              | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Table 8.20 PWM0 Dead Time Control Register

| Bit Number          | Bit Mnemonic | Description                                                                                     |
|---------------------|--------------|-------------------------------------------------------------------------------------------------|
| <b>7-0</b> DT0(7:0) |              | <b>12-bit PWM0 dead time control</b><br>the dead time period = (DT0.7-DT0.0) X t <sub>OSC</sub> |





### 8.4 EUART

### 8.4.1 Feature

- The SH79F1616 has one enhanced EUART which are compatible with the conventional 8051
- The baud rate can be selected from the divided clock of the system clock, or Timer4/2 overflow rate
- Enhancements over the standard 8051 the EUART include Framing Error detection and automatic address recognition
- The EUART can be operated in four modes

#### 8.4.2 EUART Mode Description

The EUART can be operated in 4 modes. Users must initialize the SCON before any communication can take place. This involves selection of the Mode and the baud rate. The Timer4/2 should also be initialized if the mode 1 or the mode 3 is used. In all of the 4 modes, transmission is initiated by any instruction that uses SBUF as a destination register. Reception is initiated in Mode 0 by the condition RI = 0 and REN = 1. This will generate a clock on the TxD pin and shift in 8 bits on the RxD pin. Reception is initiated in the other modes by the incoming start bit if RI = 0 and REN = 1. The external transmitter will start the communication by transmitting the start bit.

### EUART Mode Summary

| SM0 | SM1 | Mode | Туре   | Baud Clock                            | Frame Size | Start Bit | Stop Bit | 9 <sup>th</sup> bit |
|-----|-----|------|--------|---------------------------------------|------------|-----------|----------|---------------------|
| 0   | 0   | 0    | Synch  | f <sub>SYS</sub> /(4 or 12)           | 8 bits     | NO        | NO       | None                |
| 0   | 1   | 1    | Asynch | Timer 4 or 2 overflow rate/(16 or 32) | 10 bits    | 1         | 1        | None                |
| 1   | 0   | 2    | Asynch | f <sub>SYS</sub> /(32 or 64)          | 11 bits    | 1         | 1        | 0, 1                |
| 1   | 1   | 3    | Asynch | Timer 4 or 2 overflow rate/(16 or 32) | 11 bits    | 1         | 1        | 0, 1                |

### Mode0: Synchronous Mode, Half duplex

This mode provides synchronous communication with external devices. In this mode serial data is transmitted and received on the RxD line. TxD is used to output the shift clock. The TxD clock is provided by the SH79F1616 whether the device is transmitting or receiving. This mode is therefore a half duplex mode of serial communication. In this mode, 8 bits are transmitted or received per frame. The LSB is transmitted/received first.

The baud rate is programmable to either 1/12 or 1/4 of the system clock. This baud rate is determined in the SM2 bit (SCON.5). When this bit is set to 0, the serial port runs at 1/12 of the system clock. When set to 1, the serial port runs at 1/4 of the system clock.

The functional block diagram is shown below. Data enters and exits the serial port on the RxD line. The TxD line is used to output the SHIFT CLOCK. The SHIFT CLOCK is used to shift data into and out of the SH79F1616.





Any instruction that uses SBUF as a destination register ("write to SBUF" signal) will start the transmission. The next system clock tells the Tx control block to commence a transmission. The data shift occurs at the falling edge of the SHIFT CLOCK, and the contents of the transmit shift register is shifted one position to the right. As data bits shift to the right, zeros come in from the left. After transmission of all 8 bits in the transmit shift register, the Tx control block will deactivates SEND and sets TI (SCON.1) at the rising edge of the next system clock.



Send Timing of Mode 0

Reception is initiated by the condition REN (SCON.4) = 1 and RI (SCON.0) = 0. The next system clock activates RECEIVE. The data latch occurs at the rising edge of the SHIFT CLOCK, and the contents of the receive shift register are shifted one position to the left. After the receiving of all 8 bits into the receive shift register, the RX control block will deactivates RECEIVE and sets RI at the rising edge of the next system clock, and the reception will not be enabled till the RI is cleared by software.



**Receive Timing of Mode 0** 

#### Mode1: 8-Bit EUART, Variable Baud Rate, Asynchronous Full-Duplex

This mode provides the 10 bits full duplex asynchronous communication. The 10 bits consist of a start bit (logical 0), 8 data bits (LSB first), and a stop bit (logical 1). When receiving, the eight data bits are stored in SBUF and the stop bit goes into RB8 (SCON.2). The serial receive and transmit baud rate is 1/16 of the Timer4/2 overflow (Refer to **Baud Rate** Section for details). The functional block diagram is shown below.





Transmission begins with a "write to SBUF" signal, and it actually commences at the next system clock following the next rollover in the divide-by-16 counter (divide baud-rate by 16), thus, the bit times are synchronized to the divide-by-16 counter, not to the "write to SUBF" signal. The start bit is firstly put out on TxD pin, then are the 8 bits of data. After all 8 bits of data in the transmit shift register are transmitted, the stop bit is put out on the TxD pin, and the TI flag is set at the same time that the stop is send.



Send Timing of Mode 1

Reception is enabled only if REN is high. The serial port actually starts the receiving of serial data with the detection of a falling edge on the RxD pin. For this purpose RxD is sampled at the rate of 16 times baud rate. When a falling edge is detected, the divide-by-16 counter is immediately reset. This helps to align the bit boundaries with the rollovers of the divide-by-16 counter. The 16 states of the counter divide each bit time into 16ths. The bit detector samples the value of RxD at the 7<sup>th</sup>, 8<sup>th</sup> and 9<sup>th</sup> counter states of each bit time. The value accepted is the value that was seen in at least 2 of the 3 samples. This is done for noise rejection. If the first bit after the falling edge of RxD pin is not 0, which indicates an invalid start bit, and the reception is immediately aborted. The receive circuits are reset and again waiting for a falling edge in the RxD line. If a valid start bit is detected, then the rest of the bits are also detected and shifted into the shift register. After shifting in 8 data bits and the stop bit, the SBUF and RB8 are loaded and RI are set if the following conditions are met:

#### 1. RI must be 0

2. Either SM2 = 0, or the received stop bit = 1

If these conditions are met, then the stop bit goes to RB8, the 8 data bits go into SBUF and RI is set. Otherwise the received frame may be lost.

At the time, the receiver goes back to looking for another falling edge on the RxD pin. And the user should clear RI by software for further reception.



**Receive Timing of Mode 1** 



### Mode2: 9-Bit EUART, Fixed Baud Rate, Asynchronous Full-Duplex

This mode provides the 11 bits full duplex asynchronous communication. The 11 bit consists of one start bit (logical 0), 8 data bits (LSB first), a programmable 9<sup>th</sup> data bit, and a stop bit (logical 1). Mode 2 supports multiprocessor communications and hardware address recognition (Refer to Multiprocessor Communication Section for details). When data is transmitted, the 9<sup>th</sup> data bit (TB8 in SCON) can be assigned the value of 0 or 1, for example, the parity bit P in the PSW or used as data/address flag in multiprocessor communications. When data is received, the 9<sup>th</sup> data bit goes into RB8 and the stop bit is not saved. The baud rate is programmable to either 1/32 or 1/64 of the system working frequency, as determined by the SMOD bit in PCON. The functional block diagram is shown below:



Transmission begins with a "write to SBUF" signal, the "write to SBUF" signal also loads TB8 into the 9<sup>th</sup> bit position of the transmit shift register. Transmission actually commences at the next system clock following the next rollover in the divide-by-16 counter (thus, the bit times are synchronized to the divide-by-16 counter, not to the "write to SUBF" signal). The start bit is firstly put out on TxD pin, then are the 9 bits of data. After all 9 bits of data in the transmit shift register are transmitted, the stop bit is put out on the TxD pin, and the TI flag is set at the same time, this will be at the 11<sup>th</sup> rollover of the divide-by-16 counter after a write to SBUF.



#### Send Timing of Mode 2



Reception is enabled only if REN is high. The serial port actually starts the receiving of serial data, with the detection of a falling edge on the RxD pin. For this purpose RxD is sampled at the rate of 16 times baud rate. When a falling edge is detected, the divide-by-16 counter is immediately reset. This helps to align the bit boundaries with the rollovers of the divide-by-16 counter. The 16 states of the counter divide each bit time into 16ths. The bit detector samples the value of RxD at the 7<sup>th</sup>, 8<sup>th</sup> and 9<sup>th</sup> counter state of each bit time. The value accepted is the value that was seen in at least 2 of the 3 samples. This is done for noise rejection. If the first bit detected after the falling edge of RxD pin is not 0, which indicates an invalid start bit, and the reception is immediately aborted. The receive circuits are reset and again looks for a falling edge in the RxD line. If a valid start bit is detected, then the rest of the bits are also detected and shifted into the shift register. After shifting in 9 data bits and the stop bit, the SBUF and RB8 are loaded and RI is set if the following conditions are met:

#### 1. RI must be 0

2. Either SM2 = 0, or the received  $9^{th}$  bit = 1 and the received byte accords with Given Address

If these conditions are met, then the 9<sup>th</sup> bit goes to RB8, the 8 data bits go into SBUF and RI is set. Otherwise the received frame may be lost.

At the time, the receiver goes back to looking for another falling edge on the RxD pin. And the user should clear RI by software for further reception.



Receive Timing of Mode 2

### Mode3: 9-Bit EUART, Variable Baud Rate, Asynchronous Full-Duplex

Mode3 uses transmission protocol of the Mode2 and baud rate generation of the Mode1.





### 8.4.3 Baud Rate Generate

In Mode0, the baud rate is programmable to either 1/12 or 1/4 of the system frequency. This baud rate is determined by SM2 bit. When set to 0, the serial port runs at 1/12 of the system clock. When set to 1, the serial port runs at 1/4 of the system clock. In Mode1 & Mode3, the baud rate can be selected from Timer4/2 overflow rate.

Set theTCLK (T2CON.4) and RCLK (T2CON.5) bit 1 to select Timer 2 as TX and RX baud clock source (see timer chapters). Whether TCLK or RCLK to logic 1, Timer 2 baud rate generator. TCLK and RCLK is logic 0, the timer Tx and Rx baud clock source.

The Mode1 & 3 baud rate equations are shown below, where [RCAP2H, RCAP2L] is the 16-bit reload register for Timer2, [TH4, TL4] is the 16-bit reload register for Timer4.

 $BaudRate = \frac{1}{2 \times 16} \times \frac{f_{_{SYS}}}{65536 - [RCAP2H, RCAP2L]}, Baud Rate using Timer2, the clock source of Timer2 is system clock.$ 

 $BaudRate = \frac{1}{1} \times \frac{f_{SYS} / PRESCALER}{1}$ , Baud Rate using Timer4, Timer4 works in Mode 1.

 $BaudRate = \frac{1}{16} \times \frac{f_{T4}/PRESCALER}{65536 - [TH4, TL4]}, Baud Rate using Timer4, using input clock in T4 pin as Timer4 clock source and the source of the source o$ 

In Mode2, the baud rate is programmable to either 1/32 or 1/64 of the system clock. This baud rate is determined by the SMOD bit (PCON.7). When this bit is set to 0, the serial port runs at 1/64 of the clock. When set to 1, the serial port runs at 1/32 of the clock.

BaudRate = 
$$2^{\text{SMOD}} \times (\frac{f_{\text{SYS}}}{64})$$

### 8.4.4 Multi-Processor Communication

#### **Software Address Recognition**

Modes 2 and 3 of the EUART have a special provision for multi-processor communication. In these modes, 9 data bits are received. The 9th bit goes into RB8. Then a stop bit follows. The EUART can be programmed such that when the stop bit is received, the EUART interrupt will be activated (i.e. the request flag RI is set) only if RB8 = 1. This feature is enabled by setting the bit SM2 in SCON.

A way to use this feature in multiprocessor communications is as follows. If the master processor wants to transmit a block of data to one of the several slaves, it first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9th bit is 1 in an address byte and 0 in a data byte.

With SM2 = 1, no other slave will be interrupted by a data byte. An address byte, however, will interrupt all slaves, so that each slave can examine the received byte and see if it is being addressed. The addressed slave will clear its SM2 bit and prepare to receive the data bytes that will be coming. After having received a complete message, the slave sets SM2 again. The slaves that were not addressed leave their SM2 set and go on with their business, ignoring the incoming data bytes.

**Note:** In Mode0, SM2 is used to select baud rate doubling. In Mode1, SM2 can be used to check the validity of the stop bit. If SM2 = 1 in Mode1, the receive interrupt will not be activated unless a valid stop bit is received.

### Automatic (Hardware) Address Recognition

In Mode2 & 3, setting the SM2 bit will configure EUART act as following: when a stop bit is received, EUART will generate an interrupt only if the 9<sup>th</sup> bit that goes into RB8 is logic 1 (address byte) and the received data byte matches the EUART slave address. Following the received address interrupt, the slave should clear its SM2 bit to enable interrupts on the reception of the following data byte(s).

The 9-bit mode requires that the 9<sup>th</sup> information bit is a 1 to indicate that the received information is an address and not data. When the master processor wants to transmit a block of data to one of the slaves, it first sends out the address of the targeted slave (or slaves). All the slave processors should have their SM2 bit set high when waiting for an address byte, which ensures that they will be interrupted only by the reception of an address byte. The Automatic address recognition feature further ensures that only the addressed slave will be interrupted. The address comparison is done by hardware not software.

After being interrupted, the addressed slave clears the SM2 bit to receive data bytes. The un-addressed slaves will be unaffected, as they will be still waiting for their address. Once the entire message is received, the addressed slave should set its SM2 bit to ignore all transmissions until it receives the next address byte.

The Automatic Address Recognition feature allows a master to selectively communicate with one or more slaves by invoking the Given Address. All of the slaves may be contacted by using the Broadcast address. Two special Function Registers are used to define the slave's address, SADDR, and the address mask, SADEN. The slave address is an 8-bit value specified in the SADDR register. The SADEN register is actually a mask for the byte value in SADDR. If a bit position in SADEN is 0, then the corresponding bit position in SADDR is don't care. Only those bit positions in SADDR whose corresponding bits in SADEN are 1 are used to obtain the Given Address. This gives the user flexibility to address multiple slaves without changing the slave address in SADDR. Use of the Given Address allows multiple slaves to be recognized while excluding others.



|                        | Slave 1  | Slave 2  |
|------------------------|----------|----------|
| SADDR                  | 10100100 | 10100111 |
| SADEN (0 mask)         | 11111010 | 11111001 |
| Given Address          | 10100x0x | 10100xx1 |
| Broadcast Address (OR) | 1111111x | 1111111  |

The Given address for slave 1 and 2 differ in the LSB. For slave 1, it is a don't care, while for slave 2 it is 1. Thus to communicate only with slave 1, the master must send an address with LSB = 0 (10100000). Similarly the bit 1 is 0 for slave 1 and don't care for slave 2. Hence to communicate only with slave 2 the master has to transmit an address with bit 1 = 1 (1010 0011). If the master wishes to communicate with both slaves simultaneously, then the address must have bit 0 = 1 and bit 1 = 0. The bit 2 position is don't care for both the slaves. This allows two different addresses to select both slaves (1010 0001 and 1010 0101).

The master can communicate with all the slaves simultaneously with the Broadcast Address. This address is formed from the logical OR of the SADDR and SADEN. The zeros in the result are defined as don't cares. In most cases, the Broadcast Address is FFh, this address will be acknowledged by all slaves.

On reset, the SADDR and SADEN are initialized to 00h. This results in Given Address and Broadcast Address being set as XXXXXXXX (all bits don't care). This effectively removes the multiprocessor communications feature, since any selectivity is disabled. This ensures that the EUART 0 will reply to any address, which it is backwards compatible with the 80C51 microcontrollers that do not support automatic address recognition. So the user may implement multiprocessor by software address recognition mentioned above.

#### 8.4.5 Error Detection

Error detection is available when the SSTAT bit in register PCON is set to logic 1. The SSTAT bit must be logic 1 to access any of the status bits (FE, RXOV, and TXCOL). The SSTAT bit must be logic 0 to access the Mode Select bits (SM0, SM1, and SM2). All the 3 bits should be cleared by software after they are set, even when the following frames received without any error will not be cleared automatically.

#### **Transmit Collision**

The Transmit Collision bit (TXCOL bit in register SCON) reads '1' if RI is set 0 and user software writes data to the SBUF register while a transmission is still in progress. If this occurs, the new data will be ignored and the transmit buffer will not be written.

#### **Receive Overrun**

The Receive Overrun bit (RXOV in register SCON) reads '1' if a new data byte is latched into the receive buffer before software has read the previous byte. The previous data is lost when this happen.

#### Frame Error

The Frame Error bit (FE in register SCON) reads '1' if an invalid (low) STOP bit is detected.

### Break Detection

A break is detected when any 11 consecutive bits are sensed low. Since a break condition also satisfies the requirements for a framing error, a break condition will also result in reporting a framing error. Once a break condition has been detected, the EUART will go into an idle state and remain in this idle state until a valid stop bit (rising edge on RxD line) has been received.



# 8.4.6 Register

Table 8.21 EUART Control & Status Register

| 98H, Bank                  | 98H, Bank0 Bit7 |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit5                                                                                                                                                                                                                    | Bit4                                                                       | Bit3                                                            | Bit2                                         | Bit1          | Bit0     |
|----------------------------|-----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------|---------------|----------|
| SCON                       |                 | SM0<br>/FE | SM1<br>/RXOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SM2<br>/TXCOL                                                                                                                                                                                                           | REN                                                                        | TB8                                                             | RB8                                          | TI            | RI       |
| R/W                        |                 | R/W        | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W                                                                                                                                                                                                                     | R/W                                                                        | R/W                                                             | R/W                                          | R/W           | R/W      |
| Reset Valu<br>(POR/WDT/LVR | -               | 0          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                       | 0                                                                          | 0                                                               | 0                                            | 0             | 0        |
| Bit Number                 | Bit N           | Inemonic   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                         |                                                                            | Description                                                     |                                              |               |          |
| 7-6                        | 7-6 SM[0:1]     |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | e 0, Synchro<br>e 1, 8 bit Asy<br>e 2, 9 bit Asy<br>e 3, 9 bit Asy                                                                                                                                                      | ntrol bit, wh<br>nous Mode, f<br>nchronous M<br>nchronous M<br>nchronous M | ixed baud ra<br>lode, variabl<br>lode, fixed b<br>lode, variabl | te<br>e baud rate<br>aud rate<br>e baud rate |               |          |
| 7                          |                 | FE         | 0: No Fra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | EUART Frame Error flag, when FE bit is read, SSTAT bit must be set 1<br>0: No Frame Error, clear by software<br>1: Frame error occurs, set by hardware                                                                  |                                                                            |                                                                 |                                              |               |          |
| 6                          | F               | RXOV       | EUART Receive Over flag, when RXOV bit is read, SSTAT bit must be set 1<br>0: No Receive Over, clear by software<br>1: Receive over occurs, set by hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                         |                                                                            |                                                                 |                                              |               | set 1    |
| 5                          |                 | SM2        | <ul> <li>EUART Multi-processor communication enable bit (9<sup>th</sup> bit '1' checker), when SSTAT = 0</li> <li>0: In Mode0, baud-rate is 1/12 of system clock<br/>In Mode1, disable stop bit validation check, any stop bit will set RI to generate interrupt<br/>In Mode2 &amp; 3, any byte will set RI to generate interrupt</li> <li>1: In Mode0, baud-rate is 1/4 of system clock<br/>In Mode1, Enable stop bit validation check, only valid stop bit (1) will set RI to generate interrupt</li> <li>In Mode2 &amp; 3, only address byte (9<sup>th</sup> bit = 1) will set RI to generate interrupt</li> </ul> |                                                                                                                                                                                                                         |                                                                            |                                                                 |                                              |               |          |
| 5                          | т               | XCOL       | <b>set 1</b><br>0: No Tra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ansmit Collis                                                                                                                                                                                                           | sion flag, wh<br>ion, clear by<br>occurs, set b                            | software                                                        | bit is read,                                 | SSTAT bit r   | nust be  |
| 4                          |                 | REN        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | e <b>iver enabl</b><br>ve Disable<br>ve Enable                                                                                                                                                                          | e bit                                                                      |                                                                 |                                              |               |          |
| 3                          |                 | TB8        | The 9th bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | to be transr                                                                                                                                                                                                            | nitted in Mo                                                               | de2 & 3 of E                                                    | UART, set o                                  | or clear by s | oftware  |
| 2                          |                 | RB8        | In Mode(<br>In Mode1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ), RB8 is not<br>I, if receive i                                                                                                                                                                                        | red in Mode1<br>t used<br>nterrupt occu<br>ne 9 <sup>th</sup> bit that     | irs, RB8 is th                                                  | e stop bit tha                               | at was receiv | ed       |
| 1                          |                 | ТІ         | 0: cleare<br>1: Set by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <ul> <li>Transmit interrupt flag of EUART</li> <li>0: cleared by software</li> <li>1: Set by hardware at the end of the 8<sup>th</sup> bit time in Mode0, or at the beginning of the stop bit in other modes</li> </ul> |                                                                            |                                                                 |                                              |               |          |
| 0                          |                 | RI         | 1: Set by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | d by softwar                                                                                                                                                                                                            | e<br>t the end of t                                                        | he 8 <sup>th</sup> bit tim                                      | e in Mode0,                                  | or during the | stop bit |



# Table 8.22 EUART Data Buffer Register

| 99H, Bank0                          | Bit7        | Bit6   | Bit5   | Bit4   | Bit3   | Bit2   | Bit1   | Bit0   |
|-------------------------------------|-------------|--------|--------|--------|--------|--------|--------|--------|
| SBUF                                | SBUF.7      | SBUF.6 | SBUF.5 | SBUF.4 | SBUF.3 | SBUF.2 | SBUF.1 | SBUF.0 |
| R/W                                 | R/W         | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset Value<br>(POR/WDT/LVR/P       | <b>N)</b> 0 | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Rit Number Rit Mnomonic Description |             |        |        |        |        |        |        |        |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0        | SBUF[7:0]    | This SFR accesses two registers; a transmit shift register and a receive latch register<br>A write of SBUF will send the byte to the transmit shift register and then initiate a<br>transmission<br>A read of SBUF returns the contents of the receive latch |

Table 8.23 Power Control Register

| 87H, Bank0                       | Bit7 | Bit6  | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|-------|------|------|------|------|------|------|
| PCON                             | SMOD | SSTAT | -    | -    | GF1  | GF0  | PD   | IDL  |
| R/W                              | R/W  | R/W   | -    | -    | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0     | -    | -    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                    |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | SMOD         | Baud rate doubler<br>Set SMOD in Mode1 & 3, the baud-rate of EUART is doubled if using time4 as<br>baud-rate generator<br>set SMOD in Mode2, the baud-rate of EUART is doubled |
| 6          | SSTAT        | SCON[7:5] function select bit<br>0: SCON[7:5] operates as SM0, SM1, SM2<br>1: SCON[7:5] operates as FE, RXOV, TXCOL                                                            |
| 3-0        |              | Other: See "Power Management" chapter                                                                                                                                          |

Table 8.24 EUART Slave Address & Address Mask Register

| 9AH-9BH, Bank0                   | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|----------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| SADDR                            | SADDR.7 | SADDR.6 | SADDR.5 | SADDR.4 | SADDR.3 | SADDR.2 | SADDR.1 | SADDR.0 |
| SADEN                            | SADEN.7 | SADEN.6 | SADEN.5 | SADEN.4 | SADEN.3 | SADEN.2 | SADEN.1 | SADEN.0 |
| R/W                              | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                  |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0        | SADDR[7:0]   | SFR SADDR defines the EUART's slave address                                                                                                                                                                                  |
| 7-0        | SADEN[7:0]   | SFR SADEN is a bit mask to determine which bits of SADDR are checked<br>against a received address<br>0: Corresponding bit in SADDR is a "don't care"<br>1: Corresponding bit in SADDR is checked against a received address |



## Table 8.25 Rxd Pin Schmidt Voltage Control Register

| 9FH, Bank                        | D     | Bit7     | Bit6 Bit5 Bit4                                                                                                                                                                               |   |   | Bit3        | Bit2 | Bit1   | Bit0   |
|----------------------------------|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-------------|------|--------|--------|
| RxCON                            |       | -        | -                                                                                                                                                                                            | - | - | -           | -    | RxCON1 | RxCON0 |
| R/W                              |       | -        |                                                                                                                                                                                              |   | - | -           | -    | R/W    | R/W    |
| Reset Value<br>(POR/WDT/LVR/PIN) |       | -        | -                                                                                                                                                                                            | - | - | -           | -    | 0      | 0      |
| Bit Number                       | Bit N | Inemonic |                                                                                                                                                                                              |   |   | Description |      |        |        |
|                                  |       |          | Rxd pin Schmidt voltage control         00: input low voltage is 0.2 V <sub>DD</sub> 01: input low voltage is 0.4 V <sub>DD</sub> 10: input low voltage is 0.5 V <sub>DD</sub> 11: normal IO |   |   |             |      |        |        |

Note: RxCON is available when EUART is on. Refer to Electrical Characteristics for detail.



#### 8.5 Analog Digital Converter (ADC)

#### 8.5.1 Feature

- 10-bit Resolution
- Build in V<sub>REF</sub>
- Selectable external or built-in V<sub>REF</sub>
- 8 Multiplexed Input Channels

The SH79F1616 include a single ended, 10-bit SAR Analog to Digital Converter (ADC) with build in reference voltage connected to the  $V_{DD}$ , users also can select the  $V_{REF}$  pin input reference voltage. The 7 ADC channels are shared with 1 ADC module; each channel can be programmed to connect with the analog input individually. Only one channel can be available at

one time. GO/DONE signal is available to start convert, and indicate end of convert. When conversion is completed, the data in AD convert data register will be updated and ADCIF bit in ADCON register will be set. If ADC Interrupt is enabled, the ADC interrupt will generate.

The ADC integrates a digital compare function to compare the value of analog input with the digital value in the AD converter. If this function is enabled (set EC bit in ADCON register) and ADC module is enabled (set ADON bit in ADCON register). When the corresponding digital value of analog input is larger than the value in compare value register (ADDH/L), the ADC interrupt

will occur, otherwise no interrupt will be generated. The digital comparator can work continuously when GO/DONE bit is set until software clear, which behaviors different with the AD converter operation mode.

The ADC module including digital compare module can wok in Idle mode and the ADC interrupt will wake up the Idle mode, but is disabled in Power-Down mode.

#### 8.5.2 ADC Diagram



ADC Diagram



# 8.5.3 ADC Register

Table 8.26 ADC Control Register

| 93H, Bank0                  | )          | Bit7         | Bit6                                                                                                                                                                                                                                                                                                                                              | Bit5                                                                    | Bit4                                    | Bit3 | Bit2 | Bit1 | Bit0        |  |
|-----------------------------|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------|------|------|------|-------------|--|
| ADCON                       | ADCON ADON |              |                                                                                                                                                                                                                                                                                                                                                   | EC                                                                      | REFC                                    | SCH2 | SCH1 | SCH0 | GO/DONE     |  |
| R/W                         |            | R/W          | R/W                                                                                                                                                                                                                                                                                                                                               | R/W                                                                     | R/W                                     | R/W  | R/W  | R/W  | R/W         |  |
| Reset Value<br>(POR/WDT/LVR | -          | 0            | 0                                                                                                                                                                                                                                                                                                                                                 | 0                                                                       | 0                                       | 0    | 0    | 0    | 0           |  |
| Bit Number                  | Bit N      | Inemonic     | Description                                                                                                                                                                                                                                                                                                                                       |                                                                         |                                         |      |      |      |             |  |
| 7                           | A          | ADON         | 0: Disabl                                                                                                                                                                                                                                                                                                                                         | ADC Enable bit<br>0: Disable the ADC module<br>1: Enable the ADC module |                                         |      |      |      |             |  |
| 6                           | A          | <b>ADCIF</b> | <ul> <li>ADC Interrupt Flag bit</li> <li>0: No ADC interrupt, cleared by software.</li> <li>1: Set by hardware to indicate that the AD Convert has been completed, or analog input is larger than ADDH/ADDL if compare is enabled</li> </ul>                                                                                                      |                                                                         |                                         |      |      |      | , or analog |  |
| 5                           |            | EC           | Compare Function Enable bit<br>0: Compare function disabled<br>1: Compare function enabled                                                                                                                                                                                                                                                        |                                                                         |                                         |      |      |      |             |  |
| 4                           | F          | REFC         |                                                                                                                                                                                                                                                                                                                                                   | erence volta                                                            | ect bit<br>ge connecte<br>ge input fron |      |      |      |             |  |
| 3-1                         | so         | CH[2:0]      | ADC channel Select bits<br>000: ADC channel AN0<br>001: ADC channel AN1<br>010: ADC channel AN2<br>011: ADC channel AN3<br>100: ADC channel AN4<br>101: ADC channel AN5<br>110: ADC channel AN6<br>111: ADC channel AN7                                                                                                                           |                                                                         |                                         |      |      |      |             |  |
| 0                           | GC         | )/DONE       | <ul> <li>ADC status flag bit</li> <li>O: Automatically cleared by hardware when AD convert is completed. Clearing this bit during converting time will stop current conversion. If Compare function is enabled, this bit will not be cleared by hardware until software clear.</li> <li>1: Set to start AD convert or digital compare.</li> </ul> |                                                                         |                                         |      |      |      |             |  |

Notes:

When select the reference voltage input from  $V_{REF}$  pin (REFC = 1), the P4.4 is shared as  $V_{REF}$  input rather than AN3 input.



### Table 8.27 ADC Time Configuration Register

| 94H, Bank0                       | Bit7  | Bit6  | Bit5  | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|-------|-------|-------|------|------|------|------|------|
| ADT                              | TADC2 | TADC1 | TADC0 | -    | TS3  | TS2  | TS1  | TS0  |
| R/W                              | R/W   | R/W   | R/W   | -    | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0     | 0     | -    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5        | TADC[2:0]    | $\begin{array}{l} \textbf{ADC Clock Period Select bits} \\ 000: ADC Clock Period t_{AD} = 2 t_{SYS} \\ 001: ADC Clock Period t_{AD} = 4 t_{SYS} \\ 010: ADC Clock Period t_{AD} = 6 t_{SYS} \\ 011: ADC Clock Period t_{AD} = 8 t_{SYS} \\ 100: ADC Clock Period t_{AD} = 12 t_{SYS} \\ 101: ADC Clock Period t_{AD} = 16 t_{SYS} \\ 101: ADC Clock Period t_{AD} = 24 t_{SYS} \\ 110: ADC Clock Period t_{AD} = 32 t_{SYS} \end{array}$ |
| 3-0        | TS[3:0]      | Sample time select bits<br>$2 t_{AD} \le \text{Sample time} = (\text{TS } [3:0]+1) * t_{AD} \le 15 t_{AD}$                                                                                                                                                                                                                                                                                                                               |

#### Note:

(1) Make sure that  $t_{AD} \ge 1 \mu s$ ;

(2) The minimum sample time is 2  $t_{AD}$ , even TS[3:0] = 0000;

(3) The maximum sample time is  $15 t_{AD}$ , even TS[3:0] = 1111;

(4) Evaluate the series resistance connected with ADC input pin before set TS[3:0];

(5) Be sure that the series resistance connected with ADC input pin is no more than  $10k\Omega$  when 2 t<sub>AD</sub> sample time is selected; (6) Total conversion time is: 12 t<sub>AD</sub> + sample time.

#### For Example

| System Clock<br>(SYSCLK) | TADC[2:0] | t <sub>AD</sub> | TS[3:0] | Sample Time   | Conversion Time                      |
|--------------------------|-----------|-----------------|---------|---------------|--------------------------------------|
|                          | 000       | 0.25 *2=0.5µs   | -       | -             | $(t_{AD} < 1\mu s, not recommended)$ |
|                          | 001       | 0.25 *4=1μs     | 0000    | 2*1=2µs       | 12*1+2=14µs                          |
|                          | 001       | 0.25 *4=1μs     | 0111    | 8*1=8µs       | 12*1+8=20μs                          |
| 4MHz                     | 001       | 0.25 *4=1μs     | 1111    | 15*1=15µs     | 12*1+15=27μs                         |
|                          | 111       | 0.25 *32=8µs    | 0000    | 2*8=16µs      | 12*8+16=112µs                        |
|                          | 111       | 0.25 *32=8µs    | 0111    | 8*8=64µs      | 12*8+64=160μs                        |
|                          | 111       | 0.25 *32=8µs    | 1111    | 15*8=120µs    | 12*8+120=216μs                       |
|                          | 000       | 0.083*2=0.166µs | -       | -             | $(t_{AD} < 1\mu s, not recommended)$ |
|                          | 100       | 0.083*12=1µs    | 0000    | 2*1=2µs       | 12*1+2=14µs                          |
|                          | 100       | 0.083*12=1µs    | 0111    | 8*1=8µs       | 12*1+8=20μs                          |
| 12MHz                    | 100       | 0.083*12=1µs    | 1111    | 15*1=15µs     | 12*1+15=27μs                         |
|                          | 111       | 0.083*32=2.7µs  | 0000    | 2*2.7=5.4µs   | 12*2.7+5.4=37.8μs                    |
|                          | 111       | 0.083*32=2.7µs  | 0111    | 8*2.7=21.6μs  | 12*2.7+21.6=54µs                     |
|                          | 111       | 0.083*32=2.7µs  | 1111    | 15*2.7=40.5µs | 12*2.7+40.5=72.9μs                   |



#### Table 8.28 ADC Channel Configure Register

| 95H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| ADCH                             | CH7  | CH6  | CH5  | CH4  | CH3  | CH2  | CH1  | CH0  |
| R/W                              | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                      |
|------------|--------------|------------------------------------------------------------------------------------------------------------------|
| 7-0        | CH[7:0]      | Channel Configuration bits<br>0: P4.0-P4.3, P3.4-P3.7 are I/O port<br>1: P4.0-P4.3, P3.4-P3.7 are ADC input port |

#### **Table 8.29** AD Converter Data Register (Compare Value Register)

| 96H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| ADDL                             | -    | -    | -    | -    | -    | -    | A1   | A0   |
| R/W                              | -    | -    | -    | -    | -    | -    | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | -    | -    | 0    | 0    |
| 97H, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
| ADDH                             | A9   | A8   | A7   | A6   | A5   | A4   | A3   | A2   |
| R/W                              | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0<br>7-0 | A9-A0        | ADC Data register<br>Digital Value of sampled analog voltage, updated when conversion is completed<br>If ADC Compare function is enabled (EC = 1), this is the value to be compared<br>with the analog input |

#### The Approach for AD Conversion:

- (1) Select the analog input channels and reference voltage.
- (2) Enable the ADC module with the selected analog channel.
- (3) Set  $GO/\overline{DONE} = 1$  to start the AD conversion.
- (4) Wait until  $GO/\overline{DONE} = 0$  or ADCIF = 1, if the ADC interrupt is enabled, the ADC interrupt will occur.
- (5) Acquire the converted data from ADDH/ADDL.
- (6) Repeat step 3-5 if another conversion is required.

#### The Approach for Digital Compare Function:

- (1) Select the analog input channels and reference voltage.
- (2) Set ADDH/ADDL to the compare value.
- (3) Set EC = 1 to enable compare function.
- (4) Enable the ADC module with the selected analog channel.
- (5) Set GO/DONE = 1 to start the compare function.
- (6) If the analog input is lager than compare value set in ADDH/ADDL, the ADCIF will be set to 1. If the ADC interrupt is enabled, the ADC interrupt will occur.
- (7) The compare function will continue work until the  $GO/\overline{DONE}$  bit is cleared to 0.



# 8.6 Buzzer

## 8.6.1 Feature

- Output a signal (square wave) used for tones such as a confirmation tone
- Selectable whether to output one of 8 output frequencies or to disable the output

#### 8.6.2 Register

Table 8.30 Buzzer Output Control Register

| BDH, Bank0                       | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|------|------|------|------|------|------|------|
| BUZCON                           | -    | -    | -    | -    | BCA2 | BCA1 | BCA0 | BZEN |
| R/W                              | -    | -    | -    | -    | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | -    | -    | -    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                         |
|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3-1        | BCA[3:1]     | Buzzer output carrier frequency control bits<br>000: system clock/8192<br>001: system clock/4096<br>010: system clock/2048<br>011: system clock/1024<br>100: system clock/512<br>101:system clock/32<br>110: system clock/16<br>111: system clock/8 |
| 0          | BZEN         | Enable buzzer output control bit<br>0: P5.3 is I/O port<br>1: P5.3 is buzzer output port                                                                                                                                                            |



#### 8.7 Low Power Detect (LPD)

#### 8.7.1 Feature

- An internal flag indicates low power is detected
- LPD detect voltage is selectable
- LPD de-bounce timer T<sub>LVR</sub> is about 30-60µs

The low power detect (LPD) is used to monitor the supply voltage and generate an internal flag if the voltage decrease below the specified value. It is used to inform CPU whether the power is shut off or the battery is used out, so the software may do some protection action before the voltage drop down to the minimal operation voltage.

LPD interrupt can wake up from Power-down mode.

#### 8.7.2 Register

Table 8.31 Low Power Detection Control Register

| B3H                              | Bit7  | Bit6 | Bit5  | Bit4  | Bit3  | Bit2  | Bit1  | Bit0  |
|----------------------------------|-------|------|-------|-------|-------|-------|-------|-------|
| LPDCON                           | LPDEN | LPDF | LPDMD | LPDIF | LPDS3 | LPDS2 | LPDS1 | LPDS0 |
| R/W                              | R/W   | R    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0     | 0    | 0     | 0     | 0     | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                             |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | LPDEN        | LPD Enable bit<br>0: Disable lower power detection<br>1: Enable lower power detection                                                                                                                                                                   |
| 6          | LPDF         | LPD status Flag bit<br>0: No LPD happened, clear by hardware,<br>1: LPD happened, set by hardware                                                                                                                                                       |
| 5          | LPDMD        | LPD mode select bit<br>0: When V <sub>DD</sub> below LPD voltage, LPDF is set<br>1: When V <sub>DD</sub> above LPD voltage, LPDF is set                                                                                                                 |
| 4          | LPDIF        | LPD interrupt flag bit<br>0: No LPD happened, clear by software<br>1: LPD happened, set by hardware                                                                                                                                                     |
| 3-0        | LPDS[3:0]    | LPD Voltage Select bit<br>0000: 2.40V<br>0001: 2.55V<br>0010: 2.70V<br>0011: 2.85V<br>0100: 3.00V<br>0101: 3.15V<br>0110: 3.30V<br>0111: 3.45V<br>1000: 3.60V<br>1001: 3.75V<br>1000: 3.90V<br>1011: 4.05V<br>1100: 4.20V<br>1110: 4.35V<br>1110: 4.50V |





#### 8.8 Low Voltage Reset (LVR)

#### 8.8.1 Feature

- Enabled by the code option and VLVR is 4.3V or 2.1V
- LVR de-bounce timer T<sub>LVR</sub> is about 30-60µs
- An internal reset flag indicates low voltage reset generates

The LVR function is used to monitor the supply voltage and generate an internal reset in the device when the supply voltage below the specified value  $V_{LVR}$ . The LVR de-bounce timer  $T_{LVR}$  is about  $30\mu$ s.

The LVR circuit has the following functions when the LVR function is enabled: (t means the time of the supply voltage below  $V_{LVR}$ )

Generates a system reset when  $V_{DD} \le V_{LVR}$  and  $t \ge T_{LVR}$ ;

Cancels the system reset when  $V_{DD} > V_{LVR}$  or  $V_{DD} < V_{LVR}$ , but  $t < T_{LVR}$ .

The LVR function is enabled by the code option.

It is typically used in AC line or large battery supplier applications, where heavy loads may be switched on and cause the MCU supply-voltage temporarily falls below the minimum specified operating voltage. This feature can protect system from working under bad power supply environment.



#### 8.9 Watchdog Timer (WDT) and Reset State

#### 8.9.1 Feature

- WDT runs even in the Power-Down mode
- Auto detect Program Counter(PC) over range, and generate OVL Reset
- Selectable different WDT overflow frequency

#### **OVL Reset**

To enhance the anti-noise ability, SH79F1616 built in Program Counter (PC) over range detect circuit, if program counter value is larger than flash romsize, or detect operation code equal to A5H which is not exist in 8051 instruction set, a OVL reset will be generate to reset CPU, and set WDOF bit. So, to make use of this feature, you should fill unused flash rom with A5H.

#### Watchdog Timer

The watchdog timer is a down counter, and its clock source is an independent built-in RC oscillator, so it always runs even in the Power-Down mode. The watchdog timer will generate a device reset when it overflows. It can be enabled or disabled permanently by the code option.

The watchdog timer control bits (WDT.2-0) are used to select different overflow frequency. The watchdog timer overflow flag (WDOF) will be automatically set to "1" by hardware when overflow happens. To prevent overflow happen, by reading or writing the WDT register RSTSTAT, the watchdog timer should re-count before the overflow happens.

There are also some reset flags in this register as below:



# 8.9.2 Register

Table 8.32 Reset Control Register

| B1H, Bank0        | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2  | Bit1  | Bit0  |
|-------------------|------|------|------|------|------|-------|-------|-------|
| RSTSTAT           | WDOF | -    | PORF | LVRF | CLRF | WDT.2 | WDT.1 | WDT.0 |
| R/W               | R/W  | -    | R/W  | R/W  | R/W  | R/W   | R/W   | R/W   |
| Reset Value (POR) | 0    | -    | 1    | 0    | 0    | 0     | 0     | 0     |
| Reset Value (WDT) | 1    | -    | u    | u    | u    | 0     | 0     | 0     |
| Reset Value (LVR) | u    | -    | u    | 1    | u    | 0     | 0     | 0     |
| Reset Value (PIN) | u    | -    | u    | u    | 1    | 0     | 0     | 0     |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | WDOF         | <ul> <li>Watch Dog Timer Overflow or OVL Reset Flag</li> <li>Set by hardware when WDT overflow or OVL reset happened, cleared by software or Power On Reset</li> <li>0: Watch Dog not overflows and no OVL reset generated</li> <li>1: Watch Dog overflow or OVL reset occurred</li> </ul>                                                                                                                                                                                                                                                                 |
| 5          | PORF         | Power On Reset Flag<br>Set only by Power On Reset, cleared only by software<br>0: No Power On Reset<br>1: Power On Reset occurred                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4          | LVRF         | Low Voltage Reset Flag<br>Set only by Low Voltage Reset, cleared by software or Power On Reset<br>0: No Low Voltage Reset occurs<br>1: Low Voltage Reset occurred                                                                                                                                                                                                                                                                                                                                                                                          |
| 3          | CLRF         | Pin Reset Flag<br>Set only by pin reset, cleared by software or Power On Reset<br>0: No Pin Reset occurs<br>1: Pin Reset occurred                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2-0        | WDT[2:0]     | WDT Overflow period control bit<br>000: Overflow period minimal value= 4096ms<br>001: Overflow period minimal value= 1024ms<br>010: Overflow period minimal value = 256ms<br>011: Overflow period minimal value = 128ms<br>100: Overflow period minimal value = 64ms<br>101: Overflow period minimal value = 16ms<br>110: Overflow period minimal value = 4ms<br>111: Overflow period minimal value = 1ms<br>Notes: If WDT_opt is enable in application, you must clear WatchDog<br>periodically, and the interval must be less than the value list above. |





#### 8.10 Power Management

#### 8.10.1 Feature

- Two power saving modes: Idle mode and Power-Down mode
- Two ways to exit Idle and Power-Down mode: interrupt and reset

To reduce power consumption, SH79F1616 supplies two power saving modes: Idle mode and Power-Down mode. These two modes are controlled by PCON & SUSLO register.

#### 8.10.2 Idle Mode

In this mode, the clock to CPU is frozen, the program execution is halted, and the CPU will stop at a defined state. But the peripherals continue to be clocked. When entering idle mode, all the CPU status before entering will be preserved. Such as: PSW, PC, SFR & RAM are all retained.

By two consecutive instructions: setting SUSLO register as 0x55, and immediately followed by setting the IDL bit in PCON register, will make SH79F1616 enter Idle mode. If the consecutive instruction sequence requirement is not met, the CPU will clear either SUSLO register or IDL bit in the next machine cycle. And the CPU will not enter Idle mode.

The setting of IDL bit will be the last instruction that CPU executed.

There are two ways to exit Idle mode:

- (1) An interrupt generated the clock to the CPU will be restored, and the hardware will clear SUSLO register and IDL bit in PCON register. Then the program will execute the interrupt service routine first, and then jumps to the instruction immediately following the instruction that activated Idle mode.
- (2) Reset signal (logic low on the RESET pin, WDT RESET if enabled, LVR REST if enabled), this will restore the clock to the CPU, the SUSLO register and the IDL bit in PCON register will be cleared by hardware, finally the SH79F1616 will be reset. And the program will execute from address 0000H. The RAM will keep unchanged and the SFR value might be changed according to different function module.

#### 8.10.3 Power-Down Mode

The Power-Down mode places the SH79F1616 in a very low power state. Power-Down mode will stop all the clocks including CPU and peripherals. If WDT is enabled, WDT block will keep on working. When entering Power-Down mode, all the CPU status before entering will be preserved. Such as: PSW, PC, SFR & RAM are all retained.

By two consecutive instructions: setting SUSLO register as 0x55, and immediately followed by setting the PD bit in PCON register, will make SH79F1616 enter Power-Down mode. If the consecutive instruction sequence requirement is not met, the CPU will clear either SUSLO register or PD bit in the next machine cycle. And the CPU will not enter Power-Down mode.

The setting of PD bit will be the last instruction that CPU executed.

**Note:** If IDL bit and PD bit are set simultaneously, the SH79F1616 enters Power-Down mode. The CPU will not go in Idle mode when exiting from Power-Down mode, and the hardware will clear both IDL & PD bit after exit form Power-Down mode.

There are three ways to exit the Power-Down mode:

- (1) An active external Interrupt such as INT2, INT3 & INT4 will make SH79F1616 exit Power-Down mode. The oscillator will start after interrupt happens, after warm-up time, the clocks to the CPU and peripheral will be restored, the SUSLO register and PD bit in PCON register will be cleared by hardware. Program execution resumes with the interrupt service routine. After completion of the interrupt service routine, program execution resumes with the instruction immediately following the instruction that activated Power-Down mode.
- (2) Timer3 interrupt will make SH79F1616 exit Power-Down mode when 32.768kHz or 128KHz is the clock source. The oscillator will start after interrupt happens, after warm-up time, the clocks to the CPU and peripheral will be restored, the SUSLO register and PD bit in PCON register will be cleared by hardware. Program execution resumes with the interrupt service routine. After completion of the interrupt service routine, program execution resumes with the instruction immediately following the instruction that activated Power-Down mode.
- (3) Reset signal (logic low on the RESET pin, WDT RESET if enabled, LVR REST if enabled). This will restore the clock to the CPU after warm-up time, the SUSLO register and the PD bit in PCON register will be cleared by hardware, finally the SH79F1616 will be reset. And the program will execute from address 0000H. The RAM will keep unchanged and the SFR value might be changed according to different function module.

Note: In order to entering Idle/Power-Down, it is necessary to add 3 NOPs after setting IDL/PD bit in PCON.



# 8.10.4 Register

Table 8.33 Power Control Register

| 87H                              | Bit7 | Bit6  | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------------------------|------|-------|------|------|------|------|------|------|
| PCON                             | -    | SSTAT | -    | -    | GF1  | GF0  | PD   | IDL  |
| R/W                              | -    | R/W   | -    | -    | R/W  | R/W  | R/W  | R/W  |
| Reset Value<br>(POR/WDT/LVR/PIN) | -    | 0     | -    | -    | 0    | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                                   |
|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | SSTAT        | SCON[7:5] function selection bit                                                                                                              |
| 3-2        | GF[1:0]      | General purpose flags for software use                                                                                                        |
| 1          | PD           | Power-Down mode control bit<br>0: Cleared by hardware when an interrupt or reset occurs<br>1: Set by software to activate the Power-Down mode |
| 0          | IDL          | Idle mode control bit<br>0: Cleared by hardware when an interrupt or reset occurs<br>1: Set by software to activate the Idle mode             |

Table 8.34 Suspend Mode Control Register

| 8EH                              | Bit7    | Bit6    | Bit5    | Bit4    | Bit3    | Bit2    | Bit1    | Bit0    |
|----------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| SUSLO                            | SUSLO.7 | SUSLO.6 | SUSLO.5 | SUSLO.4 | SUSLO.3 | SUSLO.2 | SUSLO.1 | SUSLO.0 |
| R/W                              | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| Reset Value<br>(POR/WDT/LVR/PIN) | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                             |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0        | SUSLO[7:0]   | This register is used to control the CPU enter suspend mode (Idle or Power-Down).<br>Only consecutive instructions like below will make CPU enter suspend mode. Other<br>wise the either SUSLO, IDL or PD bit will be cleared by hardware in the next<br>machine cycle. |

Example

| IDLE_MODE:<br>MOV<br>ORL<br>NOP<br>NOP<br>NOP | SUSLO, #55H<br>PCON, #01H |  |
|-----------------------------------------------|---------------------------|--|
|                                               |                           |  |
| POWERDOWN                                     | MODE:                     |  |
| POWERDOWN<br>MOV<br>ORI                       | SUSLO, #55H               |  |
| MOV<br>ORL<br>NOP                             |                           |  |
| MOV<br>ORL                                    | SUSLO, #55H               |  |



#### 8.11 Warm-up Timer

#### 8.11.1 Feature

- Built-in power on warm-up counter to eliminate unstable state of power on
- Built-in oscillator warm-up counter to eliminate unstable state when oscillation startup

SH79F1616 has a built-in power warm-up counter; it is designed to eliminate unstable state after power on or to do some internal initial operation such as read customer option etc.

SH79F1616 has also a built-in oscillator warm-up counter, it is designed to eliminate unstable state when oscillator starts oscillating in the following conditions: Power-on reset, Pin reset, LVR reset, Watchdog Reset and Wake up from Power-down mode.

After power-on, SH79F1616 will start power warm-up procedure first, and then oscillator warm-up procedure.

#### Power Warm-up Time

| Power On Reset/<br>Pin Reset/<br>Low Voltage Reset |                 | WDT Reset<br>(Not in Power-Down Mode) |                 | WDT Reset<br>(Wakeup from Power-Down<br>Mode) |                 | Wakeup from Power-Down<br>Mode<br>(Only for interrupt) |                 |
|----------------------------------------------------|-----------------|---------------------------------------|-----------------|-----------------------------------------------|-----------------|--------------------------------------------------------|-----------------|
| TPWRT**                                            | OSC<br>Warm up* | TPWRT**                               | OSC<br>Warm up* | TPWRT**                                       | OSC<br>Warm up* | TPWRT**                                                | OSC<br>Warm up* |
| 11ms                                               | YES             | ≈1ms                                  | NO              | pprox1ms                                      | YES             | pprox800us                                             | YES             |

#### **OSC Warm-up Time**

| Option:<br>OP_WMT<br>Oscillator Type | 00                     | 01                     | 10                     | 11                    |
|--------------------------------------|------------------------|------------------------|------------------------|-----------------------|
| Ceramic/Crystal                      | 2 <sup>17</sup> X Tosc | 2 <sup>14</sup> X Tosc | 2 <sup>11</sup> X Tosc | 2 <sup>8</sup> X Tosc |
| Internal RC                          | 2 <sup>7</sup> X Tosc  |                        |                        |                       |



### 8.12 Code Option

### OP\_WDT:

0: Disable WDT function (default) 1: Enable WDT function

#### OP\_WDTPD:

0: Disable WDT function in Power-Down mode (default)

1: Enable WDT function in Power-Down mode

#### OP\_RST:

0: P5.2 used as RST pin (default) 1: P5.2 used as I/O pin

#### **OP\_WMT: (unavailable for Internal RC)**

- 00: longest warm up time (default)
- 01: longer warm up time
- 10: shorter warm up time
- 11: shortest warm up time

#### OP\_OSC:

0000: internal 12M RC oscillator (default) 1110: 2M-12M cyrstal/cearmic oscillator Others: internal 12M RC oscillator

#### OP\_LVREN:

0: Disable LVR function (default) 1: Enable LVR function

#### OP\_LVRLE:

0: 4.3V LVR level 1 (default) 1: 2.1V LVR level 2

### OP\_SCM:

0: SCM is invalid in warm up period (default) 1: SCM is valid in warm up period

#### **OP\_OSCDRIVE:**

- 011: 8M-12M crystal (default)
- 001: 4M crystal
- 111: 12M ceramic
- 101: 8M ceramic
- 110: 4M ceramic
- 100: 2M ceramic

## OP\_PORTDRIVE: (unavailable for P3)

0: Port drive ability normal mode1: Port drive ability large mode (default)

#### OP\_P3.3-P3.0:

0: port3 [3:0] sink ability normal mode 1: port3 [3:0] sink ability large mode (default)

#### OP\_P3.7-P3.4:

- 0: port3 [7:4] sink ability large mode (default)
- 1: port3 [7:4] sink ability normal mode



### 8.13 Programming Note

In order to improve reliability, unused bit of PxCR (x = 0.5) register should be written 1, unused bit of PxPCR (x = 0.5) register should be written 0, unused bit of Px (x = 0.5) register should be written 0.

Example Program (P0):

MOV P0CR, # 11XX11XXB ; P0CR unused bit write 1 ,X is user's settings MOV P0PCR, # 00XX00XXB; P0PCR unused bit write 1, X is user's settings MOV P0, # 00XX00XXB ; P0 unused bit write 1, X is user's settings



### 9. Instruction Set

| ARITHMETIC OPERATIONS  | Description                                 | 0.1       | Dut  | 0        |
|------------------------|---------------------------------------------|-----------|------|----------|
| Opcode                 | Description                                 | Code      | Byte | Cycle    |
| ADD A, Rn              | Add register to accumulator                 | 0x28-0x2F | 1    | 1        |
| ADD A, direct          | Add direct byte to accumulator              | 0x25      | 2    | 2        |
| ADD A, @Ri             | Add indirect RAM to accumulator 0x26-0      |           | 1    | 2        |
| ADD A, #data           | Add immediate data to accumulator           | 0x24      | 2    | 2        |
| ADDC A, Rn             | Add register to accumulator with carry flag | 0x38-0x3F | 1    | 1        |
| ADDC A, direct         | Add direct byte to A with carry flag        | 0x35      | 2    | 2        |
| ADDC A, @Ri            | Add indirect RAM to A with carry flag       | 0x36-0x37 | 1    | 2        |
| ADDC A, #data          | Add immediate data to A with carry flag     | 0x34      | 2    | 2        |
| SUBB A, Rn             | Subtract register from A with borrow        | 0x98-0x9F | 1    | 1        |
| SUBB A, direct         | Subtract direct byte from A with borrow     | 0x95      | 2    | 2        |
| SUBB A, @Ri            | Subtract indirect RAM from A with borrow    | 0x96-0x97 | 1    | 2        |
| SUBB A, #data          | Subtract immediate data from A with borrow  | 0x94      | 2    | 2        |
| INC A                  | Increment accumulator                       | 0x04      | 1    | 1        |
| INC Rn                 | Increment register                          | 0x08-0x0F | 1    | 2        |
| INC direct             | Increment direct byte                       | 0x05      | 2    | 3        |
| INC @Ri                | Increment indirect RAM                      | 0x06-0x07 | 1    | 3        |
| DEC A                  | Decrement accumulator                       | 0x14      | 1    | 1        |
| DEC Rn                 | Decrement register                          | 0x18-0x1F | 1    | 2        |
| DEC direct             | Decrement direct byte                       | 0x15      | 2    | 3        |
| DEC @Ri                | Decrement indirect RAM                      | 0x16-0x17 | 1    | 3        |
| INC DPTR               | Increment data pointer                      | 0xA3      | 1    | 4        |
| MUL AB 8 X 8<br>16 X 8 | Multiply A and B                            | 0xA4      | 1    | 11<br>20 |
| DIV AB 8 / 8<br>16 / 8 | Divide A by B                               | 0x84      | 1    | 11<br>20 |
| DA A                   | Decimal adjust accumulator                  | 0xD4      | 1    | 1        |



| Opcode            | Description                                | Code      | Byte | Cycle |
|-------------------|--------------------------------------------|-----------|------|-------|
| ANL A, Rn         | AND register to accumulator                | 0x58-0x5F | 1    | 1     |
| ANL A, direct     | AND direct byte to accumulator             | 0x55      | 2    | 2     |
| ANL A, @Ri        | AND indirect RAM to accumulator            | 0x56-0x57 | 1    | 2     |
| ANL A, #data      | AND immediate data to accumulator          | 0x54      | 2    | 2     |
| ANL direct, A     | AND accumulator to direct byte             | 0x52      | 2    | 3     |
| ANL direct, #data | AND immediate data to direct byte          | 0x53      | 3    | 3     |
| ORL A, Rn         | OR register to accumulator                 | 0x48-0x4F | 1    | 1     |
| ORL A, direct     | OR direct byte to accumulator              | 0x45      | 2    | 2     |
| ORL A, @Ri        | OR indirect RAM to accumulator             | 0x46-0x47 | 1    | 2     |
| ORL A, #data      | OR immediate data to accumulator           | 0x44      | 2    | 2     |
| ORL direct, A     | OR accumulator to direct byte              | 0x42      | 2    | 3     |
| ORL direct, #data | OR immediate data to direct byte           | 0x43      | 3    | 3     |
| XRL A, Rn         | Exclusive OR register to accumulator       | 0x68-0x6F | 1    | 1     |
| XRL A, direct     | Exclusive OR direct byte to accumulator    | 0x65      | 2    | 2     |
| XRL A, @Ri        | Exclusive OR indirect RAM to accumulator   | 0x66-0x67 | 1    | 2     |
| XRL A, #data      | Exclusive OR immediate data to accumulator | 0x64      | 2    | 2     |
| XRL direct, A     | Exclusive OR accumulator to direct byte    | 0x62      | 2    | 3     |
| XRL direct, #data | Exclusive OR immediate data to direct byte | 0x63      | 3    | 3     |
| CLR A             | Clear accumulator                          | 0xE4      | 1    | 1     |
| CPL A             | Complement accumulator                     | 0xF4      | 1    | 1     |
| RL A              | Rotate accumulator left                    | 0x23      | 1    | 1     |
| RLC A             | Rotate accumulator left through carry      | 0x33      | 1    | 1     |
| RR A              | Rotate accumulator right                   | 0x03      | 1    | 1     |
| RRC A             | Rotate accumulator right through carry     | 0x13      | 1    | 1     |
| SWAP A            | Swap nibbles within the accumulator        | 0xC4      | 1    | 4     |



| Opcode               | Description                                   | Code      | Byte | Cycle |
|----------------------|-----------------------------------------------|-----------|------|-------|
| MOV A, Rn            | Move register to accumulator                  | 0xE8-0xEF | 1    | 1     |
| MOV A, direct        | Move direct byte to accumulator               | 0xE5      | 2    | 2     |
| MOV A, @Ri           | Move indirect RAM to accumulator              | 0xE6-0xE7 | 1    | 2     |
| MOV A, #data         | Move immediate data to accumulator            | 0x74      | 2    | 2     |
| MOV Rn, A            | Move accumulator to register                  | 0xF8-0xFF | 1    | 2     |
| MOV Rn, direct       | Move direct byte to register                  | 0xA8-0xAF | 2    | 3     |
| MOV Rn, #data        | Move immediate data to register               | 0x78-0x7F | 2    | 2     |
| MOV direct, A        | Move accumulator to direct byte               | 0xF5      | 2    | 2     |
| MOV direct, Rn       | Move register to direct byte                  | 0x88-0x8F | 2    | 2     |
| MOV direct1, direct2 | Move direct byte to direct byte               | 0x85      | 3    | 3     |
| MOV direct, @Ri      | Move indirect RAM to direct byte              | 0x86-0x87 | 2    | 3     |
| MOV direct, #data    | Move immediate data to direct byte            | 0x75      | 3    | 3     |
| MOV @Ri, A           | Move accumulator to indirect RAM              | 0xF6-0xF7 | 1    | 2     |
| MOV @Ri, direct      | Move direct byte to indirect RAM              | 0xA6-0xA7 | 2    | 3     |
| MOV @Ri, #data       | Move immediate data to indirect RAM           | 0x76-0x77 | 2    | 2     |
| MOV DPTR, #data16    | Load data pointer with a 16-bit constant      | 0x90      | 3    | 3     |
| MOVC A, @A+DPTR      | Move code byte relative to DPTR to A          | 0x93      | 1    | 7     |
| MOVC A, @A+PC        | Move code byte relative to PC to A            | 0x83      | 1    | 8     |
| MOVX A, @Ri          | Move external RAM (8-bit address) to A        | 0xE2-0xE3 | 1    | 5     |
| MOVX A, @DPTR        | Move external RAM (16-bit address) to A       | 0xE0      | 1    | 6     |
| MOVX @Ri, A          | Move A to external RAM (8-bit address)        | 0xF2-F3   | 1    | 4     |
| MOVX @DPTR, A        | Move A to external RAM (16-bit address)       | 0xF0      | 1    | 5     |
| PUSH direct          | Push direct byte onto stack                   | 0xC0      | 2    | 5     |
| POP direct           | Pop direct byte from stack                    | 0xD0      | 2    | 4     |
| XCH A, Rn            | Exchange register with accumulator            | 0xC8-0xCF | 1    | 3     |
| XCH A, direct        | Exchange direct byte with accumulator         | 0xC5      | 2    | 4     |
| XCH A, @Ri           | Exchange indirect RAM with accumulator        | 0xC6-0xC7 | 1    | 4     |
| XCHD A, @Ri          | Exchange low-order nibble indirect RAM with A | 0xD6-0xD7 | 1    | 4     |



| Opcode              | e                         | Description                                     | Code      | Byte | Cycle  |
|---------------------|---------------------------|-------------------------------------------------|-----------|------|--------|
| ACALL addr11        |                           | Absolute subroutine call                        | 0x11-0xF1 | 2    | 7      |
| LCALL addr16        |                           | Long subroutine call                            | 0x12      | 3    | 7      |
| RET                 |                           | Return from subroutine                          | 0x22      | 1    | 8      |
| RETI                |                           | Return from interrupt                           | 0x32      | 1    | 8      |
| AJMP addr11         |                           | Absolute jump                                   | 0x01-0xE1 | 2    | 4      |
| LJMP addr16         |                           | Long jump                                       | 0x02      | 3    | 5      |
| SJMP rel            |                           | Short jump (relative address)                   | 0x80      | 2    | 4      |
| JMP @A+DPTR         |                           | Jump indirect relative to the DPTR              | 0x73      | 1    | 6      |
| JZ rel              | (not taken)<br>(taken)    | Jump if accumulator is zero                     | 0x60      | 2    | 3<br>5 |
| JNZ rel             | (not taken)<br>(taken)    | Jump if accumulator is not zero                 | 0x70      | 2    | 3<br>5 |
| JC rel              | (not taken)<br>(taken)    | Jump if carry flag is set                       | 0x40      | 2    | 2<br>4 |
| JNC rel             | (not taken)<br>(taken)    | Jump if carry flag is not set                   | 0x50      | 2    | 2<br>4 |
| JB bit, rel         | (not taken)<br>(taken)    | Jump if direct bit is set                       | 0x20      | 3    | 4<br>6 |
| JNB bit, rel        | (not taken)<br>(taken)    | Jump if direct bit is not set                   | 0x30      | 3    | 4<br>6 |
| JBC bit, rel        | (not taken)<br>(taken)    | Jump if direct bit is set and clear bit         | 0x10      | 3    | 4<br>6 |
| CJNE A, direct, rel | (not taken)<br>(taken)    | Compare direct byte to A and jump if not equal  | 0xB5      | 3    | 4<br>6 |
| CJNE A, #data, rel  | (not taken)<br>(taken)    | Compare immediate to A and jump if not equal    | 0xB4      | 3    | 4<br>6 |
| CJNE Rn, #data, rel | (not taken)<br>(taken)    | Compare immediate to reg. and jump if not equal | 0xB8-0xBF | 3    | 4<br>6 |
| CJNE @Ri, #data, re | el (not taken)<br>(taken) | Compare immediate to Ri and jump if not equal   | 0xB6-0xB7 | 3    | 4<br>6 |
| DJNZ Rn, rel        | (not taken)<br>(taken)    | Decrement register and jump if not zero         | 0xD8-0xDF | 2    | 3<br>5 |
| DJNZ direct, rel    | (not taken)<br>(taken)    | Decrement direct byte and jump if not zero      | 0xD5      | 3    | 4<br>6 |
| NOP                 |                           | No operation                                    | 0         | 1    | 1      |



| Opcode      | Description                           | Code | Byte | Cycle |
|-------------|---------------------------------------|------|------|-------|
| CLR C       | Clear carry flag                      | 0xC3 | 1    | 1     |
| CLR bit     | Clear direct bit                      | 0xC2 | 2    | 3     |
| SETB C      | Set carry flag                        | 0xD3 | 1    | 1     |
| SETB bit    | Set direct bit                        | 0xD2 | 2    | 3     |
| CPL C       | Complement carry flag                 | 0xB3 | 1    | 1     |
| CPL bit     | Complement direct bit                 | 0xB2 | 2    | 3     |
| ANL C, bit  | AND direct bit to carry flag          | 0x82 | 2    | 2     |
| ANL C, /bit | AND complement of direct bit to carry | 0xB0 | 2    | 2     |
| ORL C, bit  | OR direct bit to carry flag           | 0x72 | 2    | 2     |
| ORL C, /bit | OR complement of direct bit to carry  | 0xA0 | 2    | 2     |
| MOV C, bit  | Move direct bit to carry flag         | 0xA2 | 2    | 2     |
| MOV bit, C  | Move carry flag to direct bit         | 0x92 | 2    | 3     |



### **10. Electrical Characteristics**

| Absolute | Maximum | Ratings* |
|----------|---------|----------|
|----------|---------|----------|

| DC Supply Voltage0.3V to +6.0V                               |  |
|--------------------------------------------------------------|--|
| Input/Output Voltage GND-0.3V to $V_{\text{DD}}\text{+}0.3V$ |  |
| Operating Ambient Temperature40℃ to +85℃                     |  |
| Storage Temperature                                          |  |
| FLASH write/erase operating 0°C to +85°C                     |  |
|                                                              |  |

#### \*Comments

Stresses exceed those listed under "**Absolute Maximum Ratings**" may cause permanent damage to this device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied or intended. Exposure to the absolute maximum rating conditions for extended periods may affect device reliability.

| DC Electrical Characteristics (\ | $V_{DD} = 2.0V - 5.5V, GND =$ | : 0V, T <sub>A</sub> = +25°C, unless | otherwise specified) |
|----------------------------------|-------------------------------|--------------------------------------|----------------------|
|----------------------------------|-------------------------------|--------------------------------------|----------------------|

| Parameter                  | Symbol           | Min.                          | Тур.* | Max.                          | Unit | Condition                                                                                                                                                                                  |
|----------------------------|------------------|-------------------------------|-------|-------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operating Voltage          | V <sub>DD</sub>  | 2.0                           | 5.0   | 5.5                           | V    | $2MHz \leq f_{OSC} \leq 12MHz$                                                                                                                                                             |
| Operating Current          | I <sub>OP</sub>  | -                             | 5     | 10                            | mA   | $f_{OSC}$ = 12MHz, $V_{DD}$ = 5.0V<br>All output pins unload (including all digital input<br>pins unfloating)<br>CPU on (execute NOP instruction), WDT on, all<br>other function block off |
| Stand by Current<br>(IDLE) | I <sub>SB1</sub> | -                             | 3     | 5                             | mA   | $f_{OSC}$ = 12MHz, $V_{DD}$ = 5.0V<br>All output pins unload, CPU off (IDLE),<br>all digital input pins unfloating<br>LVR on, WDT off, all other function block off                        |
| Stand by Current           | I <sub>SB2</sub> | -                             | 2     | 10                            | uA   | Osc off, $V_{DD} = 5.0V$<br>All output pins unload (including all digital input<br>pins unfloating)<br>CPU off (Power-Down),<br>LVR on, WDT off, all other function block off              |
| (Power-Down)               | I <sub>SB3</sub> | -                             | 1.5   | 6                             | uA   | Osc off, $V_{DD} = 3.0V$<br>All output pins unload (including all digital input<br>pins unfloating)<br>CPU off (Power-Down),<br>LVR on, WDT off, all other function block off              |
| WDT Current                | I <sub>WDT</sub> | -                             | 1     | 3                             | μA   | All output pins unload, WDT on, $V_{DD} = 5.0V$                                                                                                                                            |
| LPD Current                | I <sub>LPD</sub> | -                             | -     | 1                             | μA   | V <sub>DD</sub> = 2.0 - 5.5V                                                                                                                                                               |
| Input Low Voltage 1        | V <sub>IL1</sub> | GND                           | -     | $0.3 \text{ V}_{\text{DD}}$   | V    | I/O Ports, RXD (RxCON[1:0] = 11)                                                                                                                                                           |
| Input High Voltage 1       | V <sub>IH1</sub> | $0.7 \text{ X V}_{\text{DD}}$ | -     | V <sub>DD</sub>               | V    | I/O Ports                                                                                                                                                                                  |
|                            |                  | GND                           | -     | 0.2 X V <sub>DD</sub>         | V    | RST, T3, T4, RXD (RxCON[1:0] = 00), FLT,<br>INT2/3/4, V <sub>DD</sub> = 2.4 - 5.5V                                                                                                         |
| Input Low Voltage 2        | $V_{IL2}$        | GND                           | -     | $0.4 \text{ X V}_{\text{DD}}$ | V    | RXD (RxCON[1:0] = 01), V <sub>DD</sub> = 2.4 - 5.5V                                                                                                                                        |
|                            |                  | GND                           | -     | $0.5 \ X \ V_{DD}$            | V    | RXD (RxCON[1:0] = 10), V <sub>DD</sub> = 2.4 - 5.5V                                                                                                                                        |
| Input High Voltage 2       | V <sub>IH2</sub> | 0.8 X V <sub>DD</sub>         | -     | V <sub>DD</sub>               | V    | RST, T3, T4, INT2/3/4, RXD, FLT, V <sub>DD</sub> = 2.4 - 5.5V                                                                                                                              |
| Reset pin pull-up resistor | R <sub>RPH</sub> | -                             | 30    | -                             | kΩ   | $V_{DD}$ = 5.0V, $V_{IN}$ = GND                                                                                                                                                            |
| Pull-up resistor           | R <sub>PH</sub>  | -                             | 30    | -                             | kΩ   | $V_{\text{DD}} = 5.0V,  V_{\text{IN}} = GND$                                                                                                                                               |

(to be continued)



(continue)

| Parameter                                | Symbol           | Min.                  | Тур.* | Max.      | Unit | Condition                                                                                                                      |
|------------------------------------------|------------------|-----------------------|-------|-----------|------|--------------------------------------------------------------------------------------------------------------------------------|
| Output High Voltage1                     | V <sub>OH1</sub> | V <sub>DD</sub> - 0.7 | -     | -         | V    | I/O port (P3), $I_{OH}$ = -10mA, $V_{DD}$ = 5.0V                                                                               |
| Output High Voltage2                     | V <sub>OH2</sub> | V <sub>DD</sub> - 0.7 | -     | -         | V    | I/O ports (P0, P1, P2, P4, P5),<br>$I_{OH}$ = -10mA, $V_{DD}$ = 5.0V, OP_PORTDRIVE select<br>normal mode (Code Option)         |
| Output High Voltage3                     | V <sub>OH3</sub> | V <sub>DD</sub> - 0.7 | -     | -         | V    | I/O ports (P0, P1, P2, P4, P5),<br>$I_{OH}$ = -20mA, $V_{DD}$ = 5.0V, OP_PORTDRIVE select<br>large mode (Code Option)          |
| Output Low Voltage1                      | V <sub>OL1</sub> | -                     | -     | GND + 0.6 | V    | I/O Ports, (P0, P1, P2, P4, P5)<br>I <sub>OH</sub> = -10mA, V <sub>DD</sub> = 5.0V                                             |
| Output Low Voltage2                      | V <sub>OL2</sub> | -                     | -     | GND + 0.6 | V    | I/O ports (P3), $I_{OH}$ = 15mA, $V_{DD}$ = 5.0V<br>OP_P3.3-P3.0 and OP_P3.7-P3.4 both select<br>normal mode (Code Option)     |
| large drive port sink current capability | I <sub>OL</sub>  | 120                   | 140   | -         | mA   | I/O port (P3), $V_{DD}$ = 5.0V, $V_{OL}$ = GND + 1.5V<br>OP_P3.3-P3.0 and OP_P3.7-P3.4 both select<br>large mode (Code Option) |

#### Note:

(1) "\*" Indicates that the typical value is measured at 5.0V, 25°C, unless otherwise noted. (2) maximum current value flowing through  $V_{DD}$  5.0V, 25°C must be less than 150mA. (3) maximum current value flowing through GND 5.0V, 25°C must be less than 200mA.

| Parameter                                            | Symbol            | Min. | Тур. | Max.      | Unit            | Condition                                          |
|------------------------------------------------------|-------------------|------|------|-----------|-----------------|----------------------------------------------------|
| Supply Voltage                                       | V <sub>AD</sub>   | 2.5  | 3    | 3.5       | V               |                                                    |
| Resolution                                           | N <sub>R</sub>    | -    | 10   | -         | bit             | $GND \leq V_{AIN} \leq V_{REF}$                    |
| A/D Input Voltage                                    | V <sub>AIN</sub>  | GND  | -    | $V_{REF}$ | V               |                                                    |
| A/D Input Resistor*                                  | RAIN              | 2    | -    | -         | MΩ              | V <sub>IN</sub> = 3.0V                             |
| Recommended<br>impedance of analog<br>voltage source | Z <sub>AIN</sub>  | -    | -    | 10        | kΩ              |                                                    |
| A/D conversion current                               | I <sub>AD</sub>   | -    | 1    | 3         | mA              | ADC module operating, $V_{DD}$ = 3.0V              |
| A/D Input current                                    | I <sub>ADIN</sub> | -    | -    | 10        | μΑ              | $V_{DD} = 3.0 V$                                   |
| Differential linearity error                         | D <sub>LE</sub>   | -    | -    | ±1        | LSB             | $f_{OSC} = 12MHz, V_{DD} = 3.0V$                   |
| Integral linearity error                             | I <sub>LE</sub>   | -    | -    | ±2        | LSB             | $f_{OSC} = 12MHz, V_{DD} = 3.0V$                   |
| Full scale error                                     | E <sub>F</sub>    | -    | ±1   | ±3        | LSB             | $f_{OSC} = 12MHz, V_{DD} = 3.0V$                   |
| Offset error                                         | Ez                | -    | ±0.5 | ±3        | LSB             | $f_{OSC} = 12MHz, V_{DD} = 3.0V$                   |
| Total Absolute error                                 | E <sub>AD</sub>   | -    | -    | ±3        | LSB             | $f_{OSC} = 12MHz, V_{DD} = 3.0V$                   |
| Total Conversion time**                              | T <sub>CON</sub>  | 14   | -    | -         | t <sub>AD</sub> | 10 bit Resolution, $V_{DD}$ = 3.0V, $t_{AD}$ = 1µs |

#### Note:

(1) "\*" Here the A/D input Resistor is the DC input-resistance of A/D itself.
(2) "\*\*" Recommendations ADC connected signal source resistance of less than10kΩ.



| Parameter                   | Symbol                    | Min. | Тур. | Max. | Unit | Condition                                                                               |
|-----------------------------|---------------------------|------|------|------|------|-----------------------------------------------------------------------------------------|
| Oscillator start time       | T <sub>OSC</sub>          | -    | 1    | 2    | ms   | f <sub>OSC</sub> = 12MHz                                                                |
| RESET pulse width           | t <sub>RESET</sub>        | 10   | -    | -    | μS   |                                                                                         |
| WDT RC Frequency            | $f_{WDT}$                 | -    | 2    | 3    | kHz  |                                                                                         |
| Frequency Stability<br>(RC) | ∆F /F<br>T <sub>osc</sub> | -    | ±1   | ±2   | %    | RC oscillator:<br> F - 12MHz /12MHz ( $V_{DD}$ = 2.0 - 5.0V,<br>$T_A$ = -40°C to +85°C) |
| , ,                         | 0000                      | -    | 1    | 2    | ms   | f <sub>OSC</sub> = 12MHz                                                                |

### AC Electrical Characteristics (V<sub>DD</sub> = 2.0V - 5.5V, GND = 0V, T<sub>A</sub> = +25°C, f<sub>OSC</sub> = 12MHz, unless otherwise specified)

# Low Voltage Reset Electrical Characteristics ( $V_{DD}$ = 2.0V - 5.5V, GND = 0V, $T_A$ = +25°C, unless otherwise specified)

| Parameter                        | Symbol           | Min. | Тур. | Max. | Unit | Condition                         |
|----------------------------------|------------------|------|------|------|------|-----------------------------------|
| LVR Voltage1                     | $V_{LVR1}$       | 4.2  | 4.3  | 4.4  | V    | LVR Enable $V_{DD} = 2.0V - 5.5V$ |
| LVR Voltage2                     | $V_{LVR2}$       | 2.0  | 2.1  | 2.2  | V    | LVR Enable $V_{DD} = 2.0V - 5.5V$ |
| Drop-Down Pulse<br>Width for LVR | T <sub>LVR</sub> | -    | 60   | -    | μS   |                                   |

#### **12MHz crystal Electrical Characteristics**

| Parameter | Symbol           | Min. | Тур. | Max. | Unit | Condition |
|-----------|------------------|------|------|------|------|-----------|
| Frequency | F <sub>12M</sub> | -    | 12   | -    | MHz  |           |
| Capacitor | CL               | -    | 12.5 | -    | pF   |           |



# 11. Ordering Information

| Part No.         | Package |
|------------------|---------|
| SH79F1616P/032PR | LQFP32  |

# SH79F1616

# 12. Package Information LQFP32 Outline Dimensions

### unit: inch/mm

<u>H</u>₀ D 32 1 🛄  $\oplus$ 24 뿐 ш 8 💷 17 ▶ **b** 16 9 ; e; E c . ₩ L See Detail F Ą DETAIL F

| Symbol         | Dimension | s in inches | Dimensio | ns in mm |  |
|----------------|-----------|-------------|----------|----------|--|
| Symbol         | MIN       | MAX         | MIN      | MAX      |  |
| А              | 0.057     | 0.065       | 1.45     | 1.65     |  |
| A1             | 0.000     | 0.008       | 0.01     | 0.21     |  |
| A2             | 0.051     | 0.059       | 1.30     | 1.50     |  |
| D              | 0.268     | 0.281       | 6.80     | 7.15     |  |
| E              | 0.268     | 0.281       | 6.80     | 7.15     |  |
| H <sub>D</sub> | 0.346     | 0.362       | 8.80     | 9.20     |  |
| H <sub>E</sub> | 0.346     | 0.362       | 8.80     | 9.20     |  |
| b              | 0.010     | 0.017       | 0.25     | 0.44     |  |
| е              | 0.031     | TYP         | 0.8TYP   |          |  |
| с              | 0.005     | 5 TYP       | 0.127    | ΤΥΡ      |  |
| L              | 0.016     | 0.031       | 0.40     | 0.78     |  |
| L1             | 0.035     | 0.043       | 0.90     | 1.10     |  |
| θ              | 0 °       | 10°         | 0°       | 10°      |  |



# 13. Product SPEC. Change Notice

| Version | Content                    | Date      |
|---------|----------------------------|-----------|
| 2.2     | Update Package Information | Jul. 2015 |
| 2.1     | Original                   | May. 2014 |



# Content

| 1.  | FEATURES                                |    |
|-----|-----------------------------------------|----|
| 2.  | GENERAL DESCRIPTION                     | 1  |
| 3.  | BLOCK DIAGRAM                           | 2  |
| 4.  | PIN CONFIGURATION                       | 3  |
| 5.  | PIN DESCRIPTION                         | 4  |
| 6.  | SFR MAPPING                             |    |
| 7.  | NORMAL FUNCTION                         |    |
|     | CPU                                     |    |
|     | .1.1 CPU Core SFR                       |    |
|     | 1.2 Enhanced CPU Core SFRs              |    |
|     | 1.3 Register                            |    |
|     | RAM                                     |    |
|     |                                         |    |
|     | 2.1 Features                            |    |
|     | FLASH PROGRAM MEMORY                    |    |
|     | .3.1 Features                           |    |
|     | .3.2 Flash Operation in ICP Mode        |    |
|     | SSP FUNCTION                            |    |
|     | .4.1 SSP Register                       |    |
|     | .4.2 Flash Control Flow                 |    |
| 7   | .4.3 SSP Programming Notice             | 24 |
| 7.5 | System Clock and Oscillator             | 25 |
| 7   | 5.1 Features                            | 25 |
|     | .5.2 Clock Definition                   |    |
|     | 5.3 Description                         |    |
|     | . 5.4 Register                          |    |
|     | .5.5 Oscillator Type                    |    |
|     | .5.6 Capacitor Selection for Oscillator |    |
|     | System Clock Monitor (SCM)              |    |
|     | I/O Port                                |    |
|     |                                         |    |
|     | 7.1 Features                            |    |
|     | .7.2 Register                           |    |
|     | .7.3 Port Diagram                       |    |
|     | .7.4 Port Share                         |    |
|     | TIMER                                   |    |
| 7   | .8.1 Features                           | 32 |
| 7   | .8.2 Timer2                             | 32 |
| 7   | .8.3 Timer3                             | 36 |
| 7   | .8.4 Timer4                             | 38 |
|     | .8.5 Timer5                             |    |
|     | INTERRUPT                               |    |
|     | 9.1 Feature                             |    |
|     | .9.2 Interrupt Enable Control           |    |
|     | .9.3 Register                           |    |
|     | .9.4 Interrupt Flag                     |    |
|     | .9.5 Interrupt Vector                   |    |
|     | 1                                       |    |
|     | .9.6 Interrupt Priority                 |    |
|     | .9.7 Interrupt Handling                 |    |
|     | .9.8 Interrupt Response Time            |    |
|     | .9.9 External Interrupt Inputs          |    |
|     | .9.10 Interrupt Summary                 |    |
| 8.  | ENHANCED FUNCTION                       |    |
| 8.1 | NORMAL RESISTOR LCD DRIVER              | 50 |
| 8   | .1.1 Registers                          | 53 |
| 8   | 1.2 Configuration of LCD RAM            | 56 |
| 8.2 | LED DRIVER                              | 57 |
|     | 2.1 Register                            |    |
|     | .2.2 Configuration of LED RAM           |    |
|     | PWM (Pulse Width Modulation)            |    |
|     | 3.1 Feature                             |    |
|     | 3.2 PWM Module Enable                   |    |
| 0   |                                         | 00 |



# SH79F1616

| 8.3.3 PWM Timer Lock Register            |     |
|------------------------------------------|-----|
| 8.3.4 12-bit PWM Timer                   |     |
| 8.3.5 PWM01                              |     |
| 8.3.6 Dead Time                          |     |
| 8.4 EUART                                |     |
| 8.4.1 Feature                            |     |
| 8.4.2 EUART Mode Description             |     |
| 8.4.3 Baud Rate Generate                 |     |
| 8.4.4 Multi-Processor Communication      |     |
| 8.4.5 Error Detection                    |     |
| 8.4.6 Register                           |     |
| 8.5 ANALOG DIGITAL CONVERTER (ADC)       | 76  |
| 8.5.1 Feature                            |     |
| 8.5.2 ADC Diagram                        |     |
| 8.5.3 ADC Register                       |     |
| 8.6 BUZZER                               |     |
| 8.6.1 Feature                            |     |
| 8.6.2 Register                           |     |
| 8.7 Low Power Detect (LPD)               |     |
| 8.7.1 Feature                            |     |
| 8.7.2 Register                           |     |
| 8.8 LOW VOLTAGE RESET (LVR)              |     |
| 8.8.1 Feature                            |     |
| 8.9 WATCHDOG TIMER (WDT) AND RESET STATE |     |
| 8.9.1 Feature                            |     |
| 8.9.2 Register                           |     |
| 8.10 Power Management                    |     |
| 8.10.1 Feature                           |     |
| 8.10.2 Idle Mode                         |     |
| 8.10.3 Power-Down Mode                   |     |
| 8.10.4 Register                          |     |
| 8.11 WARM-UP TIMER                       |     |
| 8.11.1 Feature                           |     |
| 8.12 CODE OPTION                         |     |
| 8.13 Programming Note                    |     |
| 9. INSTRUCTION SET                       |     |
| 10. ELECTRICAL CHARACTERISTICS           |     |
| 11. ORDERING INFORMATION                 |     |
| 12. PACKAGE INFORMATION                  |     |
| 13. PRODUCT SPEC. CHANGE NOTICE          | 100 |