

# CMOS 16-BIT SINGLE CHIP MICROCONTROLLER S1C17702 Technical Manual

#### NOTICE

No part of this material may be reproduced or duplicated in any form or by any means without the written permission of Seiko Epson. Seiko Epson reserves the right to make changes to this material without notice. Seiko Epson does not assume any liability of any kind arising out of any inaccuracies contained in this material or due to its application or use in any product or circuit and, further, there is no representation that this material is applicable to products requiring high level reliability, such as medical products. Moreover, no license to any intellectual property rights is granted by implication or otherwise, and there is no representation or warranty that anything made in accordance with this material will be free from any patent or copyright infringement of a third party. This material or portions thereof may contain technology or the subject relating to strategic products under the control of the Foreign Exchange and Foreign Trade Law of Japan and may require an export license from the Ministry of Economy, Trade and Industry or other approval from another government agency.

This product uses SuperFlash® technology licensed from Silicon Storage Technology, Inc. All brands or product names mentioned herein are trademarks and/or registered trademarks of their respective companies.

### Configuration of product number



| 1 | Overview                                                              | 1-1  |
|---|-----------------------------------------------------------------------|------|
|   | 1.1 Features                                                          | 1-2  |
|   | 1.2 Block Diagram                                                     | 1-4  |
|   | 1.3 Pins                                                              | 1-5  |
|   | 1.3.1 Pinout Diagram                                                  | 1-5  |
|   | 1.3.2 Pin Descriptions                                                | 1-10 |
| 2 | CPU                                                                   | 2-1  |
|   | 2.1 S1C17 Core Features                                               | 2-1  |
|   | 2.2 CPU Registers                                                     | 2-2  |
|   | 2.3 Instruction Set                                                   | 2-3  |
|   | 2.4 Vector Table                                                      | 2-7  |
|   | 2.5 PSR Readout                                                       | 2-9  |
|   | 2.6 Processor Information                                             | 2-10 |
| 2 | Memory Map and Bus Control                                            | 2_1  |
| 3 | 3.1 Bus Cycle                                                         |      |
|   | 3.1.1 Access Size Restrictions                                        |      |
|   | 3.1.2 Instruction Execution Cycle Restrictions                        |      |
|   | 3.2 Flash Area                                                        |      |
|   | 3.2.1 Internal Flash Memory                                           |      |
|   | 3.2.2 Flash Memory Programming                                        |      |
|   | 3.2.3 Protect Bits                                                    | 3-3  |
|   | 0x27ffc-0x27ffe: Flash Protect Bits                                   |      |
|   | 3.2.4 Flash Controller Access Control                                 |      |
|   | 0x5320: FLASHC/SRAMC Control Register (MISC_FL)                       |      |
|   | 3.3 Internal RAM Area                                                 |      |
|   | 3.3.1 Internal RAM<br>0x5326: IRAM Size Select Register (MISC_IRAMSZ) |      |
|   | 3.4 Display RAM Area                                                  |      |
|   | 3.4.1 Display RAM                                                     |      |
|   | 3.4.2 SRAM Controller Access Control                                  |      |
|   | 0x5320: FLASHC/SRAMC Control Register (MISC_FL)                       | 3-6  |
|   | 3.5 Internal Peripheral Circuit Area                                  |      |
|   | 3.5.1 Internal Peripheral Circuit Area 1 (0x4000 onward)              |      |
|   | 3.5.2 Internal Peripheral Circuit Area 2 (0x5000 onward)              |      |
|   | 3.5.3 I/O Map                                                         |      |
|   | 3.6 Core I/O Reserved Area                                            | 3-12 |
| 4 | Power Supply                                                          | 4-1  |
|   | 4.1 Power Supply Voltage                                              | 4-1  |
|   | 4.2 Internal Power Supply Circuit                                     | 4-2  |
|   | 4.3 Power Supply Circuit Control                                      | 4-3  |
|   | 4.4 Heavy Load Protection Function                                    | 4-5  |
|   | 4.5 Control Register Details                                          | 4-6  |
|   | 0x5120: VD1 Control Register (VD1_CTL)                                |      |
|   | 0x50a3: LCD Voltage Regulator Control Register (LCD_VREG)             |      |
|   | 0x50a4: LCD Power Voltage Booster Control Register (LCD_PWR)          |      |
|   | 4.6 Precautions                                                       | 4-10 |

| 5  | Initial Reset                                                                                           | 5-1                       |
|----|---------------------------------------------------------------------------------------------------------|---------------------------|
|    | 5.1 Initial Reset Factors                                                                               |                           |
|    | 5.1.1 #RESET pin                                                                                        |                           |
|    | 5.1.2 P0 Port Key-Entry Reset                                                                           |                           |
|    | 5.1.3 Reset by Watchdog Timer                                                                           | 5-2                       |
|    | 5.2 Initial Reset Sequence                                                                              | 5-3                       |
|    | 5.3 Initial Settings at Initial Resetting                                                               | 5-4                       |
| 6  | Interrupt Controller                                                                                    | 6-1                       |
|    | 6.1 ITC Configuration                                                                                   | 6-1                       |
|    | 6.2 Vector Table                                                                                        | 6-2                       |
|    | 6.3 Maskable Interrupt Control                                                                          |                           |
|    | 6.3.1 Peripheral Module Interrupt Control Bit                                                           |                           |
|    | 6.3.2 ITC Interrupt Request Processing                                                                  |                           |
|    | 6.3.3 S1C17 Core Interrupt Processing                                                                   |                           |
|    | 6.4 NMI                                                                                                 |                           |
|    | 6.5 Software Interrupts                                                                                 |                           |
|    | 6.6 HALT and SLEEP Mode Cancellation                                                                    |                           |
|    |                                                                                                         |                           |
|    | 6.7 Control Register Details<br>0x4306: Interrupt Level Setup Register 0 (ITC_LV0)                      |                           |
|    | 0x4308: Interrupt Level Setup Register 0 (TC_LV0)<br>0x4308: Interrupt Level Setup Register 1 (ITC_LV1) |                           |
|    | 0x430a: Interrupt Level Setup Register 2 (ITC_LV2)                                                      |                           |
|    | 0x430c: Interrupt Level Setup Register 3 (ITC_LV3)                                                      |                           |
|    | 0x430e: Interrupt Level Setup Register 4 (ITC_LV4)                                                      |                           |
|    | 0x4310: Interrupt Level Setup Register 5 (ITC_LV5)                                                      |                           |
|    | 0x4312: Interrupt Level Setup Register 6 (ITC_LV6)                                                      |                           |
|    | 0x4314: Interrupt Level Setup Register 7 (ITC_LV7)                                                      |                           |
|    | 0x4316: Interrupt Level Setup Register 8 (ITC_LV8)<br>6.8 Precautions                                   |                           |
| _  |                                                                                                         |                           |
| 7  | Oscillator Circuit (OSC)                                                                                |                           |
|    | 7.1 OSC Module Configuration                                                                            |                           |
|    | 7.2 IOSC Oscillator Circuit                                                                             | 7-2                       |
|    | 7.3 OSC3 Oscillator Circuit                                                                             | 7-3                       |
|    | 7.4 OSC1 Oscillator Circuit                                                                             | 7-4                       |
|    | 7.5 System Clock Switching                                                                              | 7-5                       |
|    | 7.5.1 High-speed Clock (HSCLK) Selection                                                                |                           |
|    | 7.5.2 System Clock (OSC1 or HSCLK) Selection                                                            |                           |
|    | 7.6 LCD Clock Control                                                                                   |                           |
|    | 7.7 8-bit OSC1 Timer Clock Control                                                                      |                           |
|    | 7.8 Clock External Output (FOUTH, FOUT1)                                                                |                           |
|    | 7.9 RESET and NMI Input Noise Filters                                                                   |                           |
|    | ·                                                                                                       |                           |
|    | 7.10 Control Register Details<br>0x5060: Clock Source Select Register (OSC_SRC)                         |                           |
|    | 0x5061: Oscillation Control Register (OSC_SRC)                                                          |                           |
|    | 0x5062: Noise Filter Enable Register (OSC_NFEN)                                                         |                           |
|    | 0x5063: LCD Clock Setup Register (OSC_LCLK)                                                             |                           |
|    | 0x5064: FOUT Control Register (OSC_FOUT)                                                                |                           |
|    | 0x5065: T8OSC1 Clock Control Register (OSC_T8OSC1)                                                      |                           |
|    | 7.11 Precautions                                                                                        | 7-19                      |
| 8  | Clock Generator (CLG)                                                                                   | 8-1                       |
|    | 8.1 Clock Generator Configuration                                                                       |                           |
|    | 8.2 CPU Core Clock (CCLK) Control                                                                       |                           |
| ii | Seiko Epson Corporation                                                                                 | S1C17702 TECHNICAL MANUAL |
|    |                                                                                                         |                           |

| 8.3 Peripheral Module Clock (PCLK) Control                                                                                                                                        | 8-3   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 8.4 Control Register Details                                                                                                                                                      |       |
| 0x5080: PCLK Control Register (CLG_PCLK)                                                                                                                                          |       |
| 0x5081: CCLK Control Register (CLG_CCLK)                                                                                                                                          |       |
| 8.5 Precautions                                                                                                                                                                   | 8-7   |
| 9 Prescaler (PSC)                                                                                                                                                                 | 9-1   |
| 9.1 Prescaler Configuration                                                                                                                                                       |       |
| 9.2 Control Register Details                                                                                                                                                      |       |
| 0x4020: Prescaler Control Register (PSC_CTL)                                                                                                                                      |       |
| 9.3 Precautions                                                                                                                                                                   |       |
| 10 Input/Output Port (P)                                                                                                                                                          | 10-1  |
| 10.1 Input/Output Port Configuration                                                                                                                                              |       |
| 10.2 Input/Output Pin Function Selection (Port MUX)                                                                                                                               |       |
|                                                                                                                                                                                   |       |
| 10.3 Data Input/Output                                                                                                                                                            |       |
| 10.4 Pull-up Control                                                                                                                                                              |       |
| 10.5 Input Interface Level                                                                                                                                                        |       |
| 10.6 P0 and P1 Port Chattering Filter Function                                                                                                                                    |       |
| 10.7 Port Input Interrupt                                                                                                                                                         |       |
| 10.8 Control Register Details                                                                                                                                                     |       |
| 0x5200/0x5210/0x5220/0x5230: Px Port Input Data Registers (Px_IN)                                                                                                                 |       |
| 0x5201/0x5211/0x5221/0x5231: Px Port Output Data Registers (Px_OUT)                                                                                                               |       |
| 0x5202/0x5212/0x5222/0x5232: P <i>x</i> Port Output Enable Registers (P <i>x</i> _OEN)<br>0x5203/0x5213/0x5223/0x5233: P <i>x</i> Port Pull-up Control Registers (P <i>x</i> _PU) |       |
| 0x5204/0x5214/0x5224/0x5234: Px Port Schmitt Trigger Control Registers (Px_SM)                                                                                                    |       |
| 0x5205/5215: Px Port Interrupt Mask Registers (Px_IMSK)                                                                                                                           |       |
| 0x5206/5216: Px Port Interrupt Edge Select Registers (Px_EDGE)                                                                                                                    |       |
| 0x5207/5217: Px Port Interrupt Flag Registers (Px_IFLG)                                                                                                                           |       |
| 0x5208/0x5218: Px Port Chattering Filter Control Register (Px_CHAT)                                                                                                               |       |
| 0x5209: P0 Port Key-Entry Reset Configuration Register (P0_KRST)<br>0x520a/0x521a/0x522a/0x523a: Px Port Input Enable Registers (Px_IEN)                                          |       |
| 0x52a0: P0 Port Function Select Register (P0_PMUX)                                                                                                                                |       |
| 0x52a1: P1 Port Function Select Register (P1_PMUX)                                                                                                                                |       |
| 0x52a2: P2 Port Function Select Register (P2_PMUX)                                                                                                                                |       |
| 0x52a3: P3 Port Function Select Register (P3_PMUX)                                                                                                                                | 10-26 |
| 10.9 Precautions                                                                                                                                                                  | 10-27 |
| 11 16-bit Timer (T16)                                                                                                                                                             | 11-1  |
| 11.1 16-bit Timer Overview                                                                                                                                                        |       |
| 11.2 16-bit Timer Operating Modes                                                                                                                                                 |       |
| 11.2.1 Internal Clock Mode                                                                                                                                                        |       |
| 11.2.2 External Clock Mode                                                                                                                                                        |       |
| 11.2.3 Pulse Width Measurement Mode                                                                                                                                               |       |
| 11.3 Count Mode                                                                                                                                                                   |       |
| 11.4 16-bit Timer Reload Register and Underflow Cycle                                                                                                                             |       |
| 11.5 16-bit Timer Reset                                                                                                                                                           |       |
| 11.6 16-bit Timer RUN/STOP Control                                                                                                                                                |       |
| 11.7 16-bit Timer Output Signal                                                                                                                                                   |       |
|                                                                                                                                                                                   |       |
| 11.8 16-bit Timer Interrupts                                                                                                                                                      |       |
| 11.9 Control Register Details<br>0x4220/0x4240/0x4260: 16-bit Timer Ch.x Input Clock Select Registers (T16_CLKx)                                                                  |       |
| 0x4222/0x4242/0x4262: 16-bit Timer Ch.x Reload Data Registers (T16_TRx)                                                                                                           |       |
| 0x4224/0x4244/0x4264: 16-bit Timer Ch.x Counter Data Registers (T16_TCx)                                                                                                          |       |

|    | 0x4226/0x4246/0x4266: 16-bit Timer Ch.x Control Registers (T16_CTLx)                                                                                                   |       |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|    | 0x4228/0x4248/0x4268: 16-bit Timer Ch.x Interrupt Control Registers (T16_INTx)                                                                                         |       |
|    | 11.10 Precautions                                                                                                                                                      | 11-18 |
| 12 | 8-bit Timer (T8F)                                                                                                                                                      | 12-1  |
|    | 12.1 8-bit Timer Overview                                                                                                                                              | 12-1  |
|    | 12.2 8-bit Timer Count Mode                                                                                                                                            | 12-2  |
|    | 12.3 Count Clock                                                                                                                                                       | 12-3  |
|    | 12.4 8-bit Timer Reload Register and Underflow Cycle                                                                                                                   | 12-4  |
|    | 12.5 8-bit Timer Reset                                                                                                                                                 |       |
|    | 12.6 8-bit Timer RUN/STOP Control                                                                                                                                      |       |
|    | 12.7 8-bit Timer Output Signal                                                                                                                                         | 12-7  |
|    | 12.8 Fine Mode                                                                                                                                                         |       |
|    | 12.9 8-bit Timer Interrupts                                                                                                                                            |       |
|    | 12.10 Control Register Details                                                                                                                                         |       |
|    | 0x4200/0x4280: 8-bit Timer Ch.x Input Clock Select Register (T8F_CLKx)                                                                                                 |       |
|    | 0x4202/0x4282: 8-bit Timer Ch.x Reload Data Register (T8F_TRx)                                                                                                         |       |
|    | 0x4204/0x4284: 8-bit Timer Ch.x Counter Data Register (T8F_TCx)                                                                                                        |       |
|    | 0x4206/0x4286: 8-bit Timer Ch. <i>x</i> Control Register (T8F_CTL <i>x</i> )<br>0x4208/0x4288: 8-bit Timer Ch. <i>x</i> Interrupt Control Register (T8F_INT <i>x</i> ) |       |
|    | 12.11 Precautions                                                                                                                                                      |       |
|    |                                                                                                                                                                        |       |
| 13 | PWM & Capture Timer (T16E)                                                                                                                                             |       |
|    | 13.1 PWM & Capture Timer Overview                                                                                                                                      |       |
|    | 13.2 PWM & Capture Timer Operating Modes                                                                                                                               |       |
|    | 13.3 Setting and Resetting Counter Value                                                                                                                               |       |
|    | 13.4 Compare Data Settings                                                                                                                                             |       |
|    | 13.5 PWM & Capture Timer RUN/STOP Control                                                                                                                              |       |
|    | 13.6 Clock Output Control                                                                                                                                              |       |
|    | 13.7 PWM & Capture Timer Interrupts                                                                                                                                    |       |
|    | 13.8 Control Register Details                                                                                                                                          |       |
|    | 0x5300/0x5360: PWM Timer Ch.x Compare Data A Register (T16E_CAx)                                                                                                       |       |
|    | 0x5302/0x5362: PWM Timer Ch.x Compare Data B Register (T16E_CBx)<br>0x5304/0x5364: PWM Timer Ch.x Counter Data Register (T16E_TCx)                                     |       |
|    | 0x5306/0x5366: PWM Timer Ch.x Control Register (T16E_CTLx)                                                                                                             |       |
|    | 0x5308/0x5368: PWM Timer Ch.x Input Clock Select Register (T16E_CLKx)                                                                                                  |       |
|    | 0x530a/0x536a: PWM Timer Ch.x Interrupt Mask Registers (T16E_IMSKx)                                                                                                    |       |
|    | 0x530c/0x536c: PWM Timer Ch.x Interrupt Flag Registers (T16E_IFLGx)                                                                                                    |       |
|    | 13.9 Precautions                                                                                                                                                       | 13-20 |
| 14 | 8-bit OSC1 Timer (T8OSC1)                                                                                                                                              | 14-1  |
|    | 14.1 8-bit OSC1 Timer Overview                                                                                                                                         | 14-1  |
|    | 14.2 8-bit OSC1 Timer Count Mode                                                                                                                                       | 14-2  |
|    | 14.3 Count Clock                                                                                                                                                       | 14-3  |
|    | 14.4 Resetting 8-bit OSC1 Timer                                                                                                                                        | 14-4  |
|    | 14.5 Compare Data Settings                                                                                                                                             | 14-5  |
|    | 14.6 8-bit OSC1 Timer RUN/STOP Control                                                                                                                                 | 14-6  |
|    | 14.7 8-bit OSC1 Timer Interrupts                                                                                                                                       | 14-7  |
|    | 14.8 PWM output                                                                                                                                                        | 14-8  |
|    | 14.9 Control Register Details                                                                                                                                          |       |
|    | 0x50c0: 8-bit OSC1 Timer Control Register (T8OSC1_CTL)                                                                                                                 |       |
|    | 0x50c1: 8-bit OSC1 Timer Counter Data Register (T8OSC1_CNT)<br>0x50c2: 8-bit OSC1 Timer Compare Data Register (T8OSC1_CMP)                                             |       |
|    |                                                                                                                                                                        | 14-12 |

#### CONTENTS

| 0x50c3: 8-bit OSC1 Timer Interrupt Mask Register (T8OSC1_IMSK) | 14-13                                                          |
|----------------------------------------------------------------|----------------------------------------------------------------|
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
| 15.1 Clock Timer Overview                                      | 15-1                                                           |
| 15.2 Operation Clock                                           | 15-2                                                           |
|                                                                |                                                                |
| 15.4 Clock Timer RUN/STOP Control                              | 15-4                                                           |
| 15.5 Clock Timer Interrupts                                    | 15-5                                                           |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
| •                                                              |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
| •                                                              |                                                                |
| ·                                                              |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
| 16.8 Precautions                                               | 16-12                                                          |
| Watchdog Timer (WDT)                                           | 17-1                                                           |
|                                                                |                                                                |
| •                                                              |                                                                |
| •                                                              |                                                                |
| -                                                              |                                                                |
|                                                                |                                                                |
| 17.3.3 Watchdog Timer Resetting                                | 17-3                                                           |
| 17.3.4 Operation in Standby Mode                               | 17-3                                                           |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
|                                                                |                                                                |
| UART                                                           | 18-1                                                           |
| -                                                              |                                                                |
|                                                                |                                                                |
| 18.3 Transfer Clock                                            | 18-3                                                           |
| -                                                              |                                                                |
| 18.5 Data Transfer Control                                     |                                                                |
| 18.6 Receive Errors                                            |                                                                |
| 18.7 UART Interrupts                                           | 18-9                                                           |
|                                                                | 0x50c4: 8-bit OSC1 Timer Interrupt Flag Register (T8OSC1_IFLG) |

### CONTENTS

|    | 18.8  | IrDA Interface                                                                                                     | 18-11   |
|----|-------|--------------------------------------------------------------------------------------------------------------------|---------|
|    | 18.9  | Control Register Details                                                                                           | 18-13   |
|    |       | 0x4100: UART Ch.x Status Registers (UART_STx)                                                                      | . 18-14 |
|    |       | 0x4101/0x4121: UART Ch.x Transmit Data Registers (UART_TXDx)                                                       |         |
|    |       | 0x4102/0x4122: UART Ch.x Receive Data Registers (UART_RXDx)                                                        |         |
|    |       | 0x4103/0x4123: UART Ch.x Mode Registers (UART_MODx)                                                                |         |
|    |       | 0x4104/0x4124: UART Ch.x Control Registers (UART_CTLx)<br>0x4105/0x4125: UART Ch.x Expansion Registers (UART_EXPx) |         |
|    | 10 1/ | 0 Precautions                                                                                                      |         |
|    |       |                                                                                                                    |         |
| 19 | SPI   |                                                                                                                    | 19-1    |
|    | 19.1  | SPI Configuration                                                                                                  | 19-1    |
|    | 19.2  | SPI Input/Output Pins                                                                                              | 19-2    |
|    | 19.3  | SPI Clock                                                                                                          | 19-3    |
|    |       | Data Transfer Condition Settings                                                                                   |         |
|    |       | Data Transfer Control                                                                                              |         |
|    |       | SPI Interrupts                                                                                                     |         |
|    |       |                                                                                                                    |         |
|    | 19.7  | Control Register Details                                                                                           |         |
|    |       | 0x4320: SPI Status Register (SPI_ST)<br>0x4322: SPI Transmit Data Register (SPI_TXD)                               |         |
|    |       | 0x4324: SPI Receive Data Register (SPI_RXD)                                                                        |         |
|    |       | 0x4326: SPI Control Register (SPI_CTL)                                                                             |         |
|    | 19.8  | Precautions                                                                                                        |         |
| ~~ |       |                                                                                                                    |         |
| 20 |       |                                                                                                                    |         |
|    |       | I <sup>2</sup> C Configuration                                                                                     |         |
|    |       | I <sup>2</sup> C Input/Output Pins                                                                                 |         |
|    | 20.3  | I <sup>2</sup> C Clock                                                                                             | 20-3    |
|    | 20.4  | Settings Before Data Transfer                                                                                      | 20-4    |
|    | 20.5  | Data Transfer Control                                                                                              | 20-5    |
|    | 20.6  | I <sup>2</sup> C Interrupts                                                                                        | 20-11   |
|    | 20.7  | Control Register Details                                                                                           | 20-12   |
|    |       | 0x4340: I <sup>2</sup> C Enable Register (I2C_EN)                                                                  |         |
|    |       | 0x4342: I <sup>2</sup> C Control Register (I2C_CTL)                                                                |         |
|    |       | 0x4344: I <sup>2</sup> C Data Register (I2C_DAT)                                                                   |         |
|    |       | 0x4346: I <sup>2</sup> C Interrupt Control Register (I2C_ICTL)                                                     | 20-18   |
| 21 | Remot | e Controller (REMC)                                                                                                | 21-1    |
|    | 21.1  | REMC Configuration                                                                                                 | 21-1    |
|    |       | REMC Input/output Pin                                                                                              |         |
|    |       | Carrier Generation                                                                                                 |         |
|    |       | Data Length Counter Clock Settings                                                                                 |         |
|    |       | Data Transfer Control                                                                                              |         |
|    |       | REMC Interrupts                                                                                                    |         |
|    |       | •                                                                                                                  |         |
|    | 21.7  | Control Register Details<br>0x5340: REMC Configuration Register (REMC_CFG)                                         |         |
|    |       | 0x5340: REMC Conliguration Register (REMC_CFG)                                                                     |         |
|    |       | 0x5344: REMC Length Counter Register (REMC_LCNT)                                                                   |         |
|    |       | 0x5346: REMC Interrupt Control Register (REMC_INT)                                                                 |         |
|    | 21.8  | Precautions                                                                                                        |         |
| ~~ |       |                                                                                                                    |         |
| 22 |       | river (LCD)                                                                                                        |         |
|    |       | LCD Driver Configuration                                                                                           |         |
|    | 22.2  | LCD Power Supply                                                                                                   | 22-2    |

|    | 22.3   | LCD Clock                                                    | 22-3  |
|----|--------|--------------------------------------------------------------|-------|
|    |        | 22.3.1 LCD Operating Clock                                   | 22-3  |
|    |        | 22.3.2 Frame Signal                                          | 22-3  |
|    | 22.4   | Driver Duty Switching                                        | 22-4  |
|    | 22.5   | Display Memory                                               |       |
|    |        | Display Control                                              |       |
|    |        | 22.6.1 Display On/Off                                        |       |
|    |        | 22.6.2 LCD Contrast Adjustment                               |       |
|    |        | 22.6.3 Inverted Display                                      |       |
|    |        | 22.6.4 Gradation Display Control                             |       |
|    | 22.7   | LCD Interrupt                                                |       |
|    |        | Control Register Details                                     |       |
|    | 22.0   | 0x50a0: LCD Display Control Register (LCD_DCTL)              |       |
|    |        | 0x50a1: LCD Contrast Adjust Register (LCD_CADJ)              |       |
|    |        | 0x50a2: LCD Clock Control Register (LCD_CCTL)                |       |
|    |        | 0x50a3: LCD Voltage Regulator Control Register (LCD_VREG)    | 22-17 |
|    |        | 0x50a4: LCD Power Voltage Booster Control Register (LCD_PWR) |       |
|    |        | 0x50a5: LCD Interrupt Mask Register (LCD_IMSK)               |       |
|    |        | 0x50a6: LCD Interrupt Flag Register (LCD_IFLG)               |       |
|    | 22.9   | Precautions                                                  | 22-21 |
| 23 | Power  | Supply Voltage Detection Circuit (SVD)                       | 23-1  |
|    |        | SVD Module Configuration                                     |       |
|    | 23.2   | Comparison Voltage Setting                                   | 23-2  |
|    |        | SVD Circuit Control                                          |       |
|    |        | SVD Interrupt                                                |       |
|    |        | Control Register Details                                     |       |
|    | 20.0   | 0x5100: SVD Enable Register (SVD_EN)                         |       |
|    |        | 0x5101: SVD Compare Voltage Register (SVD_CMP)               |       |
|    |        | 0x5102: SVD Detection Result Register (SVD_RSLT)             |       |
|    |        | 0x5103: SVD Interrupt Mask Register (SVD_IMSK)               |       |
|    |        | 0x5104: SVD Interrupt Flag Register (SVD_IFLG)               |       |
|    | 23.6   | Precautions                                                  | 23-11 |
| 24 | On-chi | p Debugger (DBG)                                             | 24-1  |
|    |        | Resource Requirements and Debugging Tool                     |       |
|    |        | Debug Break Operation Status                                 |       |
|    |        | Additional Debugging Function                                |       |
|    |        | Control Register Details                                     |       |
|    | 24.4   | 0x5322: OSC1 Peripheral Control Register (MISC_OSC1)         |       |
|    |        | 0x5326: IRAM Size Select Register (MISC_IRAMSZ)              |       |
|    |        | 0xffff90: Debug RAM Base Register (DBRAM)                    |       |
|    |        | 0xffffa0: Debug Control Register (DCR)                       |       |
|    |        | 0xffffb8: Instruction Break Address Register 2 (IBAR2)       |       |
|    |        | Oxffffbc: Instruction Break Address Register 3 (IBAR3)       |       |
|    |        | 0xffffd0: Instruction Break Address Register 4 (IBAR4)       |       |
| 25 | Multip | lier/Divider                                                 | 25-1  |
|    | 25.1   | Overview                                                     | 25-1  |
|    | 25.2   | Operating Mode and Output Mode                               | 25-2  |
|    | 25.3   | Multiplication                                               | 25-3  |
|    |        | Division                                                     |       |
|    |        | Product-sum Operation                                        |       |
|    |        | Arithmetic Results Reading                                   |       |
|    | 20.0   | / mannede Hesults Heading                                    | 20-1  |

| 26 | <b>Basic External Connection</b>  | Diagram                                  | 26-1  |
|----|-----------------------------------|------------------------------------------|-------|
| 27 | <b>Electrical Characteristics</b> |                                          | 27-1  |
|    | 27.1 Absolute Maximum Ra          | tings                                    | 27-1  |
|    | 27.2 Recommended Operat           | ing Conditions                           | 27-1  |
|    | 27.3 DC Characteristics           |                                          | 27-2  |
|    | 27.4 Analog Circuit Charact       | eristics                                 | 27-3  |
|    | ·                                 |                                          |       |
|    | •                                 |                                          |       |
|    |                                   | cteristics                               |       |
|    |                                   | cteristics                               |       |
|    |                                   | <pre>&lt; Input AC Characteristics</pre> |       |
|    |                                   | naracteristics                           |       |
|    |                                   | tics                                     |       |
|    |                                   | (Reference Values)                       |       |
| 28 |                                   | · · · · · · · · · · · · · · · · · · ·    |       |
|    | •                                 |                                          |       |
| Ар |                                   | Prescaler                                |       |
|    | 0x4020<br>0x4100–0x4125           | UART (with IrDA)                         | -     |
|    | 0x4100-0x4125<br>0x4200-0x4208    | 8-bit Timer (with Fine Mode) Ch.0        |       |
|    | 0x4220-0x4268                     | 16-bit Timer                             |       |
|    | 0x4280-0x4288                     | 8-bit Timer (with Fine Mode) Ch.1        |       |
|    | 0x4306–0x4316                     | Interrupt Controller                     |       |
|    | 0x4320–0x4326                     | SPI                                      |       |
|    | 0x4340–0x4346                     | l <sup>2</sup> C                         | -     |
|    | 0x5000–0x5003                     | Clock Timer                              |       |
|    | 0x5020-0x5023                     | Stopwatch Timer                          | AP-16 |
|    | 0x5040-0x5041                     | Watchdog Timer                           |       |
|    | 0x5060–0x5065                     | Oscillator                               | AP-18 |
|    | 0x5080–0x5081                     | Clock Generator                          | AP-19 |
|    | 0x50a0-0x50a6                     | LCD Driver                               |       |
|    | 0x50c0-0x50c5                     | 8-bit OSC1 Timer                         | AP-21 |
|    | 0x5100-0x5104                     | SVD Circuit                              |       |
|    | 0x5120                            | Power Generator                          |       |
|    | 0x5200–0x52a3                     | P Port & Port MUX                        |       |
|    | 0x5300-0x530c                     | PWM & Capture Timer Ch.0                 |       |
|    | 0x5320-0x532c                     | MISC Registers                           |       |
|    | 0x5340-0x5346                     | Remote Controller                        |       |
|    | 0x5360-0x536c                     | PWM & Capture Timer Ch.1                 |       |
| _  | 0xffff84–0xffffd0                 | S1C17 Core I/O                           |       |
| Ар | • • •                             | ogramming                                |       |
|    |                                   |                                          |       |
|    | B.2 Self-programming via U        | ser Programs                             | AP-34 |
| Ap | •                                 |                                          |       |
|    |                                   | ving                                     |       |
|    | C.2 Reducing Power Consu          | mption via Power Supply Control          | AP-38 |
| -  |                                   | tions                                    |       |
| Ар | pendix E Initialization Rout      | tine                                     | AP-43 |
| Re | vision History                    |                                          |       |

# 1 Overview

The S1C17702 is a 16-bit MCU featuring high-speed low-power operations, compact dimensions, wide address space, and on-chip ICE. Based on an S1C17 CPU core, this product incorporates a 128KB of flash memory, a 12KB of RAM, serial interfaces such as UART supporting high-bit rate and IrDA1.0, SPI, and I<sup>2</sup>C to support various sensors, 8-bit timers, 16-bit timers, PWM & capture timers, a clock timer, a stopwatch timer, a watchdog timer, 28 general input/output ports, max. 72 segments  $\times$  32 commons LCD driver and a power supply voltage booster circuit, a power supply voltage detection circuit, 32 kHz and max. 8.2 MHz oscillator circuits, and a 1.8 V voltage regulator.

It allows 8.2 MHz high-speed operation at an operating voltage of just 1.8 V, and executes single instructions using a single clock with 16-bit RISC processing. The product also incorporates a coprocessor for arithmetic functions for multiplication and product-sum operations.

The on-chip ICE function allows onboard programs/deletes of internal flash memory and program debugging and evaluations following connection of the three signal wires to the ICD Mini (S5U1C17001H).

The S1C17702 is ideal for applications (such as remote controllers and sports watches) requiring battery power and sensor interface and for LCD displays of up to  $72 \times 32$  dots.

\* This product uses SuperFlash® technology licensed by Silicon Storage Technology, Inc.

# 1.1 Features

The main features of the S1C17702 are listed below.

| The main features of the S1C17702 are listed b | below.                                                                                                                                                                                                                                         |                                                      |
|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| CPU                                            | <ul> <li>Epson original 16-bit RISC CPU core S1C</li> <li>16-bit × 16-bit + 32-bit product-sum proces</li> <li>16-bit ÷ 16-bit divider</li> </ul>                                                                                              |                                                      |
| IOSC oscillator circuit                        | • 2.7 MHz (typ.)                                                                                                                                                                                                                               |                                                      |
| OSC3 oscillator circuit                        | • Crystal oscillator circuit or ceramic oscilla (max.)                                                                                                                                                                                         | ator circuit, 8.2 MHz                                |
| OSC1 oscillator circuit                        | • Crystal oscillator circuit 32.786 kHz (typ.)                                                                                                                                                                                                 |                                                      |
| Internal flash memory                          | <ul> <li>128K bytes (for both instructions and data)</li> <li>Allows 1,000 overwrites (min.)</li> <li>Read/program protection function</li> <li>Allows onboard rewriting with the ICD M debug tool and self-rewriting via software.</li> </ul> | lini (S5U1C17001H)                                   |
| Internal RAM                                   | • 12K bytes                                                                                                                                                                                                                                    |                                                      |
| Internal display RAM                           | • 576 bytes                                                                                                                                                                                                                                    |                                                      |
| Input/output port                              | • Max. 28-bit general purpose input/output (s circuit input/output pins)                                                                                                                                                                       | hared with peripheral                                |
| Serial interface                               | <ul> <li>SPI (master/slave)</li> <li>I<sup>2</sup>C (master)</li> <li>UART (460,800 bps, IrDA1.0 compatible)</li> <li>Remote controller (REMC)</li> </ul>                                                                                      | 1ch.<br>1ch.<br>2ch.<br>1ch.                         |
| Timer                                          | <ul> <li>8-bit timer (T8F)</li> <li>16-bit timer (T16)</li> <li>PWM&amp; capture timer (T16E)</li> <li>Clock timer (CT)</li> <li>Stopwatch timer (SWT)</li> <li>Watchdog timer (WDT)</li> <li>8-bit OSC1 timer (T8OSC1)</li> </ul>             | 2ch.<br>3ch.<br>2ch.<br>1ch.<br>1ch.<br>1ch.<br>1ch. |
| LCD driver                                     | <ul> <li>72 SEG × 32 COM or 88 SEG × 16 COM (</li> <li>Internal booster power supply circuit (16 contrast)</li> </ul>                                                                                                                          |                                                      |
| Power supply voltage detection (SVD) circu     | it • 15-value programmable (1.8 V to 3.2 V)                                                                                                                                                                                                    |                                                      |
| Interrupt                                      | <ul> <li>Reset</li> <li>NMI</li> <li>Programmable interrupt × 18 (8 levels)</li> </ul>                                                                                                                                                         |                                                      |
| Power supply voltage                           | <ul> <li>1.8 V to 3.6 V (for normal operations, int<br/>1.8 V low-power operations)</li> <li>2.7 V to 3.6 V (for flash erase/writing, inter</li> <li>Internal constant-voltage circuit (2-step provoltage)</li> </ul>                          | nal 2.5 V operations)                                |
| Operating temperature                          | • -25°C to 70°C                                                                                                                                                                                                                                |                                                      |

Current consumption

- SLEEP mode: 1.2 µA typ. (OSC1 = OFF, IOSC = OFF, OSC3 = OFF)
- HALT mode: 2.7 μA typ. (OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF, PCKEN = 0x0, LCD OFF)
  9.7 μA typ. (OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF, PCKEN = 0x0, LCD ON (All on, contrast max.))
  When operating: 16 μA typ. (OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF, OSC1 = 32 kHz, IOSC = OFF, OSC1 = 32 kHz, IOSC1 = 0FF, OSC1 = 0FF, OSC1
  - OSC3 = OFF, LCD OFF) 450 µA typ. (OSC1 = OFF, IOSC = OFF, OSC3 = 1 MHz ceramic oscillator)

- Configuration as shipped
- QFP21-176 pin package (26 mm × 26 mm, pin pitch: 0.5 mm)
- VFBGA8H-181 package (8 mm × 8 mm, ball pitch: 0.5 mm)
- VFBGA10H-180 package (10 mm × 10 mm, ball pitch: 0.65 mm)
- Chip



### 1.2 Block Diagram

Figure 1.2.1: Block diagram

### 1.3 Pins

### 1.3.1 Pinout Diagram

### QFP21-176 pin





### **1 OVERVIEW**

### VFBGA8H-181

| A1 Corner Top View |       |       |                             |                |                |                |                | Bottom View A1 Corner                   |             |      |                     |                       |                             |                     |     |                   |
|--------------------|-------|-------|-----------------------------|----------------|----------------|----------------|----------------|-----------------------------------------|-------------|------|---------------------|-----------------------|-----------------------------|---------------------|-----|-------------------|
|                    |       |       | A B C D E F G H J K L M N P | Index          |                |                |                | 000000000000000000000000000000000000000 |             |      |                     |                       | A B C D E F G H J K L M N P |                     |     |                   |
|                    |       |       | 1                           | 2345           | 6789           | 9 10 11 12     | 13 14          | 14                                      | 13 12 11 10 | 987  | 6543                | 321                   |                             |                     |     |                   |
| r                  | 1     | 2     | 3                           | 4              | 5              | 6              | 7              | 8                                       | 9           | 10   | 11                  | 12                    | 13                          | 14                  |     |                   |
|                    | N.C.  | SEG22 | SEG20                       | SEG17          | SEG14          | SEG9           | SEG6           | SEG0                                    | COM15       | COM9 | COM5                | COM2                  | СОМО                        | N.C                 |     |                   |
|                    | SEG25 | SEG24 | SEG21                       | SEG18          | SEG15          | SEG10          | SEG7           | SEG1                                    | COM13       | СОМ8 | COM4                | СОМ1                  | VDD                         | Vss                 |     |                   |
|                    | SEG27 | SEG26 | SEG23                       | SEG19          | SEG16          | SEG11          | SEG8           | SEG2                                    | COM12       | COM7 | СОМЗ                | P00<br>EXCL3          | P01<br>EXCL4                | <b>P04</b><br>TOUT4 |     |                   |
|                    | SEG31 | SEG30 | SEG29                       | SEG28          | SEG13          | SEG12          | SEG5           | SEG3                                    | COM11       | COM6 | P02<br>REMI         | P03<br>REMO           | P06<br>EXCL2                | P05<br>TOUTN4       |     |                   |
|                    | SEG35 | SEG34 | SEG33                       | SEG32          | Vss            | Vss            | SEG4           | COM14                                   | COM10       | Vss  | <b>P07</b><br>EXCL1 | P12<br>SCLK1          | P14<br>SDA                  | P13<br>FOUT1        |     |                   |
|                    | SEG39 | SEG38 | SEG37                       | SEG36          | Vss            | Vss            |                |                                         |             | Vss  | P10<br>SIN1         | P16<br>EXCL0<br>TOUT5 | P15<br>SCL                  | P17<br>#SPISS       |     |                   |
|                    | SEG44 | SEG43 | SEG42                       | SEG41          | SEG40          |                |                |                                         |             |      |                     | Vss                   | P11<br>SOUT1                | P21<br>SDO          | Vdd | <b>P20</b><br>SDI |
|                    | SEG45 | SEG46 | SEG47                       | SEG48          | Vss            |                | Тор            | View                                    |             | Vss  | P25<br>SCLK0        | P24<br>SOUT0          | P23<br>SIN0                 | P22<br>SPICLK       |     |                   |
|                    | SEG49 | SEG50 | SEG51                       | SEG52          | SEG56          | -              |                |                                         |             | Vss  | DCLK<br>P31         | P30<br>FOUTH          | <b>P26</b><br>TOUT3         | P27<br>TOUTN3       |     |                   |
|                    | SEG53 | SEG54 | SEG55                       | SEG57          | COM30<br>SEG73 | Vss            | Vss            | Vss                                     | Vss         | Vss  | Vc4                 | <b>DST2</b><br>P32    | #RESET                      | DSIO<br>P33         |     |                   |
|                    | SEG58 | SEG59 | SEG60                       | SEG68          | COM29<br>SEG74 | COM25<br>SEG78 | COM23<br>SEG80 | Vss                                     | CE          | CD   | Vc5                 | #TEST                 | OSC2                        | OSC1                |     |                   |
|                    | SEG61 | SEG62 | SEG67                       | SEG69          | COM28<br>SEG75 | COM24<br>SEG79 | COM20<br>SEG83 | Vss                                     | TEST1       | VD2  | CA                  | Vc1                   | V <sub>D1</sub>             | Vss                 |     |                   |
|                    | SEG63 | SEG64 | SEG66                       | SEG71          | COM27<br>SEG76 | COM21<br>SEG82 | COM19<br>SEG84 | COM17<br>SEG86                          | TEST3       | CG   | сс                  | Vc2                   | OSC4                        | Vdd                 |     |                   |
|                    | N.C.  | SEG65 | SEG70                       | COM31<br>SEG72 | COM26<br>SEG77 | COM22<br>SEG81 | COM18<br>SEG85 | COM16<br>SEG87                          | TEST2       | CF   | СВ                  | Vc3                   | OSC3                        | N.C                 |     |                   |
| 1                  | 1     | 2     | 3                           | 4              | 5              | 6              | 7              | 8                                       | 9           | 10   | 11                  | 12                    | 13                          | 14                  |     |                   |

#### **1 OVERVIEW**

### **VFBGA10H-180**

|   | A1 Corner Top View |       |                             |                  |                |                |                |                | Bottom View <u>A1 Corner</u> |         |                     |                       |                             |                     |    |
|---|--------------------|-------|-----------------------------|------------------|----------------|----------------|----------------|----------------|------------------------------|---------|---------------------|-----------------------|-----------------------------|---------------------|----|
|   |                    |       | A B C D E F G H J K L M N P | Index<br>2 3 4 5 | 6 7 8 0        | 10 11 12       | 113.14         |                |                              |         |                     |                       | A B C D E F G H J K L M N P |                     |    |
|   | 1                  | 2     | 3                           | 4                | 5              | 6              | 7              | 8              | 9                            | 10      | 11                  | 12                    | 13                          | 14                  |    |
|   |                    | SEG22 | SEG20                       | SEG17            | SEG14          | SEG9           | SEG6           | SEG0           | COM15                        | СОМ9    | СОМ5                | COM2                  | СОМО                        |                     | 1. |
| Α | N.C.               |       |                             |                  |                |                |                |                |                              |         |                     |                       |                             | N.C                 | A  |
| в | SEG25              | SEG24 | SEG21                       | SEG18            | SEG15          | SEG10          | SEG7           | SEG1           | COM13                        | СОМ8    | СОМ4                | COM1                  | VDD                         | Vss                 | в  |
| с | SEG27              | SEG26 | SEG23                       | SEG19            | SEG16          | SEG11          | SEG8           | SEG2           | COM12                        | COM7    | СОМЗ                | P00<br>EXCL3          | P01<br>EXCL4                | <b>P04</b><br>TOUT4 | с  |
| D | SEG31              | SEG30 | SEG29                       | SEG28            | SEG13          | SEG12          | SEG5           | SEG3           | COM11                        | COM6    | P02<br>Remi         | P03<br>REMO           | P06<br>EXCL2                | P05<br>TOUTN4       | D  |
| E | SEG35              | SEG34 | SEG33                       | SEG32            | Vss            | Vss            | SEG4           | COM14          | COM10                        | Vss     | P07<br>EXCL1        | P12<br>SCLK1          | P14<br>SDA                  | P13<br>FOUT1        | E  |
| F | SEG39              | SEG38 | SEG37                       | SEG36            | Vss            |                | -1             |                |                              | Vss     | <b>P10</b><br>SIN1  | P16<br>EXCL0<br>TOUT5 | P15<br>SCL                  | P17<br>#SPISS       | F  |
| G | SEG44              | SEG43 | SEG42                       | SEG41            | SEG40          |                | _              |                |                              | Vss     | P11<br>SOUT1        | <b>P21</b><br>SDO     | VDD                         | <b>P20</b><br>SDI   | G  |
| н | SEG45              | SEG46 | SEG47                       | SEG48            | Vss            |                | Тор            | View           |                              | Vss     | <b>P25</b><br>SCLK0 | P24<br>SOUT0          | P23<br>SIN0                 | P22<br>SPICLK       | н  |
| J | SEG49              | SEG50 | SEG51                       | SEG52            | SEG56          |                |                |                |                              | Vss     | DCLK<br>P31         | P30<br>FOUTH          | <b>P26</b><br>TOUT3         | P27<br>TOUTN3       | J  |
| к | SEG53              | SEG54 | SEG55                       | SEG57            | COM30<br>SEG73 | Vss            | Vss            | Vss            | Vss                          | Vss     | Vc4                 | <b>DST2</b><br>P32    | #RESET                      | DSIO<br>P33         | к  |
| L | SEG58              | SEG59 | SEG60                       | SEG68            | COM29<br>SEG74 | COM25<br>SEG78 | COM23<br>SEG80 | Vss            | CE                           | CD      | Vc5                 | #TEST                 | OSC2                        | OSC1                | L  |
| м | SEG61              | SEG62 | SEG67                       | SEG69            | COM28<br>SEG75 | COM24<br>SEG79 | COM20<br>SEG83 | Vss            | TEST1                        | Vd2     | CA                  | Vc1                   | VD1                         | Vss                 | м  |
| N | SEG63              | SEG64 | SEG66                       | SEG71            | COM27<br>SEG76 | COM21<br>SEG82 | COM19<br>SEG84 | COM17<br>SEG86 | TEST3                        | CG      | сс                  | Vc2                   | OSC4                        | Vdd                 | N  |
| Ρ | N.C.               | SEG65 | SEG70                       | COM31<br>SEG72   | COM26<br>SEG77 | COM22<br>SEG81 | COM18<br>SEG85 | COM16<br>SEG87 | TEST2                        | CF      | СВ                  | Vc3                   | OSC3                        | N.C                 | P  |
|   | 1                  | 2     | 3                           | 4                | 5              | 6              | 7              | 8              | 9                            | 10      | 11                  | 12                    | 13                          | 14                  | -  |
|   |                    |       |                             |                  | Figure 1       | .3.1.3:        | Pinout d       | iagram         | (VFBGA                       | 10H-180 | ))                  |                       |                             |                     |    |

### Chip



(Pad opening) No. 1 to 40, 81 to 120: 68 × 90 µm No. 41 to 80, 121 to 161: 90 × 68 µm

| Table | 1.3.1.1: | Pad | coordinates |
|-------|----------|-----|-------------|
|-------|----------|-----|-------------|

| Pad No. | Pad name | X (mm) | Y(mm)  | Pad No. | Pad name        | X (mm) | Y(mm) |
|---------|----------|--------|--------|---------|-----------------|--------|-------|
| 1       | SEG25    | -1.740 | -2.191 | 81      | Vdd             | 1.755  | 2.191 |
| 2       | SEG26    | -1.650 | -2.191 | 82      | OSC3            | 1.665  | 2.191 |
| 3       | SEG27    | -1.560 | -2.191 | 83      | OSC4            | 1.575  | 2.191 |
| 4       | SEG28    | -1.470 | -2.191 | 84      | Vss             | 1.485  | 2.191 |
| 5       | SEG29    | -1.380 | -2.191 | 85      | V <sub>D1</sub> | 1.395  | 2.191 |
| 6       | SEG30    | -1.290 | -2.191 | 86      | OSC1            | 1.235  | 2.191 |
| 7       | SEG31    | -1.200 | -2.191 | 87      | OSC2            | 1.145  | 2.191 |
| 8       | SEG32    | -1.110 | -2.191 | 88      | #TEST           | 1.055  | 2.191 |
| 9       | SEG33    | -1.020 | -2.191 | 89      | #RESET          | 0.965  | 2.191 |
| 10      | SEG34    | -0.930 | -2.191 | 90      | DSIO/P33        | 0.875  | 2.191 |
| 11      | SEG35    | -0.840 | -2.191 | 91      | DST2/P32        | 0.785  | 2.191 |
| 12      | SEG36    | -0.750 | -2.191 | 92      | DCLK/P31        | 0.695  | 2.191 |
| 13      | SEG37    | -0.660 | -2.191 | 93      | P30/FOUTH       | 0.605  | 2.191 |
| 14      | SEG38    | -0.570 | -2.191 | 94      | P27/TOUTN3      | 0.515  | 2.191 |
| 15      | SEG39    | -0.480 | -2.191 | 95      | P26/TOUT3       | 0.425  | 2.191 |
| 16      | SEG40    | -0.390 | -2.191 | 96      | P25/SCLK0       | 0.335  | 2.191 |
| 17      | SEG41    | -0.300 | -2.191 | 97      | P24/SOUT0       | 0.245  | 2.191 |
| 18      | SEG42    | -0.210 | -2.191 | 98      | P23/SIN0        | 0.155  | 2.191 |
| 19      | SEG43    | -0.120 | -2.191 | 99      | P22/SPICLK      | 0.065  | 2.191 |
| 20      | SEG44    | -0.030 | -2.191 | 100     | P21/SDO         | -0.025 | 2.191 |
| 21      | SEG45    | 0.060  | -2.191 | 101     | P20/SDI         | -0.115 | 2.191 |

### **1 OVERVIEW**

| Pad No. | Pad name       | X (mm) | Y(mm)  | Pad No. | Pad name        | X (mm) | Y(mm)  |
|---------|----------------|--------|--------|---------|-----------------|--------|--------|
| 22      | SEG46          | 0.150  | -2.191 | 102     | Vdd             | -0.205 | 2.191  |
| 23      | SEG47          | 0.240  | -2.191 | 103     | P17/#SPISS      | -0.295 | 2.191  |
| 24      | SEG48          | 0.330  | -2.191 | 104     | P16/EXCL0/TOUT5 | -0.385 | 2.191  |
| 25      | SEG49          | 0.420  | -2.191 | 105     | P15/SCL         | -0.475 | 2.191  |
| 26      | SEG50          | 0.510  | -2.191 | 106     | P14/SDA         | -0.565 | 2.191  |
| 27      | SEG51          | 0.600  | -2.191 | 107     | P13/FOUT1       | -0.655 | 2.191  |
| 28      | SEG52          | 0.690  | -2.191 | 108     | P12/SCLK1       | -0.745 | 2.191  |
| 29      | SEG53          | 0.780  | -2.191 | 109     | P11/SOUT1       | -0.835 | 2.191  |
| 30      | SEG54          | 0.870  | -2.191 | 110     | P10/SIN1        | -0.925 | 2.191  |
| 31      | SEG55          | 0.960  | -2.191 | 111     | P07/EXCL1       | -1.015 | 2.191  |
| 32      | SEG56          | 1.050  | -2.191 | 112     | P06/EXCL2       | -1.105 | 2.191  |
| 33      | SEG57          | 1.140  | -2.191 | 113     | P05/TOUTN4      | -1.195 | 2.191  |
| 34      | SEG58          | 1.230  | -2.191 | 114     | P04/TOUT4       | -1.285 | 2.191  |
| 35      | SEG59          | 1.320  | -2.191 | 115     | P03/REMO        | -1.375 | 2.191  |
| 36      | SEG60          | 1.410  | -2.191 | 116     | P02/REMI        | -1.465 | 2.191  |
| 37      | SEG61          | 1.500  | -2.191 | 117     | P01/EXCL4       | -1.555 | 2.191  |
| 38      | SEG62          | 1.590  | -2.191 | 118     | P00/EXCL3       | -1.645 | 2.191  |
| 39      | SEG63          | 1.680  | -2.191 | 119     | VDD             | -1.735 | 2.191  |
| 40      | SEG64          | 1.770  | -2.191 | 120     | Vss             | -1.825 | 2.191  |
| 41      | SEG65          | 2.131  | -1.740 | 121     | COM0            | -2.131 | 1.780  |
| 42      | SEG66          | 2.131  | -1.650 | 122     | COM1            | -2.131 | 1.690  |
| 43      | SEG67          | 2.131  | -1.560 | 122     | COM2            | -2.131 | 1.600  |
| 44      | SEG68          | 2.131  | -1.470 | 123     | COM3            | -2.131 | 1.510  |
| 45      | SEG69          | 2.131  | -1.380 | 125     | COM4            | -2.131 | 1.420  |
| 46      | SEG70          | 2.131  | -1.290 | 126     | COM5            | -2.131 | 1.330  |
| 47      | SEG71          | 2.131  | -1.200 | 120     | COM6            | -2.131 | 1.240  |
| 48      | COM31          | 2.131  | -1.100 | 127     | COM7            | -2.131 | 1.150  |
| 49      | COM30          | 2.131  | -1.010 | 120     | COM8            | -2.131 | 1.060  |
| <br>50  | COM29          | 2.131  | -0.920 | 130     | COM9            | -2.131 | 0.970  |
| 51      | COM29          | 2.131  | -0.830 | 131     | COM10           | -2.131 | 0.880  |
| 52      | COM27          | 2.131  | -0.740 | 132     | COM10           | -2.131 | 0.790  |
| 53      | COM26          | 2.131  | -0.650 | 133     | COM12           | -2.131 | 0.790  |
| 54      | COM25          | 2.131  | -0.560 | 133     | COM12<br>COM13  | -2.131 | 0.700  |
| 55      | COM24          | 2.131  | -0.300 | 134     | COM13<br>COM14  | -2.131 | 0.520  |
|         | COM24<br>COM23 | 2.131  | -0.470 |         | COM14<br>COM15  | -2.131 | 0.520  |
| 56      |                |        |        | 136     | SEG0            |        |        |
| 57      | COM22          | 2.131  | -0.290 | 137     |                 | -2.131 | 0.330  |
| 58      | COM21          | 2.131  | -0.200 | 138     | SEG1            | -2.131 | 0.240  |
| 59      | COM20          | 2.131  | -0.110 | 139     | SEG2            | -2.131 | 0.150  |
| 60      | COM19          | 2.131  | -0.020 | 140     | SEG3            | -2.131 | 0.060  |
| 61      | COM18          | 2.131  | 0.070  | 141     | SEG4            | -2.131 | -0.030 |
| 62      | COM17          | 2.131  | 0.160  | 142     | SEG5            | -2.131 | -0.120 |
| 63      | COM16          | 2.131  | 0.250  | 143     | SEG6            | -2.131 | -0.210 |
| 64      | Vss            | 2.131  | 0.400  | 144     | SEG7            | -2.131 | -0.300 |
| 65      | TEST3          | 2.131  | 0.490  | 145     | SEG8            | -2.131 | -0.390 |
| 66      | TEST2          | 2.131  | 0.580  | 146     | SEG9            | -2.131 | -0.480 |
| 67      | TEST1          | 2.131  | 0.670  | 147     | SEG10           | -2.131 | -0.570 |
| 68      | VD2            | 2.131  | 0.760  | 148     | SEG11           | -2.131 | -0.660 |
| 69      | CG             | 2.131  | 0.850  | 149     | SEG12           | -2.131 | -0.750 |
| 70      | CF             | 2.131  | 0.940  | 150     | SEG13           | -2.131 | -0.840 |
| 71      | CE             | 2.131  | 1.030  | 151     | SEG14           | -2.131 | -0.930 |
| 72      | CD             | 2.131  | 1.120  | 152     | SEG15           | -2.131 | -1.020 |
| 73      | CC             | 2.131  | 1.210  | 153     | SEG16           | -2.131 | -1.110 |
| 74      | СВ             | 2.131  | 1.300  | 154     | SEG17           | -2.131 | -1.200 |
| 75      | CA             | 2.131  | 1.390  | 155     | SEG18           | -2.131 | -1.290 |
| 76      | Vc5            | 2.131  | 1.480  | 156     | SEG19           | -2.131 | -1.380 |
| 77      | Vc4            | 2.131  | 1.570  | 157     | SEG20           | -2.131 | -1.470 |
| 78      | Vсз            | 2.131  | 1.660  | 158     | SEG21           | -2.131 | -1.560 |
| 79      | VC2            | 2.131  | 1.750  | 159     | SEG22           | -2.131 | -1.650 |
| 80      | Vc1            | 2.131  | 1.840  | 160     | SEG23           | -2.131 | -1.740 |
| _       | _              | _      | _      | 161     | SEG24           | -2.131 | -1.830 |

## 1.3.2 Pin Descriptions

| Din /h                                          |             |                             |            |                 |                                                                                                                                          |
|-------------------------------------------------|-------------|-----------------------------|------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Pin/ba                                          |             | Name                        | I/O        | Default         | Function                                                                                                                                 |
| QFP                                             | VFBGA       |                             |            | status          |                                                                                                                                          |
| 1, 3, 5 to 40,<br>42, 44 to 45,<br>47, 49 to 53 | *2          | SEG25 to 71                 | 0          | O (L)           | LCD segment output pin                                                                                                                   |
| 54 to 69                                        | *3          | COM31 to 16/<br>SEG72 to 87 | 0          | O (L)           | LCD common output pin*1/LCD segment output pin                                                                                           |
| 70                                              | *4          | Vss                         | _          | _               | Power supply pin (GND)                                                                                                                   |
| 71                                              | N9          | TEST3                       | -          | -               | Flash test pin (open during normal operations)                                                                                           |
| 72                                              | P9          | TEST2                       | _          | _               | Flash test pin (fixed to High during normal operations)                                                                                  |
| 73                                              | M9          | TEST1                       | -          | -               | Flash test pin (open during normal operations)                                                                                           |
| 74                                              | M10         | VD2                         | -          | -               | LCD circuit power supply booster output pin                                                                                              |
| 75                                              | N10         | CG                          | -          | -               | Power supply voltage booster capacitor connector pin                                                                                     |
| 76                                              | P10         | CF                          | _          | _               | Power supply voltage booster capacitor connector pin                                                                                     |
| 77                                              | L9          | CE                          | -          | -               | LCD booster capacitor connector pin                                                                                                      |
| 78                                              | L10         | CD                          | -          |                 | LCD booster capacitor connector pin                                                                                                      |
| 79                                              | N11         | CC                          | -          | -               | LCD booster capacitor connector pin                                                                                                      |
| 80                                              | P11         | СВ                          | _          | _               | LCD booster capacitor connector pin                                                                                                      |
| 81                                              | M11         | CA                          | -          | _               | LCD booster capacitor connector pin                                                                                                      |
| 82                                              | L11         | Vc5                         | -          | -               | LCD circuit drive voltage output pin                                                                                                     |
| 83                                              | K11         | Vc4                         | -          | -               | LCD circuit drive voltage output pin                                                                                                     |
| 84                                              | P12         | Vc3                         | _          | -               | LCD circuit drive voltage output pin                                                                                                     |
| 86                                              | N12         | Vc2                         | _          | _               | LCD circuit drive voltage output pin                                                                                                     |
| 88                                              | M12         | Vc1                         | _          | -               | LCD circuit drive voltage output pin                                                                                                     |
| 89                                              | N14         | VDD                         | -          | -               | Power supply pin (+)                                                                                                                     |
| 91                                              | P13         | OSC3                        |            | 1               | OSC3 oscillator input pin                                                                                                                |
| 93<br>94                                        | N13<br>*4   | OSC4<br>Vss                 | 0          | 0               | OSC3 oscillator output pin                                                                                                               |
| 94<br>95                                        | M13         | VD1                         | -          | -               | Power supply pin (GND)                                                                                                                   |
| 95<br>96                                        | L14         | OSC1                        | -          | -               | Internal logic and oscillator circuit voltage regulator output pin<br>OSC1 oscillator input pin                                          |
| 90                                              | L14<br>L13  | OSC2                        | 0          | 0               | OSC1 oscillator output pin                                                                                                               |
| 98                                              | L13         | #TEST                       |            | I (Pull-UP)     | Test pin (fixed to High during normal operations)                                                                                        |
| 99                                              | K13         | #RESET                      |            | I (Pull-UP)     | Initial set input pin                                                                                                                    |
| 100                                             | K14         | DSIO/P33                    | 1/0        | I (Pull-UP)     | On-chip debugger data input/output pin*1/input/output port pin                                                                           |
| 101                                             | K12         | DST2/P32                    | 1/O        | O (L)           | On-chip debugger status output pin*1/input/output port pin                                                                               |
| 102                                             | J11         | DCLK/P31                    | 1/O        | O (H)           | On-chip debugger clock output pin*1/input/output port pin                                                                                |
| 103                                             | J12         | P30/FOUTH                   | I/O        | I (Pull-UP)     | Input/output port pin/OSC3 dividing clock output pin                                                                                     |
| 104                                             | J14         | P27/TOUTN3                  | I/O        | I (Pull-UP)     | Input/output port pin*1/T16E Ch.0 PWM signal inverted output pin                                                                         |
| 105                                             | J13         | P26/TOUT3                   | I/O        | I (Pull-UP)     | Input/output port pin*1/T16E Ch.0 PWM signal output pin                                                                                  |
| 106                                             | H11         | P25/SCLK0                   | I/O        | I (Pull-UP)     | Input/output port pin*1/UART Ch.0 clock input pin                                                                                        |
| 107                                             | H12         | P24/SOUT0                   | I/O        | I (Pull-UP)     | Input/output port pin*1/UART Ch.0 data output pin                                                                                        |
| 108                                             | H13         | P23/SIN0                    | I/O        | I (Pull-UP)     | Input/output port pin*1/UART Ch.0 data input pin                                                                                         |
| 109                                             | H14         | P22/SPICLK                  | I/O        | I (Pull-UP)     | Input/output port pin*1/SPI clock input/output pin                                                                                       |
| 110                                             | G12         | P21/SDO                     | I/O        | I (Pull-UP)     | Input/output port pin*1/SPI data output pin                                                                                              |
| 111                                             | G14         | P20/SDI                     | I/O        | I (Pull-UP)     | Input/output port pin*1/SPI data input pin                                                                                               |
| 112                                             | G13         | VDD                         | -          | -               | Power supply pin (+)                                                                                                                     |
| 113                                             | F14         | P17/#SPISS                  | I/O        | I (Pull-UP)     | Input/output port pin (with interrupt)*1/SPI slave select input pin                                                                      |
| 114                                             | F12         | P16/EXCL0/                  | I/O        | I (Pull-UP)     | Input/output port pin (with interrupt)/T16 Ch.0 external clock input pin                                                                 |
| 4                                               | <b>E</b> /2 | TOUT5                       |            |                 | T8OSC1 PWM signal output pin                                                                                                             |
| 115                                             | F13         | P15/SCL                     | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt)*1/I2C clock output pin                                                                            |
| 116                                             | E13         | P14/SDA                     | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt)*1/I2C data input/output pin                                                                       |
| 117                                             | E14         | P13/FOUT1                   | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt)*1/USC1 clock output pin                                                                           |
| 118<br>119                                      | E12<br>G11  | P12/SCLK1<br>P11/SOUT1      | 1/0<br>1/0 | I (Pull-UP)     | Input/output port pin (with interrupt)*1/UART Ch.1 clock input pin<br>Input/output port pin (with interrupt)*1/UART Ch.1 data output pin |
| 119                                             | F11         | P10/SIN1                    | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt)*//OART Ch.1 data output pin                                                                       |
| 120                                             | E11         | P10/SINT<br>P07/EXCL1       | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt)/T16 Ch.1 external clock input pin                                                                 |
| 121                                             | D13         | P06/EXCL2                   | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt)/T16 Ch.2 external clock input pin                                                                 |
| 122                                             | D13<br>D14  | P05/TOUTN4                  | 1/O<br>1/O | I (Pull-UP)     | Input/output port pin (with interrupt)*1/T16E Ch.1 PWM signal inverted output pin                                                        |
| 124                                             | C14         | <b>P04</b> /TOUT4           | I/O        | I (Pull-UP)     | Input/output port pin (with interrupt)*1/T16E Ch.1 PWM signal output pin                                                                 |
| 124                                             | D12         | <b>P03</b> /REMO            | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt) / 1102 On 11 Will signal output pin                                                               |
| 126                                             | D12         | P02/REMI                    | 1/0        | I (Pull-UP)     | Input/output port pin (with interrupt) *1/Remote input pin                                                                               |
| 120                                             |             |                             |            | _ · (i uii-0i ) | Inserver por pin (with interrupt) / hemote input pin                                                                                     |

Table 1.3.2.1: Pin descriptions

#### **1 OVERVIEW**

| Pin/ba     | all No. | Name       | 1/0 | Default     | Function                                                                  |
|------------|---------|------------|-----|-------------|---------------------------------------------------------------------------|
| QFP        | VFBGA   | Name       | 1/0 | status      | Fullcaoli                                                                 |
| 127        | C13     | P01/EXCL4  | I/O | I (Pull-UP) | Input/output port pin (with interrupt)/T16E Ch.1 external clock input pin |
| 128        | C12     | P00/EXCL3  | I/O | I (Pull-UP) | Input/output port pin (with interrupt)/T16E Ch.0 external clock input pin |
| 130        | B13     | VDD        | -   | -           | Power supply pin (+)                                                      |
| 132        | *4      | Vss        | -   | -           | Power supply pin (GND)                                                    |
| 133, 135,  | *3      | COM0 to 15 | 0   | O (L)       | LCD common output pin                                                     |
| 137 to 150 |         |            |     |             |                                                                           |
| 151 to 175 | *2      | SEG0 to 24 | 0   | O (L)       | LCD segment output pin                                                    |

\*1: Default function settings

#### \*2: SEG0 to 71 ball numbers

| SEG No.  | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Ball No. | A8 | B8 | C8 | D8 | E7 | D7 | A7 | B7 | C7 | A6 | B6 | C6 | D6 | D5 | A5 | B5 |
| SEG No.  | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| Ball No. | C5 | A4 | B4 | C4 | A3 | B3 | A2 | C3 | B2 | B1 | C2 | C1 | D4 | D3 | D2 | D1 |
| SEG No.  | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
| Ball No  | E4 | E3 | E2 | E1 | F4 | F3 | F2 | F1 | G5 | G4 | G3 | G2 | G1 | H1 | H2 | H3 |
| SEG No.  | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 |
| Ball No. | H4 | J1 | J2 | J3 | J4 | K1 | K2 | K3 | J5 | K4 | L1 | L2 | L3 | M1 | M2 | N1 |
| SEG No.  | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 |    |    |    |    |    |    |    |    |
| Ball No. | N2 | P2 | N3 | M3 | L4 | M4 | P3 | N4 |    |    |    |    |    |    |    |    |

### \*3: COM0 to 31 ball numbers

| COM No.  | 0   | 1   | 2   | 3   | 4   | 5   | 6   | 7   | 8   | 9   | 10 | 11 | 12 | 13 | 14 | 15 |
|----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|
| Ball No. | A13 | B12 | A12 | C11 | B11 | A11 | D10 | C10 | B10 | A10 | E9 | D9 | C9 | B9 | E8 | A9 |
| COM No.  | 16  | 17  | 18  | 19  | 20  | 21  | 22  | 23  | 24  | 25  | 26 | 27 | 28 | 29 | 30 | 31 |
| Ball No. | P8  | N8  | P7  | N7  | M7  | N6  | P6  | L7  | M6  | L6  | P5 | N5 | M5 | L5 | K5 | P4 |

#### \*4: Vss ball numbers

B14, E5, E6, E10, F5,  $F6^{(note)}$ , F10, G10, H5, H10, J10, K6, K7, K8, K9, K10, L8, M8, M14 (note) The F6 pin does not exist in the VFBGA10H-180 package.

# **2 CPU**

The S1C17702 uses an S1C17 core as the core processor.

The S1C17 core is an original Seiko Epson 16-bit RISC processor.

It features low power consumption, high-speed operation, wide address space, main instruction single-clock execution, and gate-saving design. It is ideal for use in controllers or sequencers, in which 8-bit CPUs are widely used.

For detailed information on the S1C17 core, refer to the S1C17 Family S1C17 Core Manual.

# 2.1 S1C17 Core Features

### Processor type

- Seiko Epson original 16-bit RISC processor
- + 0.35  $\mu$ m to 0.15  $\mu$ m low-power CMOS process technology

### Instruction set

- Code length
   Fixed 16-bit length
- Number of instructions
- 111 basic instructions (184 in total)
- Execution cycleImmediate expansion instructions

Main instructions executed in one cycle s Expansion of immediate to 24 bits

• Compact, high-speed instruction set optimized for development with C

### Register set

- 24-bit general purpose register × 8
- 24-bit special register × 2
- 8-bit special register × 1

### Memory space, buses

- Up to 16M bytes of memory space (24-bit address)
- Harvard architecture with separate instruction bus (16-bit) and data bus (32-bit)

### Interrupt

- Supports reset, NMI, and 32 different types of external interrupt
- Irregular address interrupt
- Debug interrupt
- · Reading vector from vector table and direct branching to interrupt handler routines
- Permits software interrupts using vector numbers (all vector numbers can be specified)

### Power saving

- HALT (halt instruction)
- SLEEP (slp instruction)

### Coprocessor interface

- 16-bit × 16-bit + 32-bit product-sum processor
- 16-bit ÷ 16-bit divider

# 2.2 CPU Registers

The S1C17 core contains eight general purpose registers and three special registers.



|   |       | General purpose registers |       |
|---|-------|---------------------------|-------|
| В | it 23 |                           | Bit 0 |
| 7 |       | R7                        |       |
| 6 |       | R6                        |       |
| 5 |       | R5                        |       |
| 4 |       | R4                        |       |
| 3 |       | R3                        |       |
| 2 |       | R2                        |       |
| 1 |       | R1                        |       |
| 0 |       | R0                        |       |

# Conoral purpose registers

Figure 2.2.1: Registers

# 2.3 Instruction Set

The S1C17 core instruction codes are all 16-bit and fixed-length. Major instructions are executed in a single cycle using pipeline processing. For more information on the various instructions, refer to the *S1C17 Family S1C17 Core Manual*.

| Туре          |       | Mnemonic                   | Function                                                                                     |
|---------------|-------|----------------------------|----------------------------------------------------------------------------------------------|
| Data transfer | ld.b  | %rd,%rs                    | General purpose register (byte) $\rightarrow$ General purpose register (sign extension)      |
|               |       | %rd,[%rb]                  | Memory (byte) → General purpose register (sign extension)                                    |
|               |       | %rd,[%rb]+                 | Memory address post-increment/post-decrement                                                 |
|               |       | %rd,[%rb]-                 | A pre-decrement function can be used                                                         |
|               |       | %rd,-[%rb]                 |                                                                                              |
|               |       | <pre>%rd, [%sp+imm7]</pre> | Stack (byte) → General purpose register (sign extension)                                     |
|               |       | %rd,[imm7]                 | Memory (byte) → General purpose register (sign extension)                                    |
|               |       | [%rb],%rs                  | General purpose register (byte) → Memory                                                     |
|               |       | [%rb]+,%rs                 | Memory address post-increment/post-decrement                                                 |
|               |       | [%rb]-,%rs                 | A pre-decrement function can be used                                                         |
|               |       | -[%rb],%rs                 |                                                                                              |
|               |       | [%sp+imm7],%rs             | General purpose register (byte) → Stack                                                      |
|               |       | [imm7],%rs                 | General purpose register (byte) → Memory                                                     |
|               | ld.ub | %rd,%rs                    | General purpose register (byte) $\rightarrow$ General purpose register (zero extension)      |
|               |       | %rd,[%rb]                  | Memory (byte) → General purpose register (zero extension)                                    |
|               |       | %rd,[%rb]+                 | Memory address post-increment/post-decrement                                                 |
|               |       | %rd,[%rb]-                 | A pre-decrement function can be used                                                         |
|               |       | %rd,-[%rb]                 | 7                                                                                            |
|               |       | %rd,[%sp+imm7]             | Stack (byte) → General purpose register (zero extension)                                     |
|               |       | %rd,[imm7]                 | Memory (byte) → General purpose register (zero extension)                                    |
|               | ld    | %rd,%rs                    | General purpose register (16 bits) → General purpose register                                |
|               |       | %rd,sign7                  | Immediate → General purpose register (sign extension)                                        |
|               |       | %rd,[%rb]                  | Memory (16 bits) → General purpose register                                                  |
|               |       | %rd,[%rb]+                 | Memory address post-increment/post-decrement                                                 |
|               |       | %rd,[%rb]-                 | A pre-decrement function can be used                                                         |
|               |       | %rd,-[%rb]                 |                                                                                              |
|               |       | <pre>%rd, [%sp+imm7]</pre> | Stack (16 bits) → General purpose register                                                   |
|               |       | %rd,[imm7]                 | Memory (16 bits) → General purpose register                                                  |
|               |       | [%rb],%rs                  | General purpose register (16 bits) → Memory                                                  |
|               |       | [%rb]+,%rs                 | Memory address post-increment/post-decrement                                                 |
|               |       | [%rb]-,%rs                 | A pre-decrement function can be used                                                         |
|               |       | -[%rb],%rs                 |                                                                                              |
|               |       | [%sp+imm7],%rs             | General purpose register (16 bits) → Stack                                                   |
|               |       | [imm7],%rs                 | General purpose register (16 bits) → Memory                                                  |
|               | ld.a  | %rd, %rs                   | General purpose register (24 bits) → General purpose register                                |
|               |       | %rd,imm7                   | Immediate → General purpose register (zero extension)                                        |
|               |       | %rd,[%rb]                  | Memory (32 bits) $\rightarrow$ General purpose register (*1)                                 |
|               |       | %rd,[%rb]+                 | Memory address post-increment/post-decrement                                                 |
|               |       | %rd, [%rb] -               | A pre-decrement function can be used                                                         |
|               |       | 8rd, - [8rb]               |                                                                                              |
|               |       | %rd, [%sp+imm7]            | Stack (32 bits) → General purpose register (*1)                                              |
|               |       | %rd,[imm7]                 | Memory (32 bits) → General purpose register (*1)                                             |
|               |       | [%rb],%rs                  | General purpose register (32 bits, zero extension) → Memory (*1)                             |
|               |       | [%rb]+,%rs                 | Memory address post-increment/post-decrement                                                 |
|               |       | [%rb]-,%rs                 | A pre-decrement function can be used                                                         |
|               |       | -[%rb],%rs                 |                                                                                              |
|               |       | [%sp+imm7],%rs             | General purpose register (32 bits, zero extension) → Stack (*1)                              |
|               |       | [imm7],%rs                 | General purpose register (32 bits, zero extension) → Memory (*1)                             |
|               |       | %rd,%sp                    | SP $\rightarrow$ General purpose register (32 bits, 2ero extension) $\rightarrow$ Memory (1) |
|               |       |                            | PC → General purpose register                                                                |
|               |       | \$rd, %pc                  |                                                                                              |
|               |       | \$rd, [%sp]                | Stack (32 bits) → General purpose register (*1)                                              |
|               |       | \$rd, [%sp]+               | Stack pointer post-increment/post-decrement                                                  |
|               |       | %rd, [%sp] -               | A pre-decrement function can be used                                                         |
|               |       | %rd,-[%sp]                 |                                                                                              |

| Table 0.2.1. 01017 | aava instruction | 1:-+ |
|--------------------|------------------|------|
| Table 2.3.1: S1C17 | core instruction | list |

| Туре               |               | Mnemonic           | Function                                                                       |
|--------------------|---------------|--------------------|--------------------------------------------------------------------------------|
| Data transfer      | ld.a          | [%sp],%rs          | General purpose register (32 bits, zero extension) → Stack (*1)                |
|                    |               | [%sp]+,%rs         | Stack pointer post-increment/post-decrement                                    |
|                    |               | [%sp]-,% <i>rs</i> | A pre-decrement function can be used                                           |
|                    |               | -[%sp],%rs         |                                                                                |
|                    |               | %sp,% <i>rs</i>    | General purpose register (24 bits) → SP                                        |
|                    |               | %sp,imm7           | Immediate → SP                                                                 |
| nteger arithmetic  | add           | %rd,%rs            | Adds 16 bits between general purpose registers                                 |
| nieger antimitette | add/c         |                    | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | add/nc        | -                  | C = 0                                                                          |
|                    | add/ne<br>add | %rd,imm7           | Adds general purpose register and immediate 16 bits                            |
|                    |               |                    |                                                                                |
|                    | add.a         | %rd,%rs            | Adds 24 bits between general purpose registers                                 |
|                    | add.a/c       | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | add.a/nc      |                    | C = 0)                                                                         |
|                    | add.a         | %sp,% <i>rs</i>    | Adds SP and general purpose register 24 bits                                   |
|                    |               | %rd,imm7           | Adds general purpose register and immediate 24 bits                            |
|                    |               | %sp, <i>imm7</i>   | Adds SP and immediate 24 bits                                                  |
|                    | adc           | %rd,%rs            | Adds 16 bits with carry between general purpose registers                      |
|                    | adc/c         | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed wher    |
|                    | adc/nc        |                    | C = 0                                                                          |
|                    | adc           | %rd,imm7           | Adds general purpose register and immediate 16 bits with carry                 |
|                    | sub           | %rd,%rs            | Subtracts 16 bits between general purpose registers                            |
|                    | sub/c         | 010,010            | Supports conditional execution (/c: Executed when $C = 1$ , /nc: Executed when |
|                    |               | -                  |                                                                                |
|                    | sub/nc        | 0                  | C = 0                                                                          |
|                    | sub           | %rd,imm7           | Subtracts general purpose register and immediate 16 bits                       |
|                    | sub.a         | %rd,%rs            | Subtracts 24 bits between general purpose registers                            |
|                    | sub.a/c       | _                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | sub.a/nc      |                    | C = 0)                                                                         |
|                    | sub.a         | %sp,% <i>rs</i>    | Subtracts SP and general purpose register 24 bits                              |
|                    |               | %rd,imm7           | Subtracts general purpose register and immediate 24 bits                       |
|                    |               | %sp,imm7           | Subtracts SP and immediate 24 bits                                             |
| _                  | sbc           | %rd,%rs            | Subtracts 16 bits with carry between general purpose registers                 |
|                    | sbc/c         | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | sbc/nc        | -                  | C = 0                                                                          |
|                    | sbc           | %rd,imm7           | Subtracts general purpose register and immediate 16 bits with carry            |
|                    |               | %rd,%rs            |                                                                                |
|                    | cmp           | 51U, 51S           | Compares 16 bits between general purpose registers                             |
|                    | cmp/c         | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | cmp/nc        |                    | C = 0)                                                                         |
|                    | cmp           | %rd,sign7          | Compares general purpose registers and immediate 16 bits                       |
|                    | cmp.a         | %rd,%rs            | Compares 24 bits between general purpose registers                             |
|                    | cmp.a/c       | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | cmp.a/nc      |                    | C = 0)                                                                         |
|                    | cmp.a         | %rd,imm7           | Compares general purpose registers and immediate 24 bits                       |
|                    | cmc           | %rd,%rs            | Compares 16 bits with carry between general purpose registers                  |
|                    | cmc/c         |                    | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | cmc/nc        | -                  | C = 0                                                                          |
|                    | CmC           | %rd,sign7          | Compares general purpose register and immediate 16 bits with carry             |
| Logic operations   | and           | %rd,%rs            | AND operation between general purpose registers                                |
| Logic operations   | and/c         | ora, orb           | Supports conditional execution (/c: Executed when $C = 1$ , /nc: Executed when |
|                    |               | -                  |                                                                                |
|                    | and/nc        | 0.1.1.7            | C = 0                                                                          |
|                    | and           | %rd,sign7          | AND operation for general purpose register and immediate                       |
|                    | or            | %rd,%rs            | OR operation between general purpose registers                                 |
|                    | or/c          | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed wher    |
|                    | or/nc         |                    | C = 0)                                                                         |
|                    | or            | %rd,sign7          | OR operation for general purpose register and immediate                        |
|                    | xor           | %rd,%rs            | EXCLUSIVE OR between general purpose registers                                 |
|                    | xor/c         |                    | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | xor/nc        |                    | C = 0                                                                          |
|                    | xor           | %rd,sign7          | EXCLUSIVE OR for general purpose register and immediate                        |
|                    | not           | %rd,%rs            | NOT operation between general purpose registers (1 complement)                 |
|                    |               | 010,015            |                                                                                |
|                    | not/c         | -                  | Supports conditional execution (/c: Executed when C = 1, /nc: Executed when    |
|                    | not/nc<br>not |                    | C = 0                                                                          |
|                    |               | %rd,sign7          | NOT operation for general purpose register and immediate (1 complement)        |

| Туре               |                | Mnemonic      | Function                                                                       |
|--------------------|----------------|---------------|--------------------------------------------------------------------------------|
| Shift & swap       | sr             | %rd,%rs       | Right logic shift (shift bit number specified by register)                     |
|                    |                | %rd,imm7      | Right logic shift (shift bit number specified by immediate)                    |
|                    | sa             | %rd,%rs       | Right operation shift (shift bit number specified by register)                 |
|                    |                | %rd,imm7      | Right operation shift (shift bit number specified by immediate)                |
|                    | sl             | %rd,%rs       | Left logic shift (shift bit number specified by register)                      |
|                    |                | %rd,imm7      | Left logic shift (shift bit number specified by immediate)                     |
|                    | swap           | %rd,%rs       | Byte swap at 16-bit boundary                                                   |
| mmediate extension | ext            | imm13         | Extend operand for next instruction                                            |
| Conversion         | cv.ab          | %rd,%rs       | Convert 8-bit coded data to 24 bits                                            |
|                    | cv.as          | %rd,%rs       | Convert 16-bit coded data to 24 bits                                           |
|                    | cv.al          | %rd,%rs       | Convert 32-bit data to 24 bits                                                 |
|                    | cv.la          | %rd,%rs       | Convert 24-bit data to 32 bits                                                 |
|                    | cv.ls          | %rd,%rs       | Convert 16-bit data to 32 bits                                                 |
| Branch             | jpr            | sign10        | PC-relative jump                                                               |
|                    | jpr.d          | %rb           | Allows delayed branching                                                       |
|                    | jpa            | imm7          | Absolute jump                                                                  |
|                    | jpa.d          | %rb           | Allows delayed branching                                                       |
|                    | jrgt           | sign7         | Conditional PC-relative jump Branch conditions: !Z & !(N ^ V)                  |
|                    | jrgt.d         |               | Allows delayed branching                                                       |
|                    | jrge           | sign7         | Conditional PC-relative jump Branch conditions: !(N ^ V)                       |
|                    | jrge.d         |               | Allows delayed branching                                                       |
|                    | jrlt           | sign7         | Conditional PC-relative jump Branch conditions: N ^ V                          |
|                    | jrlt.d         |               | Allows delayed branching                                                       |
|                    | jrle           | sign7         | Conditional PC-relative jump Branch conditions: Z   N ^ V                      |
|                    | jrle.d         | 5             | Allows delayed branching                                                       |
|                    | jrugt          | sign7         | Conditional PC-relative jump Branch conditions: !Z & !C                        |
|                    | jrugt.d        | 5             | Allows delayed branching                                                       |
|                    | jruge          | sign7         | Conditional PC-relative jump Branch conditions: !C                             |
|                    | jruge.d        |               | Allows delayed branching                                                       |
| -                  | jrult          | sign7         | Conditional PC-relative jump Branch conditions: C                              |
|                    | jrult.d        | Sign,         | Allows delayed branching                                                       |
|                    | jrule          | sign7         | Conditional PC-relative jump Branch conditions: Z   C                          |
|                    | jrule.d        | Sign,         | Allows delayed branching                                                       |
|                    | jreq           | sign7         | Conditional PC-relative jump Branch conditions: Z                              |
|                    |                | Sign/         |                                                                                |
|                    | jreq.d<br>jrne | sign7         | Allows delayed branching<br>Conditional PC-relative jump Branch conditions: IZ |
|                    |                | Sign/         | Allows delayed branching                                                       |
|                    | jrne.d<br>call | aim10         | PC-relative subroutine call                                                    |
|                    |                | sign10<br>%rb |                                                                                |
|                    | call.d         |               | Allows delayed branching                                                       |
|                    | calla          | imm7          | Absolute subroutine call                                                       |
|                    | calla.d        | %rb           | Allows delayed branching                                                       |
|                    | ret            |               | Return from subroutine                                                         |
|                    | ret.d          |               | Allows delayed branching                                                       |
|                    | int            | imm5          | Software interrupt                                                             |
|                    | intl           | imm5,imm3     | Software interrupt with interrupt level specification                          |
|                    | reti           |               | Return from interrupt                                                          |
|                    | reti.d         |               | Allows delayed branching                                                       |
|                    | brk            |               | Debug interrupt                                                                |
|                    | retd           |               | Return from debug processing                                                   |
| System control     | nop            |               | No operation                                                                   |
|                    | halt           |               | HALT                                                                           |
|                    | slp            |               | SLEEP                                                                          |
|                    | ei             |               | Permits interrupt                                                              |
|                    | di             |               | Prevents interrupt                                                             |
| Coprocessor        | ld.cw          | %rd,%rs       | Transfer data to coprocessor                                                   |
| control            |                | %rd,imm7      |                                                                                |
|                    | ld.ca          | %rd,%rs       | Transfer data to coprocessor and obtain results and flag status                |
|                    | L              | %rd,imm7      |                                                                                |
|                    | ld.cf          | %rd,%rs       | Transfer data to coprocessor and obtain flag status                            |
|                    | 1              | %rd,imm7      |                                                                                |

\*1 Instruction 1d.a accesses 32-bit memory. When data is transferred from register to memory, 32 bits of data with the first 8 bits set to 0 are written to memory. When data is read from memory, the first 8 bits are ignored.

The codes used in this table are explained below.

### Table 2.3.2: Code meanings

| Code                      | Description                                                                           |
|---------------------------|---------------------------------------------------------------------------------------|
| %rs                       | General purpose source register                                                       |
| %rd                       | General purpose destination register                                                  |
| [%rb]                     | Memory specified indirectly by general purpose register                               |
| [%rb]+                    | Memory specified indirectly by general purpose register (with address post-increment) |
| [%rb]-                    | Memory specified indirectly by general purpose register (with address post-decrement) |
| -[%rb]                    | Memory specified indirectly by general purpose register (with address pre-decrement)  |
| %sp                       | Stack pointer                                                                         |
| [%sp],[%sp+ <i>imm</i> 7] | Stack                                                                                 |
| [%sp]+                    | Stack (with address post-increment)                                                   |
| [%sp]-                    | Stack (with address post-decrement)                                                   |
| -[%sp]                    | Stack (with address pre-decrement)                                                    |
| imm3,imm5,imm7,imm13      | Immediate without code (number indicates bit length)                                  |
| sign7,sign10              | Immediate with code (number indicates bit length)                                     |

## 2.4 Vector Table

The vector table contains the vectors (handler routine start addresses) for interrupt handler routines. When an interrupt occurs, the S1C17 core reads the vector corresponding to the interrupt and executes that handler routine. The boot address for starting program execution must be written at the top of the vector table after resetting.

The S1C17702 vector table starts from address 0x8000. The vector table base address can be read from the TTBR (vector table base register) at address 0xffff80.

Table 2.4.1 shows the S1C17702 vector table.

| Vector No./ Soft-<br>vare interrupt No. | Vector address | Hardware interrupt name            | Hardware interrupt factor                                                                  | Priorit |
|-----------------------------------------|----------------|------------------------------------|--------------------------------------------------------------------------------------------|---------|
| 0 (0x00)                                | TTBR + 0x00    | Reset                              | <ul> <li>Low input to #RESET pin</li> <li>Watchdog timer overflow <sup>*2</sup></li> </ul> | 1       |
| 1 (0x01)                                | TTBR + 0x04    | Irregular address interrupt        | Memory access instruction                                                                  | 2       |
| -                                       | (0xfffc00)     | Debug interrupt                    | brk instruction etc.                                                                       | 3       |
| 2 (0x02)                                | TTBR + 0x08    | NMI                                | Watchdog timer overflow *2                                                                 | 4       |
| 3 (0x03)                                | TTBR + 0x0c    | reserved                           | -                                                                                          | -       |
| 4 (0x04)                                | TTBR + 0x10    | P0 port interrupt                  | P00 to P07 port input                                                                      | High    |
| 5 (0x05)                                | TTBR + 0x14    | P1 port interrupt                  | P10 to P17 port input                                                                      | ^       |
| 6 (0x06)                                | TTBR + 0x18    | Stopwatch timer interrupt          | Timer 100 Hz signal                                                                        |         |
|                                         |                |                                    | Timer 10 Hz signal                                                                         |         |
|                                         |                |                                    | Timer 1 Hz signal                                                                          |         |
| 7 (0x07)                                | TTBR + 0x1c    | Clock timer interrupt              | Timer 32 Hz signal                                                                         |         |
|                                         |                | •                                  | Timer 8 Hz signal                                                                          |         |
|                                         |                |                                    | Timer 2 Hz signal                                                                          |         |
|                                         |                |                                    | Timer 1 Hz signal                                                                          |         |
| 8 (0x08)                                | TTBR + 0x20    | 8-bit OSC1 timer interrupt         | Compare match                                                                              |         |
| 9 (0x09)                                | TTBR + 0x24    | SVD interrupt                      | Detect power supply voltage drop                                                           |         |
| 10 (0x0a)                               | TTBR + 0x28    | LCD interrupt                      | Frame signal                                                                               |         |
| 11 (0x0b)                               | TTBR + 0x2c    | PWM & capture timer Ch.0 interrupt | Compare A                                                                                  |         |
| (0.002)                                 |                |                                    | Compare B                                                                                  |         |
| 12 (0x0c)                               | TTBR + 0x30    | 8-bit timer Ch.0 & Ch.1 interrupt  | Ch.0 underflow                                                                             |         |
| 12 (0,00)                               |                |                                    | Ch.1 underflow                                                                             |         |
| 13 (0x0d)                               | TTBR + 0x34    | 16-bit timer Ch.0 interrupt        | Timer underflow                                                                            |         |
| 14 (0x0e)                               | TTBR + 0x34    | 16-bit timer Ch.1 interrupt        | Timer underflow                                                                            |         |
| 15 (0x0f)                               | TTBR + 0x3c    | 16-bit timer Ch.2 interrupt        | Timer underflow                                                                            |         |
| . ,                                     |                | · · · · ·                          |                                                                                            |         |
| 16 (0x10)                               | TTBR + 0x40    | UART Ch.0 interrupt                | Transmit buffer empty                                                                      |         |
|                                         |                |                                    | Receive buffer full                                                                        |         |
|                                         |                |                                    | Receive error                                                                              |         |
| 17 (0x11)                               | TTBR + 0x44    | UART Ch.1 interrupt                | <ul> <li>Transmit buffer empty</li> </ul>                                                  |         |
|                                         |                |                                    | Receive buffer full                                                                        |         |
|                                         |                |                                    | Receive error                                                                              |         |
| 18 (0x12)                               | TTBR + 0x48    | SPI interrupt                      | <ul> <li>Transmit buffer empty</li> </ul>                                                  |         |
|                                         |                |                                    | Receive buffer full                                                                        |         |
| 19 (0x13)                               | TTBR + 0x4c    | I <sup>2</sup> C interrupt         | <ul> <li>Transmit buffer empty</li> </ul>                                                  |         |
|                                         |                |                                    | Receive buffer full                                                                        |         |
| 20 (0x14)                               | TTBR + 0x50    | Remote controller interrupt        | <ul> <li>Data length counter underflow</li> </ul>                                          |         |
|                                         |                |                                    | <ul> <li>Input rising edge detection</li> </ul>                                            |         |
|                                         |                |                                    | <ul> <li>Input falling edge detection</li> </ul>                                           |         |
| 21 (0x15)                               | TTBR + 0x54    | PWM & capture timer Ch.1 interrupt | Compare A                                                                                  |         |
| · · · /                                 |                |                                    | Compare B                                                                                  |         |
| 22 (0x16)                               | TTBR + 0x58    | reserved                           |                                                                                            |         |
|                                         |                |                                    |                                                                                            | L.      |
| 31 (0x1f)                               | TTBR + 0x7c    | reserved                           |                                                                                            | Low     |

| Table | 24        | 1• ' | Vector | table |
|-------|-----------|------|--------|-------|
| Table | <u></u> , | ••   | VCCLOI | labic |

\*1: When same interrupt level is set

\*2: Watchdog timer interrupt selects reset or NMI using software.

### 2 CPU

The base (top) address for the vector table for writing interrupt vectors can be set using the MISC\_TTBRL and MISC\_TTBRH registers (0x5328 and 0x532a). "TTBR" in Table 2.4.1 indicates the values set for these registers. The MISC\_TTBRL and MISC\_TTBRH registers are set to the 0x8000 address after initial resetting. This means only the reset vector must be written to the above address, even when changing the vector table location. Bits 7 to 0 in the MISC\_TTBRL register are fixed to 0; the initial address of the vector table normally starts from the 256 byte boundary.

| Register name            | Address   | Bit   | Name        | Function                          | Setting  | Init. | R/W | Remarks            |
|--------------------------|-----------|-------|-------------|-----------------------------------|----------|-------|-----|--------------------|
| Vector Table             | 0x5328    | D15-8 | TTBR[15:8]  | Vector table base address A[15:8] | 0x0–0xff | 0x80  | R/W |                    |
| Address Low              | (16 bits) | D7–0  | TTBR[7:0]   | Vector table base address A[7:0]  | 0x0      | 0x0   | R   |                    |
| Register<br>(MISC_TTBRL) |           |       |             | (fixed at 0)                      |          |       |     |                    |
| Vector Table             | 0x532a    | D15-8 | -           | reserved                          | -        | -     | -   | 0 when being read. |
| Address High             | (16 bits) | D7–0  | TTBR[23:16] | Vector table base address         | 0x0–0xff | 0x0   | R/W |                    |
| Register<br>(MISC_TTBRH) |           |       |             | A[23:16]                          |          |       |     |                    |

Note: The MISC\_TTBRL and MISC\_TTBRH registers are write-protected. To program to these registers, write-protection must be overridden by writing 0x96 to the MISC Protect Register (0x5324). Normally, the MISC Protect Register (0x5324) should be set to a value other than 0x96, except when writing to the MISC\_TTBRL and MISC\_TTBRH registers, since unnecessary programs may result in system malfunctions.

# 2.5 PSR Readout

The S1C17702 incorporates a PSR register (0x532c) for reading out the contents of the PSR (Processor Status Register) in the S1C17 core. Reading out the contents of this register makes it possible to check the contents of the PSR using application software. Note that data cannot be written to the PSR.

| Register name | Address                                                                                                         | Bit    | Name                      | Function                                           |         | Sett   | ing           | Init. | R/W | Remarks            |
|---------------|-----------------------------------------------------------------------------------------------------------------|--------|---------------------------|----------------------------------------------------|---------|--------|---------------|-------|-----|--------------------|
| PSR Register  | 0x532c                                                                                                          | D15-8  | -                         | reserved                                           |         | -      | -             | -     | -   | 0 when being read. |
| (MISC_PSR)    | (16 bits)                                                                                                       | D7–5   | PSRIL[2:0]                | PSR interrupt level (IL) bits                      |         | 0x0 to | o 0x7         | 0x0   | R   | -                  |
|               |                                                                                                                 | D4     | PSRIE                     | PSR interrupt enable (IE) bit                      | 1 1 (en | able)  | 0 0 (disable) | 0     | R   |                    |
|               |                                                                                                                 | D3     | PSRC                      | PSR carry (C) flag                                 | 1 1 (se |        | 0 (cleared)   | 0     | R   | ]                  |
|               |                                                                                                                 | D2     | PSRV                      | PSR overflow (V) flag                              | 1 1 (se |        | 0 (cleared)   | 0     | R   |                    |
|               |                                                                                                                 | D1     | PSRZ                      | PSR zero (Z) flag                                  | 1 1 (se | t)     | 0 (cleared)   | 0     | R   |                    |
|               |                                                                                                                 | D0     | PSRN                      | PSR negative (N) flag                              | 1 1 (se | t)     | 0 (cleared)   | 0     | R   |                    |
| D4            | Read out the value (interrupt level) of the IL bit of the PSR. (default: 0x0)                                   |        |                           |                                                    |         |        |               |       |     |                    |
| D3            | PSRC: F                                                                                                         | PSR Ca | arry (C) F<br>ue of the I | ed) (default)<br><b>lag</b><br>PSR C (carry) flag. |         |        |               |       |     |                    |
|               | PSRV: PSR Overflow (V) Flag<br>Read out the value of the PSR V (overflow) flag.<br>1(R): 1<br>0(R): 0 (default) |        |                           |                                                    |         |        |               |       |     |                    |
|               | PSRZ: PSR Zero (Z) Flag<br>Read out the value of the PSR Z (zero) flag.<br>1(R): 1<br>0(R): 0 (default)         |        |                           |                                                    |         |        |               |       |     |                    |
|               |                                                                                                                 |        | egative (N<br>ue of the F | <b>V) Flag</b><br>PSR N (negative) flag.           |         |        |               |       |     |                    |

### 0x532c: PSR Register (MISC\_PSR)

1(R): 1 0(R): 0 (default)

## 2.6 Processor Information

The S1C17702 contains a processor ID register (0xffff84) to allow specification of the CPU core type by the application software.

### 0xffff84: Processor ID Register (IDIR)

| Register name                      | Address              | Bit  | Name | Function                         | Setting | Init. | R/W | Remarks |
|------------------------------------|----------------------|------|------|----------------------------------|---------|-------|-----|---------|
| Processor ID<br>Register<br>(IDIR) | 0xffff84<br>(8 bits) | D7–0 |      | Processor ID<br>0x10: S1C17 Core | 0x10    | 0x10  | R   |         |

This is the read-only register containing the ID code indicating the processor type. The S1C17 core ID code is 0x10.

# **3** Memory Map and Bus Control

Figure 3.1 shows the S1C17702 memory map.

|                                |       |                                    |              |        |    | Periphe | eral functions (D            | evice size) |
|--------------------------------|-------|------------------------------------|--------------|--------|----|---------|------------------------------|-------------|
| 0xff                           | ffff  | Core I/O reserved area             |              | 0x5380 | to | 0x5fff  | reserved                     | -           |
|                                |       |                                    |              | 0x5360 | to | 0x537f  | PWM & capture timer Ch.1     | (16 bits)   |
| 0xff                           | fc00  | (1K bytes, 1 cycle)                |              | 0x5340 | to | 0x535f  | Remote controller            | (16 bits)   |
| 0xff                           | fbff  | reserved                           |              | 0x5320 | to | 0x533f  | MISC register                | (16 bits)   |
| 0x08                           | 0560  | reserved                           | /            | 0x5300 | to | 0x531f  | PWM & capture timer Ch.0     | (16 bits)   |
| 0x08                           | 055f  | Display RAM area                   |              | 0x52c0 | to | 0x52ff  | reserved                     | -           |
|                                |       | (576 bytes, 2–5 cycles)            |              | 0x52a0 | to | 0x52bf  | Port MUX                     | (8 bits)    |
| 0x08                           | 0000  | (Device size: 8 bits)              |              | 0x5280 | to | 0x529f  | reserved                     | -           |
| 0x07                           | ffff  | reserved                           |              | 0x5200 | to | 0x527f  | P port                       | (8 bits)    |
| 0x02                           | 8000  | leselved                           |              |        |    |         | reserved                     | -           |
| 0x02                           | 7fff  |                                    |              | 0x5120 | to | 0x513f  | Power supply control circuit | (8 bits)    |
|                                |       | Flash area                         |              | 0x5100 | to | 0x511f  | SVD circuit                  | (8 bits)    |
|                                |       | (128K bytes, 1–5 cycles)           |              | 0x50e0 | to | 0x50ff  | reserved                     | -           |
|                                |       | (Device size: 16 bits)             |              | 0x50c0 | to | 0x50df  | 8-bit OSC1 timer             | (8 bits)    |
|                                |       | (Device size. To bits)             |              |        |    |         | LCD driver                   | (8 bits)    |
|                                |       |                                    |              |        |    |         | Clock generator              | (8 bits)    |
| 0x00                           | 8000  | Vector table                       |              |        |    |         | Oscillator circuit           | (8 bits)    |
| 0x00                           | 7fff  | reserved                           | /            |        |    |         | Watchdog timer               | (8 bits)    |
| 0x00                           |       | leselved                           | /            |        |    |         | Stopwatch timer              | (8 bits)    |
| 0x00                           | 5fff  | Internal peripheral circuit area 2 |              | 0x5000 | to | 0x501f  | Clock timer                  | (8 bits)    |
|                                |       | (4K bytes, 1 cycle)                |              | 1      |    |         |                              |             |
| $0 \times 00$                  | 5000  |                                    | //           |        |    |         | reserved                     | -           |
| 0x00                           | 4fff  | reserved                           |              |        |    | 0x435f  |                              | (16 bits)   |
| 0x00                           |       | 10001704                           |              | 1      |    | 0x433f  | ••••                         | (16 bits)   |
| 0x00                           | 43ff  | Internal peripheral circuit area 1 |              |        |    |         | Interrupt controller         | (16 bits)   |
|                                |       | (1K bytes, 1 cycle)                |              |        |    |         | reserved                     | -           |
| 0x00                           |       |                                    |              |        |    |         | 8-bit timer Ch.1             | (16 bits)   |
| 0x00                           | 3fff  | reserved                           | $\backslash$ |        |    |         | 16-bit timer Ch.2            | (16 bits)   |
| 0x00                           |       |                                    | $\backslash$ |        |    |         | 16-bit timer Ch.1            | (16 bits)   |
| $0 \times 0 0 \\ 0 \times 0 0$ | 2ffc0 | Debug RAM area (64 bytes)          |              |        |    |         | 16-bit timer Ch.0            | (16 bits)   |
| 01100                          | 2100  |                                    |              |        |    |         | 8-bit timer                  | (16 bits)   |
|                                |       | Internal RAM area                  |              |        |    |         | reserved                     | -           |
|                                |       | (12K bytes, 1 cycle)               |              |        |    | 0x413f  |                              | (8 bits)    |
|                                |       | (Device size: 32 bits)             |              | 1      |    |         | reserved                     | -           |
| 0x00                           | 0000  |                                    |              |        |    |         | Prescaler                    | (8 bits)    |
|                                |       |                                    | \            | 0x4000 | to | 0x401f  | reserved                     | -           |

Figure 3.1: S1C17702 memory map

# 3.1 Bus Cycle

The CPU operates with CCLK as the operating clock. For more information on CCLK, refer to "8.2 CPU Core Clock (CCLK) Control."

The time from one CCLK rising rdge to the next forms 1 CCLK, defined as one bus cycle. As shown in Figure 3.1, the number of cycles required for a single bus access depends on the peripheral circuits and memory. The number of bus accesses also varies and depends on the CPU instruction (access size) and device size.

| Device size | CPU access size | Bus access number |  |  |  |  |  |
|-------------|-----------------|-------------------|--|--|--|--|--|
| 8 bits      | 8 bits          | 1                 |  |  |  |  |  |
|             | 16 bits         | 2                 |  |  |  |  |  |
|             | 32 bits*        | 4                 |  |  |  |  |  |
| 16 bits     | 8 bits          | 1                 |  |  |  |  |  |
|             | 16 bits         | 1                 |  |  |  |  |  |
|             | 32 bits *       | 2                 |  |  |  |  |  |
| 32 bits     | 8 bits          | 1                 |  |  |  |  |  |
|             | 16 bits         | 1                 |  |  |  |  |  |
|             | 32 bits *       | 1                 |  |  |  |  |  |

| Table 3.1.1: | Bus | access | number |
|--------------|-----|--------|--------|
|--------------|-----|--------|--------|

#### \* First 8 bits of data for 32-bit data access

The first 8 bits of 32-bit data are written to memory as 0. The first 8 bits are ignored when read from memory. Interrupt processing stack operation involves reading and writing 32 bits with the PSR value in the first 8 bits and the return address in the last 24 bits.

#### Bus cycle calculation example

Number of bus cycles when accessing Display RAM area (8-bit device, 2 cycles) from CPU using 16-bit read/ program instruction:

 $2 \text{ cycles} \times 2 \text{ bus accesses} = 4 \text{ CCLK cycles}$ 

### 3.1.1 Access Size Restrictions

When programming, note that the modules listed below are subject to access size restrictions.

### **Flash memory**

Only 16-bit program instructions can be used for flash memory programming. No particular restrictions apply for data reads.

All other modules can be accessed using 8-bit, 16-bit, and 32-bit instructions. Where possible, we recommend matching access to device size. Reading from non-essential registers may alter the state of peripheral circuits and cause problems.

### 3.1.2 Instruction Execution Cycle Restrictions

In the event of any of the conditions listed below, instruction fetch and data access will not be performed simultaneously, and the instruction fetch cycle will be extended by the amount of access cycles for the areas in which data exists.

- If a instruction is executed for the flash area accessing flash area, display RAM area, and internal peripheral circuit area 2 (0x5000 onward) data
- If a instruction is executed for an internal RAM area accessing internal RAM area data

## 3.2 Flash Area

### 3.2.1 Internal Flash Memory

The 128K-byte area from 0x8000 to 0x27fff contains flash memory (4K bytes  $\times$  32 sectors) enabling data or application programs to be written. Address 0x8000 is defined as the vector table base address. The vector table (see "2.4 Vector Table") must be placed at the start of this area. The vector table base address can be modified with the MISC\_TTBRL/MISC\_TTBRH registers (0x5328 and 0x532a).

Flash memory is read in 1 to 5 cycles.

### 3.2.2 Flash Memory Programming

The S1C17702 supports onboard flash memory programming, allowing programs or data to be written by a debugger via the ICD (e.g. S5U1C17001H). Self-writing is also possible via software. Programming uses 16-bit units. For specific information on flash memory programming, refer to "Appendix B: Flash Memory Programming."

Data can be deleted either using chip erase or sector erase. Refer to the table below for detailed information on the correspondence between addresses and sectors used for sector erase.

| Note: Debuggers support chip erase only. Sector erase is not possible using debuggers. |  |
|----------------------------------------------------------------------------------------|--|
| Table 2.0.0.1. Compared and a between memory addresses and flock as show               |  |

| Table 3.2.2.1: Correspondence between memory addresses and flash sectors |                     |    |                   |                     |  |  |  |  |
|--------------------------------------------------------------------------|---------------------|----|-------------------|---------------------|--|--|--|--|
| S1C17702 address                                                         | Flash sector number |    | S1C17702 address  | Flash sector number |  |  |  |  |
| 0x17000 to 0x17fff                                                       | 15                  | 0: | x27000 to 0x27fff | 31                  |  |  |  |  |
| 0x16000 to 0x16fff                                                       | 14                  | 0: | x26000 to 0x26fff | 30                  |  |  |  |  |
| 0x15000 to 0x15fff                                                       | 13                  | 0: | x25000 to 0x25fff | 29                  |  |  |  |  |
| 0x14000 to 0x14fff                                                       | 12                  | 0: | x24000 to 0x24fff | 28                  |  |  |  |  |
| 0x13000 to 0x13fff                                                       | 11                  | 0: | x23000 to 0x23fff | 27                  |  |  |  |  |
| 0x12000 to 0x12fff                                                       | 10                  | 0: | x22000 to 0x22fff | 26                  |  |  |  |  |
| 0x11000 to 0x11fff                                                       | 9                   | 0: | x21000 to 0x21fff | 25                  |  |  |  |  |
| 0x10000 to 0x10fff                                                       | 8                   | 0: | x20000 to 0x20fff | 24                  |  |  |  |  |
| 0x0f000 to 0x0ffff                                                       | 7                   | 0: | x1f000 to 0x1ffff | 23                  |  |  |  |  |
| 0x0e000 to 0x0efff                                                       | 6                   | 0: | x1e000 to 0x1efff | 22                  |  |  |  |  |
| 0x0d000 to 0x0dfff                                                       | 5                   | 0: | x1d000 to 0x1dfff | 21                  |  |  |  |  |
| 0x0c000 to 0x0cfff                                                       | 4                   | 0: | x1c000 to 0x1cfff | 20                  |  |  |  |  |
| 0x0b000 to 0x0bfff                                                       | 3                   | 0: | x1b000 to 0x1bfff | 19                  |  |  |  |  |
| 0x0a000 to 0x0afff                                                       | 2                   | 0: | x1a000 to 0x1afff | 18                  |  |  |  |  |
| 0x09000 to 0x09fff                                                       | 1                   | 0: | x19000 to 0x19fff | 17                  |  |  |  |  |
| 0x08000 to 0x08fff                                                       | 0                   | 0: | x18000 to 0x18fff | 16                  |  |  |  |  |

Note: The last 32 bits (0x27ffc to 0x27fff) of sector 31 are reserved by the system as protect bits. Be careful to ensure that data other than protection settings is not written to these bits.

### 3.2.3 Protect Bits

Write-protect and data read-protect can be set in the respective 16K-byte areas to protect internal flash memory contents.

Write-protect prevents data writing to the set area.

Data read-protect prevents data reading from the set area (the value read is always 0x0000). Note that CPU instruction fetch operations are not protected.

This setting uses the protect bits listed below. To set protection, program the protect bit corresponding to the area to be set to 0.

### 0x27ffc-0x27ffe: Flash Protect Bits

| Address   | Bit   | Function                                        |   | Set      | ting | 9         | Init. | R/W | Remarks           |
|-----------|-------|-------------------------------------------------|---|----------|------|-----------|-------|-----|-------------------|
| 0x27ffc   | D15–8 | reserved                                        | _ |          |      | -         | -     |     |                   |
| (16 bits) | D7    | Flash write-protect bit for 0x24000–0x27fff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D6    | Flash write-protect bit for 0x20000-0x23fff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D5    | Flash write-protect bit for 0x1c000–0x1ffff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D4    | Flash write-protect bit for 0x18000–0x1bfff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D3    | Flash write-protect bit for 0x14000–0x17fff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D2    | Flash write-protect bit for 0x10000–0x13fff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D1    | Flash write-protect bit for 0x0c000–0x0ffff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
|           | D0    | Flash write-protect bit for 0x08000–0x0bfff     | 1 | Writable | 0    | Protected | 1     | R/W |                   |
| 0x27ffe   | D15–4 | reserved                                        |   | -        | _    |           | -     | -   |                   |
| (16 bits) | D7    | Flash data-read-protect bit for 0x24000–0x27fff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D6    | Flash data-read-protect bit for 0x20000–0x23fff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D5    | Flash data-read-protect bit for 0x1c000–0x1ffff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D4    | Flash data-read-protect bit for 0x18000–0x1bfff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D3    | Flash data-read-protect bit for 0x14000–0x17fff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D2    | Flash data-read-protect bit for 0x10000–0x13fff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D1    | Flash data-read-protect bit for 0x0c000–0x0ffff | 1 | Readable | 0    | Protected | 1     | R/W |                   |
|           | D0    | reserved                                        |   |          | 1    |           | 1     | R/W | Must be set to 1. |

Note: • Do not place the area set for data read-protect in the .data or .rodata sections.

• D0 of 0x27ffe must always be set to 1. The program cannot be booted if this is set to 0.

### 3.2.4 Flash Controller Access Control

The S1C17702 internal flash memory is accessed via a dedicated flash controller. The MISC register is used for setting access to this controller.

### Flash controller read access cycle settings

Set the optimum read access cycles using FLCYC[2:0] (D[2:0]/MISC\_FL register) to suit the CCLK frequency to ensure that data is read correctly from the flash memory.

### 0x5320: FLASHC/SRAMC Control Register (MISC\_FL)

| Register name | Address   | Bit    | Name       | Function                 | Set        | ting         | Init. | R/W | Remarks            |
|---------------|-----------|--------|------------|--------------------------|------------|--------------|-------|-----|--------------------|
| FLASHC/       | 0x5320    | D15–10 | -          | reserved                 | -          | -            | -     | -   | 0 when being read. |
| SRAMC Control | (16 bits) | D9–8   | SRCYC[1:0] | SRAMC access cycle       | SRCYC[1:0] | Access cycle | 0x3   | R/W |                    |
| Register      |           |        |            |                          | 0x3        | 5 cycles     |       |     |                    |
| (MISC_FL)     |           |        |            |                          | 0x2        | 4 cycles     |       |     |                    |
|               |           |        |            |                          | 0x1        | 3 cycles     |       |     |                    |
|               |           |        |            |                          | 0x0        | 2 cycles     |       |     |                    |
|               |           | D7–3   | -          | reserved                 | -          | -            | -     | -   | 0 when being read. |
|               |           | D20    | FLCYC[2:0] | FLASHC read access cycle | FLCYC[2:0] | Read cycle   | 0x3   | R/W |                    |
|               |           |        |            |                          | 0x7-0x5    | reserved     |       |     |                    |
|               |           |        |            |                          | 0x4        | 1 cycle      |       |     |                    |
|               |           |        |            |                          | 0x3        | 5 cycles     |       |     |                    |
|               |           |        |            |                          | 0x2        | 4 cycles     |       |     |                    |
|               |           |        |            |                          | 0x1        | 3 cycles     |       |     |                    |
|               |           |        |            |                          | 0x0        | 2 cycles     |       |     |                    |

### D[2:0] FLCYC[2:0]: FLASHC Read Access Cycle Setup Bits

Sets the number of read access cycles for the flash controller.

| Table 0.2.4.1. Thas controller read access cycle settings |                    |                |  |  |  |  |  |
|-----------------------------------------------------------|--------------------|----------------|--|--|--|--|--|
| FLCYC[2:0]                                                | Read access cycles | CCLK frequency |  |  |  |  |  |
| 0x7 to 0x5                                                | Reserved           | -              |  |  |  |  |  |
| 0x4                                                       | 1 cycle            | 8.2 MHz max.   |  |  |  |  |  |
| 0x3                                                       | 5 cycles           | 8.2 MHz max.   |  |  |  |  |  |
| 0x2                                                       | 4 cycles           | 8.2 MHz max.   |  |  |  |  |  |
| 0x1                                                       | 3 cycles           | 8.2 MHz max.   |  |  |  |  |  |
| 0x0                                                       | 2 cycles           | 8.2 MHz max.   |  |  |  |  |  |

| Table 3.2.4.1: Flash controller read a | access cycle settings |
|----------------------------------------|-----------------------|
|                                        |                       |

(Default: 0x3)

- Note: Do not set the read access cycles to a value exceeding the CCLK maximum permissible frequency. This will cause malfunctions.
  - For maximum performance, set FLCYC[2:0] = 0x4.

# 3.3 Internal RAM Area

## 3.3.1 Internal RAM

RAM exists in a 12-Kbyte area from address 0x0 to 0x2fff. This RAM can be accessed in one cycle for reading or writing. In addition to storing variables, it can also be used to copy instruction codes and execute them rapidly in RAM.

Note: The last 64 bytes of the internal RAM (0x2fc0 to 0x2fff) are reserved for on-chip debugging. This area should not be accessed by application programs when using debug functions (for example, during application development).

It can be used for applications in mass-produced products that do not require debugging.

| Register name   | Address   | Bit   | Name        | Function                  |    | Set       | ting       | Init. | R/W | Remarks            |
|-----------------|-----------|-------|-------------|---------------------------|----|-----------|------------|-------|-----|--------------------|
| IRAM Size       | 0x5326    | D15–9 | -           | reserved                  |    | -         | -          | -     | -   | 0 when being read. |
| Select Register | (16 bits) | D8    | DBADR       | Debug base address select | 1  | 0x0       | 0 0xfffc00 | 0     | R/W |                    |
| (MISC_IRAMSZ)   |           | D7–2  | -           | reserved                  |    | -         | -          | -     | -   | 0 when being read. |
|                 |           | D1–0  | IRAMSZ[1:0] | IRAM size select          | IF | AMSZ[1:0] | Read cycle | 0x0   | R/W |                    |
|                 |           |       |             |                           |    | 0x3       | reserved   | 1     |     |                    |
|                 |           |       |             |                           |    | 0x2       | reserved   |       |     |                    |
|                 |           |       |             |                           |    | 0x1       | reserved   |       |     |                    |
|                 |           |       |             |                           |    | 0x0       | reserved   |       |     |                    |

## 0x5326: IRAM Size Select Register (MISC\_IRAMSZ)

## D[1:0] IRAMSZ[1:0]: IRAM Size Select Bits

Selects the internal RAM size used.

| IRAMSZ[1:0] | Internal RAM size |
|-------------|-------------------|
| 0x3         | Reserved          |
| 0x2         | Reserved          |
| 0x1         | Reserved          |
| 0x0         | Reserved          |
|             |                   |

Table 3.3.1.1: Internal RAM size selection

(Default: 0x0)

- Note: The IRAM Size Select Register is write-protected. The write-protection must be overridden by writing 0x96 to the MISC Protect Register (0x5324). Note that MISC Protect Register (0x5324) should normally be set to a value other than 0x96, except when writing to the IRAM Size Select Register. Unnecessary programs may result in system malfunctions.
  - Do not alter IRAMSZ[1:0] (D[1:0]/MISC\_IRAMSZ register) from the default value.

## 3.4 Display RAM Area

## 3.4.1 Display RAM

The 576-byte area from address 0x80000 to 0x8055f is assigned as an 8-bit device by the display RAM for internal LCD driver. This RAM is accessed in 2 to 5 cycles. Areas not used for display can be used for general purposes. For specific information on the display memory, refer to "22.5 Display Memory".

## 3.4.2 SRAM Controller Access Control

The S1C17702 display RAM is accessed via a dedicated SRAM controller. The MISC register is used to set access to this controller.

## SRAM controller access cycle settings

Set the optimum access cycles using SRCYC[1:0] (D[9:8]/MISC\_FL register) to suit the CCLK frequency to ensure that data is read or written correctly to or from the display RAM.

## 0x5320: FLASHC/SRAMC Control Register (MISC\_FL)

| Register name | Address   | Bit    | Name       | Function                 | Set        | ting         | Init. | R/W | Remarks            |
|---------------|-----------|--------|------------|--------------------------|------------|--------------|-------|-----|--------------------|
| FLASHC/       | 0x5320    | D15–10 | -          | reserved                 | -          | _            | -     | -   | 0 when being read. |
| SRAMC Control | (16 bits) | D9–8   | SRCYC[1:0] | SRAMC access cycle       | SRCYC[1:0] | Access cycle | 0x3   | R/W |                    |
| Register      |           |        |            |                          | 0x3        | 5 cycles     |       |     |                    |
| (MISC_FL)     |           |        |            |                          | 0x2        | 4 cycles     |       |     |                    |
|               |           |        |            |                          | 0x1        | 3 cycles     |       |     |                    |
|               |           |        |            |                          | 0x0        | 2 cycles     |       |     |                    |
|               |           | D7–3   | -          | reserved                 | -          | _            | -     | -   | 0 when being read. |
|               |           | D2–0   | FLCYC[2:0] | FLASHC read access cycle | FLCYC[2:0] | Read cycle   | 0x3   | R/W |                    |
|               |           |        |            |                          | 0x7-0x5    | reserved     | 1     |     |                    |
|               |           |        |            |                          | 0x4        | 1 cycle      |       |     |                    |
|               |           |        |            |                          | 0x3        | 5 cycles     |       |     |                    |
|               |           |        |            |                          | 0x2        | 4 cycles     |       |     |                    |
|               |           |        |            |                          | 0x1        | 3 cycles     |       |     |                    |
|               |           |        |            |                          | 0x0        | 2 cycles     |       |     |                    |

## D[9:8] SRCYC[1:0]: SRAMC Access Cycle Setup Bits

Sets the number of access cycles for the SRAM (display RAM) controller.

| SRCYC[1:0] | Access cycles | CCLK frequency |
|------------|---------------|----------------|
| 0x3        | 5 cycles      | 8.2 MHz max.   |
| 0x2        | 4 cycles      | 8.2 MHz max.   |
| 0x1        | 3 cycles      | 8.2 MHz max.   |
| 0x0        | 2 cycles      | 6 MHz max.     |

#### Table 3.4.2.1: SRAM controller access cycle settings

(Default: 0x3)

# 3.5 Internal Peripheral Circuit Area

The 1K-byte area starting at address 0x4000 and the 4K-byte area from 0x5000 are assigned for use as internal peripheral circuit I/O and control registers.

## 3.5.1 Internal Peripheral Circuit Area 1 (0x4000 onward)

The internal peripheral circuit area 1 starting at address 0x4000 is assigned for use as the following internal peripheral function I/O memory and can be accessed in a single cycle.

- Prescaler (PSC, 8-bit device)
- UART (UART, 8-bit device)
- 8-bit timer (T8F, 16-bit device)
- 16-bit timer (T16, 16-bit device)
- Interrupt controller (ITC, 16-bit device)
- SPI (SPI, 16-bit device)
- I<sup>2</sup>C (I<sup>2</sup>C, 16-bit device)

## 3.5.2 Internal Peripheral Circuit Area 2 (0x5000 onward)

The internal peripheral circuit area 2 starting at address 0x5000 is assigned for use as the following internal peripheral function I/O memory, and can be accessed in one cycle.

- Clock timer (CT, 8-bit device)
- Stopwatch timer (SWT, 8-bit device)
- Watchdog timer (WDT, 8-bit device)
- Oscillator circuit (OSC, 8-bit device)
- Clock generator (CLG, 8-bit device)
- LCD driver (LCD, 8-bit device)
- 8-bit OSC1 timer (T8OSC1, 8-bit device)
- SVD circuit (SVD, 8-bit device)
- Power supply circuit (VD1, 8-bit device)
- Input/output port & port MUX (P, 8-bit device)
- PWM & capture timer (T16E, 16-bit device)
- MISC register (MISC, 16-bit device)
- Remote controller (REMC, 16-bit device)

## 3.5.3 I/O Map

The I/O map for the internal peripheral circuit area is shown below. For more information on control registers, refer to the I/O register list in the Appendix or the corresponding peripheral circuit explanations.

| Peripheral circuit       | Address          |           | Register name                                 | Function                                                             |
|--------------------------|------------------|-----------|-----------------------------------------------|----------------------------------------------------------------------|
| Prescaler                | 0x4020           | PSC_CTL   | Prescaler Control Register                    | Prescaler start/stop control                                         |
| (8-bit device)           |                  | F30_01L   |                                               |                                                                      |
| UART (with IrDA)         | 0x4021 to 0x403f |           | -                                             | Reserved                                                             |
| Ch.0                     | 0x4100           | UART_STO  | UART Ch.0 Status Register                     | Transfer, buffer, and error status display                           |
| (8-bit device)           | 0x4101           |           | UART Ch.0 Transmit Data Register              | Transmission data                                                    |
| (,                       | 0x4102           |           | UART Ch.0 Receive Data Register               | Received data                                                        |
|                          | 0x4103           |           | UART Ch.0 Mode Register                       | Transfer data format setting                                         |
|                          | 0x4104           |           | UART Ch.0 Control Register                    | Data transfer control                                                |
|                          | 0x4105           | UARI_EXPU | UART Ch.0 Expansion Register                  | IrDA mode setting                                                    |
|                          | 0x4106 to 0x411f |           | -                                             | Reserved                                                             |
| UART (with IrDA)<br>Ch.1 | 0x4120           | UART_ST1  | UART Ch.1 Status Register                     | Transfer, buffer, and error status display                           |
| (8-bit device)           | 0x4121           |           | UART Ch.1 Transmit Data Register              | Transmission data                                                    |
| (0 511 001100)           | 0x4122           |           | UART Ch.1 Receive Data Register               | Received data                                                        |
|                          | 0x4123           |           | UART Ch.1 Mode Register                       | Transfer data format setting                                         |
|                          | 0x4124           |           | UART Ch.1 Control Register                    | Data transfer control                                                |
|                          | 0x4125           | UART_EXP1 | UART Ch.1 Expansion Register                  | IrDA mode setting                                                    |
|                          | 0x4126 to 0x413f | -         |                                               | Reserved                                                             |
| 8-bit timer              | 0x4200           | T8F_CLK   | 8-bit Timer Input Clock Select Register       | Prescaler output clock selection                                     |
| (with F mode)<br>Ch.0    | 0x4202           | T8F_TR    | 8-bit Timer Reload Data Register              | Reload data setting                                                  |
| (16-bit device)          | 0x4204           | T8F_TC    | 8-bit Timer Counter Data Register             | Counter data                                                         |
|                          | 0x4206           | T8F_CTL   | 8-bit Timer Control Register                  | Timer mode setting and timer RUN/STOP                                |
|                          | 0x4208           | T8F_INT   | 8-bit Timer Interrupt Control Register        | Interrupt control                                                    |
|                          | 0x420a to 0x421f | -         | -                                             | Reserved                                                             |
| 16-bit timer Ch.0        | 0x4220           | T16_CLK0  | 16-bit Timer Ch.0 Input Clock Select Register | Prescaler output clock selection                                     |
| (16-bit device)          | 0x4222           | T16_TR0   | 16-bit Timer Ch.0 Reload Data Register        | Reload data setting                                                  |
|                          | 0x 24            | T16_TC0   | 16-bit Timer Ch.0 Counter Data Register       | Counter data                                                         |
|                          | 0x4226           | T16_CTL0  | 16-bit Timer Ch.0 Control Register            | Timer mode setting and timer RUN/STOP                                |
|                          | 0x4228           | T16_INT0  | 16-bit Timer Ch.0 Interrupt Control Register  | Interrupt control                                                    |
|                          | 0x422a to 0x423f | -         | -                                             | Reserved                                                             |
| 16-bit timer Ch.1        | 0x4240           | T16_CLK1  | 16-bit Timer Ch.1 Input Clock Select Register | Prescaler output clock selection                                     |
| (16-bit device)          | 0x4242           | T16_TR1   | 16-bit Timer Ch.1 Reload Data Register        | Reload data setting                                                  |
|                          | 0x4244           | T16_TC1   | 16-bit Timer Ch.1 Counter Data Register       | Counter data                                                         |
|                          | 0x4246           | T16_CTL1  | 16-bit Timer Ch.1 Control Register            | Timer mode setting and timer RUN/STOP                                |
|                          | 0x4248           | T16_INT1  | 16-bit Timer Ch.1 Interrupt Control Register  | Interrupt control                                                    |
|                          | 0x424a to 0x425f | _         | -                                             | Reserved                                                             |
| 16-bit timer Ch.2        | 0x4260           | T16_CLK2  | 16-bit Timer Ch.2 Input Clock Select Register | Prescaler output clock selection                                     |
| (16-bit device)          | 0x4262           |           | 16-bit Timer Ch.2 Reload Data Register        | Reload data setting                                                  |
|                          | 0x4264           |           | 16-bit Timer Ch.2 Counter Data Register       | Counter data                                                         |
|                          | 0x4266           | T16_CTL2  | 16-bit Timer Ch.2 Control Register            | Timer mode setting and timer RUN/STOP                                |
|                          | 0x4268           | T16_INT2  | 16-bit Timer Ch.2 Interrupt Control Register  | Interrupt control                                                    |
|                          | 0x426a to 0x427f | _         | _                                             | Reserved                                                             |
| 8-bit timer              | 0x4280           | T8F_CLK1  | 8-bit Timer Ch.1 Input Clock Select Register  | Prescaler output clock selection                                     |
| (with F mode)            | 0x4282           | T8F_TR1   | 8-bit Timer Ch.1 Reload Data Register         | Reload data setting                                                  |
| Ch.1                     | 0x4284           | T8F_TC1   | 8-bit Timer Ch.1 Counter Data Register        | Counter data                                                         |
| (16-bit device)          | 0x4286           | T8F_CTL1  | 8-bit Timer Ch.1 Control Register             | Timer mode setting and timer RUN/STOP                                |
|                          | 0x4288           | T8F_INT1  | 8-bit Timer Ch.1 Interrupt Control Register   | Interrupt control                                                    |
|                          | 0x428a to 0x429f | _         |                                               | Reserved                                                             |
| Interrupt                | 0x4300 to 0x4304 | _         | L                                             | Reserved                                                             |
| controller               |                  |           | Interrupt Lovel Setup Resister 0              | P0/P1 interrupt level setting                                        |
| (16-bit device)          | 0x4306<br>0x4308 | ITC_LV0   | Interrupt Level Setup Register 0              |                                                                      |
| ,                        |                  | ITC_LV1   | Interrupt Level Setup Register 1              | SWT/CT interrupt level setting<br>T8OSC1/SVD interrupt level setting |
|                          | 0x430a           | ITC_LV2   | Interrupt Level Setup Register 2              | + · · · ·                                                            |
|                          | 0x430c           | ITC_LV3   | Interrupt Level Setup Register 3              | LCD/T16E Ch.0 interrupt level setting                                |
|                          | 0x430e           | ITC_LV4   | Interrupt Level Setup Register 4              | T8F/T16 Ch.0 interrupt level setting                                 |
|                          | 0x4310           | ITC_LV5   | Interrupt Level Setup Register 5              | T16 Ch.1/Ch.2 interrupt level setting                                |
|                          | 0x4312           | ITC_LV6   | Interrupt Level Setup Register 6              | UART Ch.0/Ch.1 interrupt level setting                               |
|                          | 0x4314           | ITC_LV7   | Interrupt Level Setup Register 7              | SPI/I <sup>2</sup> C interrupt level setting                         |
|                          | 0x4316           | ITC_LV8   | Interrupt Level Setup Register 8              | REMC/T16E Ch.1 interrupt level setting                               |
|                          | 0x4318 to 0x431f | -         | -                                             | Reserved                                                             |

Table 3.5.3.1: I/O map (internal peripheral circuit area 1)

#### **3 MEMORY MAP AND BUS CONTROL**

| Peripheral circuit | Address          |          | Register name                               | Function                                             |
|--------------------|------------------|----------|---------------------------------------------|------------------------------------------------------|
| SPI                | 0x4320           | SPI_ST   | SPI Status Register                         | Transfer and buffer status display                   |
| (16-bit device)    | 0x4322           | SPI_TXD  | SPI Transmit Data Register                  | Transmission data                                    |
|                    | 0x4324           | SPI_RXD  | SPI Receive Data Register                   | Received data                                        |
|                    | 0x4326           | SPI_CTL  |                                             | SPI mode and data transfer permission setting        |
|                    | 0x4328 to 0x433f | -        | -                                           | Reserved                                             |
| I <sup>2</sup> C   | 0x4340           | I2C_EN   | I <sup>2</sup> C Enable Register            | I <sup>2</sup> C module enable                       |
| (16-bit device)    | 0x4342           | I2C_CTL  | I <sup>2</sup> C Control Register           | I <sup>2</sup> C control and transfer status display |
|                    | 0x4344           | I2C_DAT  | I <sup>2</sup> C Data Register              | Transfer data                                        |
|                    | 0x4346           | I2C_ICTL | I <sup>2</sup> C Interrupt Control Register | I <sup>2</sup> C interrupt control                   |
|                    | 0x4348 to 0x435f | -        | -                                           | Reserved                                             |

#### Table 3.5.3.2: I/O map (internal peripheral circuit area 2)

| Peripheral circuit   | Address          |             | Register name                              | Function                                         |
|----------------------|------------------|-------------|--------------------------------------------|--------------------------------------------------|
| Clock timer          | 0x5000           | CT CTL      |                                            | Timer reset and RUN/STOP control                 |
| (8-bit device)       |                  |             | Clock Timer Control Register               |                                                  |
|                      | 0x5001           | CT_CNT      | Clock Timer Counter Register               | Counter data                                     |
|                      | 0x5002           | CT_IMSK     | Clock Timer Interrupt Mask Register        | Interrupt mask setting                           |
|                      | 0x5003           | CT_IFLG     | Clock Timer Interrupt Flag Register        | Interrupt occurrence status display/reset        |
|                      | 0x5004 to 0x501f | -           | -                                          | Reserved                                         |
| Stopwatch timer      | 0x5020           | SWT_CTL     | Stopwatch Timer Control Register           | Timer reset and RUN/STOP control                 |
| (8-bit device)       | 0x5021           | SWT_BCNT    | Stopwatch Timer BCD Counter Register       | BCD Counter data                                 |
|                      | 0x5022           | SWT_IMSK    | Stopwatch Timer Interrupt Mask Register    | Interrupt mask setting                           |
|                      | 0x5023           | SWT_IFLG    | Stopwatch Timer Interrupt Flag Register    | Interrupt occurrence status display/reset        |
|                      | 0x5024 to 0x503f | -           | -                                          | Reserved                                         |
| Watchdog timer       | 0x5040           | WDT_CTL     | Watchdog Timer Control Register            | Timer reset and RUN/STOP control                 |
| (8-bit device)       | 0x5041           | WDT_ST      | Watchdog Timer Status Register             | Timer mode setting and NMI status display        |
|                      | 0x5042 to 0x505f | -           | -                                          | Reserved                                         |
| Oscillator circuit   | 0x5060           | OSC_SRC     | Clock Source Select Register               | Clock source selection                           |
| (8-bit device)       | 0x5061           | OSC_CTL     | Oscillation Control Register               | Oscillation control                              |
|                      | 0x5062           | OSC_NFEN    | Noise Filter Enable Register               | Noise filter ON/OFF                              |
|                      | 0x5063           | OSC_LCLK    | LCD Clock Setup Register                   | LCD clock setting                                |
|                      | 0x5064           | OSC_FOUT    | FOUT Control Register                      | Clock external output control                    |
|                      | 0x5065           | OSC_T8OSC1  | T8OSC1 Clock Control Register              | 8-bit OSC1 timer clock setting                   |
|                      | 0x5066 to 0x507f | _           | _                                          | Reserved                                         |
| Clock generator      | 0x5080           | CLG PCLK    | PCLK Control Register                      | PCLK feed control                                |
| (8-bit device)       | 0x5081           | CLG_CCLK    | CCLK Control Register                      | CCLK division ratio setting                      |
|                      | 0x5082 to 0x509f | _           | _                                          | Reserved                                         |
| LCD driver           | 0x50a0           | LCD DCTL    | LCD Display Control Register               | LCD display control                              |
| (8-bit device)       | 0x50a1           | LCD_CADJ    | LCD Contrast Adjust Register               | Contrast control                                 |
|                      | 0x50a2           | LCD CCTL    | LCD Clock Control Register                 | LCD clock duty selection                         |
|                      | 0x50a3           | LCD VREG    | LCD Voltage Regulator Control Register     | LCD driver voltage regulator control             |
|                      | 0x50a4           | LCD_PWR     | LCD Power Voltage Booster Control Register | LCD power supply voltage booster circuit control |
|                      | 0x50a5           | LCD IMSK    | LCD Interrupt Mask Register                | Interrupt mask setting                           |
|                      | 0x50a6           | LCD_IFLG    | LCD Interrupt Flag Register                | Interrupt occurrence status display/reset        |
|                      | 0x50a7 to 0x50bf | _           | _                                          | Reserved                                         |
| 8-bit OSC1 timer     | 0x50c0           | T8OSC1 CTL  | 8-bit OSC1 Timer Control Register          | Timer mode setting and timer RUN/STOP            |
| (8-bit device)       | 0x50c1           | T8OSC1_CNT  | 8-bit OSC1 Timer Counter Data Register     | Counter data                                     |
| ,                    | 0x50c2           | T8OSC1_CMP  | 8-bit OSC1 Timer Compare Data Register     | Compare data setting                             |
|                      | 0x50c3           | T8OSC1_UMSK | 8-bit OSC1 Timer Interrupt Mask Register   | Interrupt mask setting                           |
|                      | 0x50c3           | T8OSC1_IMSR | 8-bit OSC1 Timer Interrupt Flag Register   | Interrupt occurrence status display/reset        |
|                      | 0x50c4           | T8OSC1_IFLG |                                            | PWM output data setting                          |
|                      |                  |             | 8-bit OSC1 Timer PWM Duty Data Register    | Reserved                                         |
|                      | 0x50c6 to 0x50df |             |                                            |                                                  |
| SVD circuit          | 0x5100           | SVD_EN      | SVD Enable Register                        | SVD operation permission/prohibition             |
| (8-bit device)       | 0x5101           | SVD_CMP     | SVD Compare Voltage Register               | Comparison voltage setting                       |
|                      | 0x5102           | SVD_RSLT    | SVD Detection Result Register              | Voltage detection results                        |
|                      | 0x5103           | SVD_IMSK    | SVD Interrupt Mask Register                | Interrupt mask setting                           |
|                      | 0x5104           | SVD_IFLG    | SVD Interrupt Flag Register                | Interrupt occurrence status display/reset        |
|                      | 0x5105 to 0x511f | -           | -                                          | Reserved                                         |
| Power supply circuit | 0x5120           | VD1_CTL     | VD1 Control Register                       | VD1 voltage and load protection control          |
| (8-bit device)       | 0x5121 to 0x513f | -           |                                            | Reserved                                         |

#### **3 MEMORY MAP AND BUS CONTROL**

| Peripheral circuit                                                     | Address                                                                                                                                                      |                                                                                                                                                                      | Register name                                                                                                                                                                                                                                                                                                                                                                         | Function                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P port & port                                                          | 0x5200                                                                                                                                                       | P0_IN                                                                                                                                                                | P0 Port Input Data Register                                                                                                                                                                                                                                                                                                                                                           | P0 port input data                                                                                                                                                                                                                                                                                                                                                                   |
| MUX<br>(8-bit device)                                                  | 0x5201                                                                                                                                                       | P0_OUT                                                                                                                                                               | P0 Port Output Data Register                                                                                                                                                                                                                                                                                                                                                          | P0 port output data                                                                                                                                                                                                                                                                                                                                                                  |
| o-bit device)                                                          | 0x5202                                                                                                                                                       | P0_OEN                                                                                                                                                               | P0 Port Output Enable Register                                                                                                                                                                                                                                                                                                                                                        | P0 port output enable                                                                                                                                                                                                                                                                                                                                                                |
|                                                                        | 0x5203                                                                                                                                                       | P0_PU                                                                                                                                                                | P0 Port Pull-up Control Register                                                                                                                                                                                                                                                                                                                                                      | P0 port pull-up control                                                                                                                                                                                                                                                                                                                                                              |
|                                                                        | 0x5204                                                                                                                                                       | P0_SM                                                                                                                                                                | P0 Port Schmitt Trigger Control Register                                                                                                                                                                                                                                                                                                                                              | P0 port Schmitt trigger control                                                                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x5205                                                                                                                                                       | P0_IMSK                                                                                                                                                              | P0 Port Interrupt Mask Register                                                                                                                                                                                                                                                                                                                                                       | P0 port interrupt mask setting                                                                                                                                                                                                                                                                                                                                                       |
|                                                                        | 0x5206<br>0x5207                                                                                                                                             | P0_EDGE<br>P0_IFLG                                                                                                                                                   | P0 Port Interrupt Edge Select Register<br>P0 Port Interrupt Flag Register                                                                                                                                                                                                                                                                                                             | P0 port interrupt edge selection<br>P0 port interrupt occurrence status displa                                                                                                                                                                                                                                                                                                       |
|                                                                        | 0x5208                                                                                                                                                       | P0_CHAT                                                                                                                                                              | P0 Port Chattering Filter Control Register                                                                                                                                                                                                                                                                                                                                            | reset<br>P0 port chattering filter control                                                                                                                                                                                                                                                                                                                                           |
|                                                                        | 0x5209                                                                                                                                                       | P0_KRST                                                                                                                                                              | P0 Port Key-Entry Reset Configuration Register                                                                                                                                                                                                                                                                                                                                        | P0 port key entry reset setting                                                                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x520a<br>0x520b to 0x520f                                                                                                                                   | P0_IEN<br>-                                                                                                                                                          | P0 Port Input Enable Register                                                                                                                                                                                                                                                                                                                                                         | P0 port input enable<br>Reserved                                                                                                                                                                                                                                                                                                                                                     |
|                                                                        | 0x5210                                                                                                                                                       | P1_IN                                                                                                                                                                | P1 Port Input Data Register                                                                                                                                                                                                                                                                                                                                                           | P1 port input data                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                        | 0x5211                                                                                                                                                       | P1_OUT                                                                                                                                                               | P1 Port Output Data Register                                                                                                                                                                                                                                                                                                                                                          | P1 port output data                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                        | 0x5212                                                                                                                                                       | P1_OEN                                                                                                                                                               | P1 Port Output Enable Register                                                                                                                                                                                                                                                                                                                                                        | P1 port output enable                                                                                                                                                                                                                                                                                                                                                                |
|                                                                        | 0x5213                                                                                                                                                       | P1_PU                                                                                                                                                                | P1 Port Pull-up Control Register                                                                                                                                                                                                                                                                                                                                                      | P1 port pull-up control                                                                                                                                                                                                                                                                                                                                                              |
|                                                                        | 0x5214                                                                                                                                                       | P1_SM                                                                                                                                                                | P1 Port Schmitt Trigger Control Register                                                                                                                                                                                                                                                                                                                                              | P1 port Schmitt trigger control                                                                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x5215                                                                                                                                                       | P1_IMSK                                                                                                                                                              | P1 Port Interrupt Mask Register                                                                                                                                                                                                                                                                                                                                                       | P1 port interrupt mask setting                                                                                                                                                                                                                                                                                                                                                       |
|                                                                        | 0x5216                                                                                                                                                       | P1_EDGE                                                                                                                                                              | P1 Port Interrupt Edge Select Register                                                                                                                                                                                                                                                                                                                                                | P1 port interrupt edge selection                                                                                                                                                                                                                                                                                                                                                     |
|                                                                        | 0x5217                                                                                                                                                       | P1_IFLG                                                                                                                                                              | P1 Port Interrupt Flag Register                                                                                                                                                                                                                                                                                                                                                       | P1 port interrupt occurrence status displa<br>reset                                                                                                                                                                                                                                                                                                                                  |
|                                                                        | 0x5218<br>0x5219                                                                                                                                             | P1_CHAT                                                                                                                                                              | P1 Port Chattering Filter Control Register                                                                                                                                                                                                                                                                                                                                            | P1 port chattering filter control<br>Reserved                                                                                                                                                                                                                                                                                                                                        |
|                                                                        | 0x5219<br>0x521a                                                                                                                                             | P1 IEN                                                                                                                                                               | P1 Port Input Enable Register                                                                                                                                                                                                                                                                                                                                                         | P1 port input enable                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                        | 0x521b to 0x521f                                                                                                                                             | _                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                        | 0x5220                                                                                                                                                       | P2_IN                                                                                                                                                                | P2 Port Input Data Register                                                                                                                                                                                                                                                                                                                                                           | P2 port input data                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                        | 0x5221                                                                                                                                                       | P2_OUT                                                                                                                                                               | P2 Port Output Data Register                                                                                                                                                                                                                                                                                                                                                          | P2 port output data                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                        | 0x5222                                                                                                                                                       | P2_0EN                                                                                                                                                               | P2 Port Output Enable Register                                                                                                                                                                                                                                                                                                                                                        | P2 port output enable                                                                                                                                                                                                                                                                                                                                                                |
|                                                                        | 0x5223                                                                                                                                                       | P2_PU                                                                                                                                                                | P2 Port Pull-up Control Register                                                                                                                                                                                                                                                                                                                                                      | P2 port pull-up control                                                                                                                                                                                                                                                                                                                                                              |
|                                                                        | 0x5224                                                                                                                                                       | P2_SM                                                                                                                                                                | P2 Port Schmitt Trigger Control Register                                                                                                                                                                                                                                                                                                                                              | P2 port Schmitt trigger control                                                                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x5225 to 0x5229                                                                                                                                             | _                                                                                                                                                                    | _                                                                                                                                                                                                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                        | 0x522a                                                                                                                                                       | P2_IEN                                                                                                                                                               | P2 Port Input Enable Register                                                                                                                                                                                                                                                                                                                                                         | P2 port input enable                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                        | 0x522b to 0x522f                                                                                                                                             | -                                                                                                                                                                    | _                                                                                                                                                                                                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                        | 0x5230                                                                                                                                                       | P3_IN                                                                                                                                                                | P3 Port Input Data Register                                                                                                                                                                                                                                                                                                                                                           | P3 port input data                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                        | 0x5231                                                                                                                                                       | P3_OUT                                                                                                                                                               | P3 Port Output Data Register                                                                                                                                                                                                                                                                                                                                                          | P3 port output data                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                        | 0x5232                                                                                                                                                       | P3_OEN                                                                                                                                                               | P3 Port Output Enable Register                                                                                                                                                                                                                                                                                                                                                        | P3 port output enable                                                                                                                                                                                                                                                                                                                                                                |
|                                                                        | 0x5233                                                                                                                                                       | P3_PU                                                                                                                                                                | P3 Port Pull-up Control Register                                                                                                                                                                                                                                                                                                                                                      | P3 port pull-up control                                                                                                                                                                                                                                                                                                                                                              |
|                                                                        | 0x5234                                                                                                                                                       | P3_SM                                                                                                                                                                | P3 Port Schmitt Trigger Control Register                                                                                                                                                                                                                                                                                                                                              | P3 port Schmitt trigger control                                                                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x5235 to 0x5239                                                                                                                                             | -                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                        | 0x523a                                                                                                                                                       | P3_IEN                                                                                                                                                               | P3 Port Input Enable Register                                                                                                                                                                                                                                                                                                                                                         | P3 port input enable                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                        | 0x523b to 0x527f                                                                                                                                             | -                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                        | 0x52a0                                                                                                                                                       | P0_PMUX                                                                                                                                                              | P0 Port Function Select Register                                                                                                                                                                                                                                                                                                                                                      | P0 port function selection                                                                                                                                                                                                                                                                                                                                                           |
|                                                                        | 0x52a1                                                                                                                                                       | P1_PMUX                                                                                                                                                              | P1 Port Function Select Register                                                                                                                                                                                                                                                                                                                                                      | P1 port function selection                                                                                                                                                                                                                                                                                                                                                           |
|                                                                        | 0x52a2                                                                                                                                                       | P2_PMUX                                                                                                                                                              | P2 Port Function Select Register                                                                                                                                                                                                                                                                                                                                                      | P2 port function selection                                                                                                                                                                                                                                                                                                                                                           |
|                                                                        | 0x52a3                                                                                                                                                       | P3_PMUX                                                                                                                                                              | P3 Port Function Select Register                                                                                                                                                                                                                                                                                                                                                      | P3 port function selection                                                                                                                                                                                                                                                                                                                                                           |
|                                                                        | 0x52a4 to 0x52bf                                                                                                                                             | -                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                             |
| PWM & capture                                                          | 0x5300                                                                                                                                                       | T16E_CA0                                                                                                                                                             | PWM Timer Ch.0 Compare Data A Register                                                                                                                                                                                                                                                                                                                                                | Compare data A setting                                                                                                                                                                                                                                                                                                                                                               |
| imer                                                                   | 0x5302                                                                                                                                                       | T16E_CB0                                                                                                                                                             | PWM Timer Ch.0 Compare Data B Register                                                                                                                                                                                                                                                                                                                                                | Compare data B setting                                                                                                                                                                                                                                                                                                                                                               |
| Ch.O                                                                   | 0x5304                                                                                                                                                       | T16E_TC0                                                                                                                                                             | PWM Timer Ch.0 Counter Data Register                                                                                                                                                                                                                                                                                                                                                  | Counter data                                                                                                                                                                                                                                                                                                                                                                         |
| 16-bit device)                                                         | 0x5306                                                                                                                                                       | T16E_CTL0                                                                                                                                                            | PWM Timer Ch.0 Control Register                                                                                                                                                                                                                                                                                                                                                       | Timer mode setting and timer RUN/STOP                                                                                                                                                                                                                                                                                                                                                |
|                                                                        |                                                                                                                                                              |                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x5308                                                                                                                                                       | T16E_CLK0                                                                                                                                                            | PWM Timer Ch.0 Input Clock Select Register                                                                                                                                                                                                                                                                                                                                            | Prescaler output clock selection                                                                                                                                                                                                                                                                                                                                                     |
|                                                                        | 0x5308<br>0x530a                                                                                                                                             |                                                                                                                                                                      | PWM Timer Ch.0 Input Clock Select Register<br>PWM Timer Ch.0 Interrupt Mask Register                                                                                                                                                                                                                                                                                                  | Prescaler output clock selection<br>Interrupt mask setting                                                                                                                                                                                                                                                                                                                           |
|                                                                        | 0x530a<br>0x530c                                                                                                                                             |                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                       | Interrupt mask setting<br>Interrupt occurrence status display/reset                                                                                                                                                                                                                                                                                                                  |
| MISC register                                                          | 0x530a<br>0x530c<br>0x530e to 0x531f                                                                                                                         | T16E_IMSK0<br>T16E_IFLG0<br>-                                                                                                                                        | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-                                                                                                                                                                                                                                                                                                 | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved                                                                                                                                                                                                                                                                                                      |
|                                                                        | 0x530a<br>0x530c                                                                                                                                             | T16E_IMSK0                                                                                                                                                           | PWM Timer Ch.0 Interrupt Mask Register                                                                                                                                                                                                                                                                                                                                                | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir                                                                                                                                                                                                                 |
|                                                                        | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322                                                                                                     | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1                                                                                                                | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register                                                                                                                                                                                                                            | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging                                                                                                                                                                                                |
|                                                                        | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324                                                                                           | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT                                                                                                   | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register                                                                                                                                                                                                   | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection                                                                                                                                                              |
|                                                                        | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326                                                                                 | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ                                                                                    | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register                                                                                                                                                                      | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection<br>IRAM size selection                                                                                                                                       |
|                                                                        | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328                                                                       | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL                                                                      | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register<br>Vector Table Address Low Register                                                                                                                                 | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection                                                                                                                                                              |
|                                                                        | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328<br>0x532a                                                             | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL<br>MISC_TTBRH                                                        | PWM Timer Ch.0 Interrupt Mask Register         PWM Timer Ch.0 Interrupt Flag Register         -         FLASHC/SRAMC Control Register         OSC1 Peripheral Control Register         MISC Protect Register         IRAM Size Select Register         Vector Table Address Low Register         Vector Table Address High Register                                                   | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settir<br>OSC1 operation peripheral function settin<br>for debugging<br>MISC register write protection<br>IRAM size selection<br>Vector table address setting                                                                                                       |
| •                                                                      | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328<br>0x532a<br>0x532a                                                   | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL                                                                      | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register<br>Vector Table Address Low Register                                                                                                                                 | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection<br>IRAM size selection<br>Vector table address setting<br>S1C17 core PSR readout                                                                             |
| 16-bit device)                                                         | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328<br>0x532a<br>0x532a<br>0x532c<br>0x532e to 0x533f                     | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL<br>MISC_TTBRL<br>MISC_TTBRH<br>MISC_PSR<br>-                         | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register<br>Vector Table Address Low Register<br>Vector Table Address High Register<br>PSR Register<br>-                                                                      | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection<br>IRAM size selection<br>Vector table address setting<br>S1C17 core PSR readout<br>Reserved                                                                 |
| 16-bit device)                                                         | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328<br>0x532a<br>0x532a<br>0x532c<br>0x532e to 0x533f<br>0x5340           | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL<br>MISC_TTBRL<br>MISC_TTBRH<br>MISC_PSR<br>-<br>REMC_CFG             | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register<br>Vector Table Address Low Register<br>Vector Table Address High Register<br>PSR Register<br>-<br>REMC Configuration Register                                       | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection<br>IRAM size selection<br>Vector table address setting<br>S1C17 core PSR readout<br>Reserved<br>Clock transfer control                                       |
| 16-bit device)                                                         | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328<br>0x5328<br>0x532a<br>0x532c<br>0x532e to 0x533f<br>0x5340<br>0x5342 | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL<br>MISC_TTBRL<br>MISC_TTBRH<br>MISC_PSR<br>-<br>REMC_CFG<br>REMC_CAR | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register<br>Vector Table Address Low Register<br>Vector Table Address High Register<br>PSR Register<br>-<br>REMC Configuration Register<br>REMC Carrier Length Setup Register | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection<br>IRAM size selection<br>Vector table address setting<br>S1C17 core PSR readout<br>Reserved<br>Clock transfer control<br>Carrier H/L section length setting |
| MISC register<br>16-bit device)<br>Remote controller<br>16-bit device) | 0x530a<br>0x530c<br>0x530e to 0x531f<br>0x5320<br>0x5322<br>0x5324<br>0x5326<br>0x5328<br>0x532a<br>0x532a<br>0x532c<br>0x532e to 0x533f<br>0x5340           | T16E_IMSK0<br>T16E_IFLG0<br>-<br>MISC_FL<br>MISC_OSC1<br>MISC_PROT<br>MISC_IRAMSZ<br>MISC_TTBRL<br>MISC_TTBRL<br>MISC_TTBRH<br>MISC_PSR<br>-<br>REMC_CFG<br>REMC_CAR | PWM Timer Ch.0 Interrupt Mask Register<br>PWM Timer Ch.0 Interrupt Flag Register<br>-<br>FLASHC/SRAMC Control Register<br>OSC1 Peripheral Control Register<br>MISC Protect Register<br>IRAM Size Select Register<br>Vector Table Address Low Register<br>Vector Table Address High Register<br>PSR Register<br>-<br>REMC Configuration Register                                       | Interrupt mask setting<br>Interrupt occurrence status display/reset<br>Reserved<br>FLASHC/SRAMC access condition settin<br>OSC1 operation peripheral function settir<br>for debugging<br>MISC register write protection<br>IRAM size selection<br>Vector table address setting<br>S1C17 core PSR readout<br>Reserved<br>Clock transfer control                                       |

| Peripheral circuit | Address          |            | Register name                              | Function                                  |
|--------------------|------------------|------------|--------------------------------------------|-------------------------------------------|
| PWM & capture      | 0x5360           | T16E_CA1   | PWM Timer Ch.1 Compare Data A Register     | Compare data A setting                    |
| timer              | 0x5362           | T16E_CB1   | PWM Timer Ch.1 Compare Data B Register     | Compare data B setting                    |
| Ch.1               | 0x5364           | T16E_TC1   | PWM Timer Ch.1 Counter Data Register       | Counter data                              |
| (16-bit device)    | 0x5366           | T16E_CTL1  | PWM Timer Ch.1 Control Register            | Timer mode setting and timer RUN/STOP     |
|                    | 0x5368           | T16E_CLK1  | PWM Timer Ch.1 Input Clock Select Register | Prescaler output clock selection          |
|                    | 0x536a           | T16E_IMSK1 | PWM Timer Ch.1 Interrupt Mask Register     | Interrupt mask setting                    |
|                    | 0x536c           | T16E_IFLG1 | PWM Timer Ch.1 Interrupt Flag Register     | Interrupt occurrence status display/reset |
|                    | 0x536e to 0x537f | -          | _                                          | Reserved                                  |

Note: Addresses indicated as "Reserved" or blank unused peripheral circuit areas should not be accessed by application programs.

## 3.6 Core I/O Reserved Area

The 1K-byte area from 0xfffc00 to 0xffffff is used as the CPU core I/O area, and the following I/O registers are assigned.

| Peripheral circuit | Address  |       | Register name                        | Function                             |
|--------------------|----------|-------|--------------------------------------|--------------------------------------|
| S1C17 core I/O     | 0xffff84 | IDIR  | Processor ID Register                | Processor ID display                 |
|                    | 0xffff90 | DBRAM | Debug RAM Base Register              | Debugging RAM base address display   |
|                    | 0xffffa0 | DCR   | Debug Control Register               | Debug control                        |
|                    | 0xffffb8 | IBAR2 | Instruction Break Address Register 2 | Instruction break address #2 setting |
|                    | 0xfffbc  | IBAR3 | Instruction Break Address Register 3 | Instruction break address #3 setting |
|                    | 0xffffd0 | IBAR4 | Instruction Break Address Register 4 | Instruction break address #4 setting |

#### Table 3.6.1: I/O map (Core I/O reserved area)

See "2.5 Processor Information" for more information on IDIR and "24. On-chip Debugger (DBG)" for more information on other registers.

This area incorporates S1C17 core registers, in addition to those described above. For more information on these registers, refer to the *S1C17 Core Manual*.

# **4** Power Supply

## 4.1 Power Supply Voltage

The S1C17702 operation power supply voltages are given below.

| Normal operation:         | 1.8 V to 3.6 V    |
|---------------------------|-------------------|
| Flash memory programming: | 2.7 V to 3.6 V $$ |

Supply voltages within the range to VDD pin with the Vss pin as GND.

The S1C17702 QFP21-176 pin package has three VDD pins and three Vss pins. The VFBGA8H-181 package has three VDD pins and 19 Vss pins. The VFBGA10H-180 package has three VDD pins and 18 Vss pins. In either case, all must be connected to the + power supply and GND rather than left open.

# 4.2 Internal Power Supply Circuit

The S1C17702 includes a power supply circuit, as shown in Figure 4.2.1, which generates all the voltages required for internal circuits within the IC. Broadly speaking, the power supply circuit is divided into three sections.

| Circuit                              | Power supply circuit                 | Output voltage |  |  |  |
|--------------------------------------|--------------------------------------|----------------|--|--|--|
| Oscillator circuit, internal circuit | Internal voltage regulator           | VD1            |  |  |  |
| LCD voltage regulator                | Power supply voltage booster circuit | Vdd or Vd2     |  |  |  |
| LCD driver                           | LCD voltage regulator                | Vc1 to Vc5     |  |  |  |

Table 4.2.1: Dower supply circuit



Figure 4.2.1: Power supply circuit configuration

## Note: Never use the output from pins VD1, VD2, or VC1 to VC5 to drive external circuits.

## Internal voltage regulator

The internal voltage regulator generates voltage VDI to operate internal logic and oscillator circuits. The voltage of VDI can be switched via the program and is set to 1.8 V for normal operations and 2.5 V for flash memory programming.

## Power supply voltage booster circuit

The power supply voltage booster circuit generates voltage VD2 for operating LCD voltage regulators. The LCD voltage regulator power supply can be selected to be VDD or VD2 to suit the power supply voltage VDD.

| Power supply voltage VDD | LCD voltage regulator power supply |
|--------------------------|------------------------------------|
| 1.8 to 2.5V              | VD2 (≈ VDD × 2)                    |
| 2.5 to 3.6V              | Vdd                                |

Table 4.2.1: LCD voltage regulator power supply

## LCD voltage regulator

The LCD voltage regulator generates 1/5 bias voltages Vc1, Vc2, Vc3, Vc4, and Vc5 for driving LCDs. In the S1C17702, these LCD drive voltages are fed to the internal LCD driver to drive the LCD panels connected to the common/segment pins.

# Note: Voltages Vc1 to Vc5 cannot be obtained correctly if VDD is used as the power supply for LCD voltage regulators when 2.5 V or less.

Seiko Epson Corporation

## 4.3 Power Supply Circuit Control

The various power supply circuits can be controlled via software to ensure that correct operating voltages within the chip are generated to suit the power supply voltage and operating mode and to minimize consumption current.

## **Operating mode switching**

The S1C17702 features two operating modes:

1. Normal operating mode

Normal operating mode for running application programs.  $V_{DD} = 1.8 \text{ V}$  to 3.6 V, internal operating voltage  $V_{D1} = 1.8 \text{ V}$ 

2. Flash erase/programming mode

Operating mode for deleting and writing program/data to flash memory.

VDD = 2.7 V to 3.6 V, internal operating voltage VD1 = 2.5 V

The voltage V<sub>D1</sub> must be switched as described to suit the operating mode above. This is done using VD1MD (D0/VD1\_CTL register). VD1MD is normally used with the default setting 0 (V<sub>D1</sub> = 1.8 V). VD1MD is set to 1 for flash memory erase/programming.

\* VD1MD: Flash Erase/Program Mode Bit in the VD1 Control (VD1\_CTL) Register (D0/0x5120)

Note: An interval of 5 ms (max) is required for the internal operating voltage to stabilize after switching the operating mode. Start flash memory programming only after this stabilization time has elapsed.

#### LCD power supply control

The LCD voltage regulators must be operated at a voltage of at least 2.5 V to ensure that the correct LCD drive voltages VC1 to VC5 are generated. When the 1.8 V to 2.5 V power supply (VDD) is used, VDD is approximately doubled by the power supply voltage booster circuit, and the output voltage VD2 is used to drive the LCD voltage regulator. In this case, set PBON (D0/LCD\_PWR register) to 1 and turn on the power supply voltage booster circuit. To drive the LCD voltage regulator using VD2 generated, set VDSEL (D1/LCD\_PWR register) to 1. PBON must be set to 1 before switching to the VD2 voltage.

- \* **PBON:** Power Voltage Booster Control Bit in the LCD Power Voltage Booster Control (LCD\_PWR) Register (D0/0x50a4)
- \* VDSEL: Regulator Power Source Select Bit in the LCD Power Voltage Booster Control (LCD\_PWR) Register (D1/0x50a4)

VDD is used to drive the LCD voltage regulator when using a power supply (VDD) of 2.5 V or more. The power supply voltage booster circuit is switched off to minimize current consumption. In this case, PBON and VDSEL should both be left at the default value of 0.

Note: An interval of approximately 1 ms is required for the output voltage V<sub>D2</sub> to stabilize after you turn on the power supply voltage booster circuit. Do not switch the LCD voltage regulator power supply to V<sub>D2</sub> until this time has elapsed.

LCD drive voltages Vc1 to Vc5 are fed to the LCD driver if DSPC[1:0] (D[1:0]/LCD\_DCTL register) is set to a value other than 0x0 (display off).

\* DSPC[1:0]: LCD Display Control Bits in the LCD Display Control (LCD\_DCTL) Register (D[1:0]/0x50a0)

If the internal LCD driver is not used, turn off the power supply voltage booster circuit and LCD voltage regulator to minimize current consumption. PBON, VDSEL, and DSPC[1:0] should all be 0 (default).

## Power supply control bit settings list

Table 4.3.1 lists the power supply control bit settings for different conditions.

|                  | Condition    |            |       | Cont             | rol bit |            |  |  |
|------------------|--------------|------------|-------|------------------|---------|------------|--|--|
| Operating mode   | Vdd          | LCD driver | VD1MD | PBON             | VDSEL   | DSPC[1:0]  |  |  |
| Normal operation | 1.8 to 2.5 V | Used       | 0     | 1                | 1       | Other than |  |  |
|                  |              |            |       |                  |         | 0x0        |  |  |
|                  | 2.5 to 3.6 V | Used       | 0     | 0                | 0       | Other than |  |  |
|                  |              |            |       |                  |         | 0x0        |  |  |
|                  | 1.8 to 3.6 V | Not used   | 0     | 0                | 0       | 0x0        |  |  |
| Flash erase/     | 1.8 to 2.7 V | -          |       | (Not to be used) |         |            |  |  |
| programming      | 2.7 to 3.6 V | Used       | 1     | 0                | 0       | Other than |  |  |
|                  |              |            |       |                  |         | 0x0        |  |  |
|                  | 2.7 to 3.6 V | Not used   | 1     | 0                | 0       | 0x0        |  |  |

For specific information on DSPC[1:0] settings, refer to "0x50a0: LCD Display Control Register (LCD\_DCTL)" in section 22.8.

# 4.4 Heavy Load Protection Function

The internal constant-voltage and LCD voltage regulators include heavy load protection functions that can be set via software to ensure stable operations and LCD display, even when the power supply voltage fluctuates due to external loads.

The internal voltage regulator is switched to heavy load protection mode by writing 1 to HVLD (D5/VD1\_CTL register), stabilizing VD1 output.

\* HVLD: VD1 Heavy Load Protection Mode Bit in the VD1 Control (VD1\_CTL) Register (D5/0x5120)

VD1 may become unstable in the operations shown below and in other conditions. If the IC operations are unstable due to these conditions during evaluation, set the internal logic voltage regulator to heavy load protection mode before starting the operations.

- When driving a diode or buzzer in which a large current flows using a port output (Maintain the regulator in heavy load protection mode while the port is driving the load.)
- When switching the system clock from the high-speed clock to the low-speed clock and vice versa (Set the regulator in heavy load protection mode immediately before switching the clock and maintain it for several 10  $\mu$ s after the switching has completed.)
- When placing/releasing the system into/from HALT/SLEEP mode at frequent intervals (Maintain the regulator in heavy load protection mode while the processing is being repeated.)

# Note: Always cancel heavy load protection mode after the processing that causes unstable operations has finished. When executing an unstable processing repeatedly, the program must maintain heavy load protection mode while it repeating the processing.

The LCD voltage regulator is switched to heavy load protection mode by writing 1 to LHVLD (D4/LCD\_VREG register), stabilizing the Vc1 to Vc5 output. Make this setting if you observe brightness fluctuations on the LCD display.

\* LHVLD: LCD Heavy Load Protection Mode Bit in the LCD Voltage Regulator Control (LCD\_VREG) Register (D4/0x50a3)

## Note: Current consumption will be higher in heavy load protection mode than normal operations. Avoid setting heavy load protection via software unless necessary.

# 4.5 Control Register Details

| Address |                                                    | Register | Function                                         |  |  |  |  |  |  |
|---------|----------------------------------------------------|----------|--------------------------------------------------|--|--|--|--|--|--|
| 0x5120  | VD1_CTL VD1 Control Register                       |          | VD1 voltage and heavy load protection control    |  |  |  |  |  |  |
| 0x50a3  | LCD_VREG LCD Voltage Regulator Control Register    |          | LCD driver voltage regulator control             |  |  |  |  |  |  |
| 0x50a4  | LCD_PWR LCD Power Voltage Booster Control Register |          | LCD power supply voltage booster circuit control |  |  |  |  |  |  |

#### Table 4.5.1: Power supply control register list

The individual power supply control registers are described below. These are all 8-bit registers.

Note: When writing data to registers, always program 0 to those bits indicated as "Reserved." Avoid writing 1.

## 0x5120: VD1 Control Register (VD1\_CTL)

|               | <br>••••• |      |          | - |
|---------------|-----------|------|----------|---|
| Desister name | D:4       | Nama | Eunation |   |

| Register name | Address  | Bit  | Name  | Function                       | Setting |            | Init. | R/W          | Remarks            |     |                    |
|---------------|----------|------|-------|--------------------------------|---------|------------|-------|--------------|--------------------|-----|--------------------|
| VD1 Control   | 0x5120   | D7–6 | -     | reserved                       | Γ       | -          | -     |              | -                  | -   | 0 when being read. |
| Register      | (8 bits) | D5   | HVLD  | VD1 heavy load protection mode | 1       | On         | 0     | Off          | 0                  | R/W |                    |
| (VD1_CTL)     |          | D4–1 | -     | reserved                       | -       |            | -     | -            | 0 when being read. |     |                    |
|               |          | D0   | VD1MD | Flash erase/program mode       | 1       | Flash (2.5 | 0     | Norm.(1.8 V) | 0                  | R/W |                    |
|               |          |      |       |                                |         | V)         |       |              |                    |     |                    |

#### D[7:6] Reserved

#### D5 HVLD: VD1 Heavy Load Protection Mode Bit

Sets the internal voltage regulator to heavy load protection mode.

1 (R/W): Heavy load protection on

0 (R/W): Heavy load protection off (default)

The internal voltage regulator is switched to heavy load protection mode by writing 1 to HVLD, stabilizing the VDI output.

VD1 may become unstable in the operations shown below and in other conditions. If the IC operations are unstable due to these conditions during evaluation, set the internal logic voltage regulator to heavy load protection mode before starting the operations.

- When driving a diode or buzzer in which a large current flows using a port output (Maintain the regulator in heavy load protection mode while the port is driving the load.)
- When switching the system clock from the high-speed clock to the low-speed clock and vice versa (Set the regulator in heavy load protection mode immediately before switching the clock and maintain it for several 10 µs after the switching has completed.)
- When placing/releasing the system into/from HALT/SLEEP mode at frequent intervals (Maintain the regulator in heavy load protection mode while the processing is being repeated.)
- Note: Always cancel heavy load protection mode after the processing that causes unstable operations has finished. When executing an unstable processing repeatedly, the program must maintain heavy load protection mode while it repeating the processing.
  - Since it increases current consumption, avoid setting heavy load protection mode unless necessary.

#### D[4:1] Reserved

## D0 VD1MD: Flash Erase/Program Mode Bit

Selects the internal operating voltage VD1 value (operating mode).

1 (R/W):  $V_{D1} = 2.5 V$ , Flash erase/programming mode

0 (R/W):  $V_{D1} = 1.8$  V, Normal operating mode (default)

VD1MD is normally used with the default setting of 0 ( $V_{D1} = 1.8 V$ ). Set VD1MD to 1 for flash memory erase and programming.

Note: An interval of 5 ms (max) is required for the internal operating voltage to stabilize after switching the operating mode. Start flash memory programming after this stabilization time has elapsed.

## 0x50a3: LCD Voltage Regulator Control Register (LCD\_VREG)

| Register name    | Address  | Bit  | Name  | Function                       | Setting    |   | R/W | Remarks            |
|------------------|----------|------|-------|--------------------------------|------------|---|-----|--------------------|
| LCD Voltage      | 0x50a3   | D7–5 | -     | reserved                       | -          | - | -   | 0 when being read. |
| Regulator        | (8 bits) | D4   | LHVLD | LCD heavy load protection mode | 1 On 0 Off | 0 | R/W |                    |
| Control Register |          | D3–0 | -     | reserved                       | -          | - | -   | 0 when being read. |
| (LCD_VREG)       |          |      |       |                                |            |   |     |                    |

## D[7:5] Reserved

## D4 LHVLD: LCD Heavy Load Protection Mode Bit

Sets the LCD voltage regulator to heavy load protection mode.

1 (R/W): Heavy load protection on

0 (R/W): Heavy load protection off (default)

The LCD voltage regulator is switched to heavy load protection mode by writing 1 to LHVLD, stabilizing the VC1 to VC5 output. Make this setting if you observe brightness fluctuations on the LCD display.

Since it increases current consumption, avoid setting heavy load protection mode unless necessary.

## D[3:0] Reserved

## 0x50a4: LCD Power Voltage Booster Control Register (LCD\_PWR)

|                  |          |      |       |                               |         | -   |           |     |                    |     |  |
|------------------|----------|------|-------|-------------------------------|---------|-----|-----------|-----|--------------------|-----|--|
| Register name    | Address  | Bit  | Name  | Function                      | Setting |     | Init. R/W |     | Remarks            |     |  |
| LCD Power        | 0x50a4   | D7–2 | -     | reserved                      | -       |     | -         | -   | 0 when being read. |     |  |
| Voltage Booster  | (8 bits) |      |       |                               |         |     |           |     | -                  |     |  |
| Control Register |          | D1   | VDSEL | Regulator power source select | 1       | VD2 | 0         | Vdd | 0                  | R/W |  |
| (LCD_PWR)        |          | D0   | PBON  | Power voltage booster control | 1       | On  | 0         | Off | 0                  | R/W |  |

#### D[7:2] Reserved

### D1 VDSEL: Regulator Power Source Select Bit

Selects the LCD voltage regulator power supply voltage. 1 (R/W): VD2

0 (R/W): VDD (default)

When using the 1.8 V to 2.5 V power supply (VDD), program 1 to VDSEL to drive the LCD voltage regulator using VD2 generated by the power supply voltage booster circuit. 1 must be written to PBON (D0) before switching on the power supply voltage booster circuit.

When using a power supply (VDD) of 2.5 V or more, set VDSEL to 0 to drive the LCD voltage regulator using VDD. The power supply voltage booster circuit is switched off in this case to minimize current consumption.

## D0 PBON: Power Voltage Booster Control Bit

Controls the power supply voltage booster circuit. 1 (R/W): On 0 (R/W): Off (default)

When the 1.8 V to 2.5 V power supply (VDD) is used, program 1 to PBON to turn on the power supply voltage booster circuit. The power supply voltage booster circuit doubles VDD to generate VD2 to drive the LCD voltage regulator. VDSEL (D1) must also be set to 1 to drive the LCD voltage regulator using VD2. When using a power supply (VDD) of 2.5 V or more, there is no need to generate VD2. The power supply voltage booster circuit should be switched off to minimize current consumption.

Note: An interval of approximately 1 ms is required for the output voltage V<sub>D2</sub> to stabilize after you turn on the power supply voltage booster circuit. Do not switch the LCD voltage regulator power supply to V<sub>D2</sub> until this time has elapsed.

# 4.6 Precautions

- Never use the output from pins VD1, VD2, and VC1 to VC5 to drive external circuits.
- The correct Vc1 to Vc5 voltages will not be obtained if you use VDD as the power supply for LCD voltage regulators when 2.5 V or less.
- An interval of 5 ms (max.) is required for the internal operating voltage to stabilize after switching the operating mode to Flash erase/programming mode. Start flash memory programming after this stabilization time has elapsed.
- An interval of approximately 1 ms is required for the output voltage VD2 to stabilize after you turn on the power supply voltage booster circuit. Do not switch the LCD voltage regulator power supply to VD2 until this time has elapsed.
- Always cancel heavy load protection mode after the processing that causes unstable operations has finished. When executing an unstable processing repeatedly, the program must maintain heavy load protection mode while it repeating the processing.
- Current consumption will be higher in heavy load protection mode than for normal operation. Avoid setting heavy load protection mode via software unless necessary.

# **5** Initial Reset

# 5.1 Initial Reset Factors

Shown below are the three different initial reset factors for initializing S1C17702 internal circuits.

- (1) External initial reset via #RESET pin
- (2) External initial reset via P0 port (pins P00 to P03) key entry (set by software)
- (3) Internal initial reset via watchdog timer (set by software)

Figure 5.1.1 illustrates the initial reset circuit configuration.



Figure 5.1.1: Initial reset circuit configuration

The CPU and peripheral circuits are initialized by initial reset factors. The CPU begins reset processing once the factors are cleared.

This causes the reset vector to be read from the start of the vector table, and the program (initialization routine) starting at that address to be executed.

## 5.1.1 #RESET pin

Initial resetting is possible by inputting external Low level to the #RESET pin.

To initialize the S1C17702 reliably, the #RESET pin must be maintained at Low level for at least the specified duration after the power supply voltage rises. (Refer to "26.6 AC Characteristics.")

Initial resetting is cleared if the #RESET input changes from Low to High, and the CPU begins reset interrupt processing.

The #RESET pin incorporates a pull-up resistance.

## 5.1.2 P0 Port Key-Entry Reset

Initial resetting is possible by inputting external Low level simultaneously to the ports (P00 to P03) selected by software. The ports can be selected by P0KRST[1:0] (D[1:0]/P0\_KRST register).

\* POKRST[1:0]: P0 Port Key-Entry Reset Configuration Bits in the P0 Port Key-Entry Reset Configuration (P0\_KRST) Register (D[1:0]/0x5209)

|             | , . ,              |
|-------------|--------------------|
| P0KRST[1:0] | Port used          |
| 0x3         | P00, P01, P02, P03 |
| 0x2         | P00, P01, P02      |
| 0x1         | P00, P01           |
| 0x0         | Not used           |

| Table 5.1.2.1: P0 port key-entr | y reset settings |
|---------------------------------|------------------|
|---------------------------------|------------------|

For example, initial reset is applied when input to the four ports P00 to P03 is Low level simultaneously if P0KRST[1:0] is set to 0x3.

- Note: Make sure the specified ports are not simultaneously switched to Low during normal operations when using the P0 port key-entry reset function.
  - The P0 port key-entry reset function is enabled by software and cannot be used to perform a reset at power-on.
  - The P0 port key-entry reset function cannot be used in SLEEP state.

## 5.1.3 Reset by Watchdog Timer

The S1C17702 incorporates a watchdog timer to detect runaway CPU. If the watchdog timer is not reset by software every 4 seconds (with this failure indicating a runaway CPU), the timer overflows, generating an NMI or reset. A reset is generated by writing "1" to WDTMD (D1/WDT\_ST register). (NMI is generated if WDTMD is 0.)

\*WDTMD: NMI/Reset Mode Select Bit in the Watchdog Timer Status (WDT\_ST) Register (D1/0x5041)

For detailed information on the watchdog timer, refer to "17 Watchdog Timer (WDT)."

- Note: When using the reset function with the watchdog timer, to prevent accidental resetting, take care to program so that the watchdog timer is reset every four seconds.
  - The watchdog timer reset function is enabled by software and cannot be used to perform a reset at power-on.

# 5.2 Initial Reset Sequence

CPU startup waits for the oscillation stabilization standby time (64/fiosc seconds\*) to expire after resetting is cleared via the #RESET pin at power-on. Figure 5.2.1 illustrates the sequence of operations after clearing the initial reset. The CPU starts up in sync with the IOSC (internal CR oscillator circuit) clock after the reset is cleared.

\*fiosc: IOSC clock frequency

Note: The oscillation stabilization standby time does not include the oscillation start time. The time may be longer than that shown between power-on or SLEEP cancellation and instruction execution.



Figure 5.2.1: Sequence of operations after initial reset cancellation

# 5.3 Initial Settings at Initial Resetting

The CPU internal register is initialized by initial resetting, as shown below.

R0 to R7: 0x0PSR:0x0 (interrupt level = 0, interrupt prohibited)SP:0x0PC:Reset vector at start of vector table is loaded by reset processing.

The internal RAM and display memory should be initialized via software, since they are not initialized by initial resetting.

The internal peripheral circuits are initialized in accordance with their particular specifications. They should be reset via software, if necessary. For detailed information on initial values after initial resetting, refer to the I/O register list in the Appendix or the respective peripheral circuit descriptions.

# **6** Interrupt Controller

# 6.1 ITC Configuration

The S1C17702 features the following 18 different types of interrupts:

- 1. P00 to P07 input interrupt (8 types)
- 2. P10 to P17 input interrupt (8 types)
- 3. Stopwatch timer interrupt (3 types)
- 4. Clock timer interrupt (4 types)
- 5. 8-bit OSC1 timer interrupt (1 type)
- 6. SVD interrupt (1 type)
- 7. LCD interrupt (1 type)
- 8. PWM & capture timer Ch.0 interrupt (2 types)
- 9. PWM & capture timer Ch.1 interrupt (2 types)
- 10. 8-bit timer Ch.0 & Ch.1 interrupt (2 types)
- 11. 16-bit timer Ch.0 interrupt (1 type)
- 12. 16-bit timer Ch.1 interrupt (1 type)
- 13. 16-bit timer Ch.2 interrupt (1 type)
- 14. UART Ch.0 interrupt (3 types)
- 15. UART Ch.1 interrupt (3 types)
- 16. Remote controller interrupt (3 types)
- 17. SPI interrupt (2 types)
- 18. I2C interrupt (2 types)

The ITC enables the interrupt level (priority) for determining the processing sequence when multiple interrupts occur simultaneously to be set for each interrupt type separately.

Each interrupt type includes the number of interrupt factor indicated in parentheses above. Settings to permit or prohibit interrupt for different causes are set by the respective peripheral module registers.

For specific information on interrupt factor and their control, refer to the peripheral module explanations. Figure 6.1.1 illustrates the interrupt system configuration

Figure 6.1.1 illustrates the interrupt system configuration.



Figure 6.1.1: Interrupt system

# 6.2 Vector Table

The vector table contains the vectors (handler routine start addresses) for interrupt handler routines. When an interrupt occurs, the S1C17 core reads the vector corresponding to the interrupt and executes that handler routine. The base (top) address for the vector table can be set using the MISC\_TTBRL and MISC\_TTBRH registers (0x5328 and 0x532a) (See "2.4 Vector Table"). "TTBR" in Table 6.2.1 indicates the values set for these registers. The MISC\_TTBRL and MISC\_TTBRH registers are set to the 0x8000 address after initial resetting. Table 6.2.1 shows the S1C17702 vector table.

| Vector No./ Soft-<br>ware interrupt No. | Vector address | Hardware interrupt name             | Hardware interrupt factor                                                                                                    | Priorit |  |
|-----------------------------------------|----------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------|--|
| 0 (0x00)                                | TTBR + 0x00    | Reset                               | <ul> <li>Low input to #RESET pin</li> <li>Watchdog timer overflow *2</li> </ul>                                              | 1       |  |
| 1 (0x01)                                | TTBR + 0x04    | Irregular address interrupt         | Memory access instruction                                                                                                    | 2       |  |
| -                                       | (0xfffc00)     | Debug interrupt                     | brk instruction etc.                                                                                                         | 3       |  |
| 2 (0x02)                                | TTBR + 0x08    | NMI                                 | Watchdog timer overflow *2                                                                                                   | 4       |  |
| 3 (0x03)                                | TTBR + 0x0c    | reserved                            | _                                                                                                                            | -       |  |
| 4 (0x04)                                | TTBR + 0x10    | P0 port interrupt                   | P00 to P07 port input                                                                                                        | High    |  |
| 5 (0x05)                                | TTBR + 0x14    | P1 port interrupt                   | P10 to P17 port input                                                                                                        | ↑       |  |
| 6 (0x06)                                | TTBR + 0x18    | Stopwatch timer interrupt           | <ul> <li>Timer 100 Hz signal</li> <li>Timer 10 Hz signal</li> <li>Timer 1 Hz signal</li> </ul>                               |         |  |
| 7 (0x07) TTBR + 0x1c                    |                | Clock timer interrupt               | <ul> <li>Timer 32 Hz signal</li> <li>Timer 8 Hz signal</li> <li>Timer 2 Hz signal</li> <li>Timer 1 Hz signal</li> </ul>      |         |  |
| 8 (0x08)                                | TTBR + 0x20    |                                     |                                                                                                                              |         |  |
| 9 (0x09)                                | TTBR + 0x24    | SVD interrupt                       | Power supply voltage drop detection                                                                                          |         |  |
| 10 (0x0a)                               | TTBR + 0x28    | LCD interrupt                       | Frame signal                                                                                                                 |         |  |
| 11 (0x0b)                               | TTBR + 0x2c    | PWM & capture timer Ch. 0 interrupt | <ul><li>Compare A</li><li>Compare B</li></ul>                                                                                |         |  |
| 12 (0x0c)                               | TTBR + 0x30    | 8-bit timer Ch.0 & Ch.1 interrupt   | <ul><li>Ch.0 underflow</li><li>Ch.1 underflow</li></ul>                                                                      |         |  |
| 13 (0x0d)                               | TTBR + 0x34    | 16-bit timer Ch.0 interrupt         | Timer underflow                                                                                                              |         |  |
| 14 (0x0e)                               | TTBR + 0x38    | 16-bit timer Ch.1 interrupt         | Timer underflow                                                                                                              |         |  |
| 15 (0x0f)                               | TTBR + 0x3c    | 16-bit timer Ch.2 interrupt         | Timer underflow                                                                                                              |         |  |
| 16 (0x10)                               | TTBR + 0x40    | UART Ch.0 interrupt                 | <ul> <li>Transmit buffer empty</li> <li>Receive buffer full</li> <li>Receive error</li> </ul>                                |         |  |
| 17 (0x11)                               | TTBR + 0x44    | UART Ch.1 interrupt                 | Transmit buffer empty     Receive buffer full     Receive error                                                              |         |  |
| 18 (0x12)                               | TTBR + 0x48    | SPI interrupt                       | <ul><li>Transmit buffer empty</li><li>Receive buffer full</li></ul>                                                          |         |  |
| 19 (0x13)                               | TTBR + 0x4c    | I <sup>2</sup> C interrupt          | <ul><li>Transmit buffer empty</li><li>Receive buffer full</li></ul>                                                          |         |  |
| 20 (0x14)                               | TTBR + 0x50    | Remote controller interrupt         | <ul> <li>Data length counter underflow</li> <li>Input rising edge detection</li> <li>Input falling edge detection</li> </ul> |         |  |
| 21 (0x15)                               | TTBR + 0x54    | PWM & capture timer Ch. 1 interrupt | Compare A     Compare B                                                                                                      |         |  |
| 22 (0x16)                               | TTBR + 0x58    | reserved                            | -                                                                                                                            | Ţ       |  |
| 31 (0x1f)                               | TTBR + 0x7c    | reserved                            | · _                                                                                                                          | Low     |  |

|  | Table | 6.2.1: | Vector | table |
|--|-------|--------|--------|-------|
|--|-------|--------|--------|-------|

\*1: When same interrupt level is set

\*2: Watchdog timer interrupt selects reset or NMI using software.

Vector numbers 4 to 21 are assigned maskable interrupts supported by the S1C17702.

# 6.3 Maskable Interrupt Control

## 6.3.1 Peripheral Module Interrupt Control Bit

The peripheral module causing the interrupt includes interrupt enable bits and interrupt flags for each interrupt cause. Setting the interrupt enable bit to 1 (interrupt permitted) sets the interrupt flag to 1, depending on the cause of the interrupt. The flag state is sent to the ITC as an interrupt request signal, generating an interrupt request to the S1C17 core. The corresponding interrupt enable bits should be set to 0 for those causes for which interrupts are not desired. In this case, the interrupt flag will not be set to 1, even if the interrupt cause occurs, and the interrupt request signal will not be activated to the ITC.

Interrupt flags set to 1 must be reset within the interrupt handler routine after the interrupt has occurred. The ITC will generate the same interrupt again once the interrupt handler routine has been ended by the reti instruction with the interrupt flag still set to 1, since it detects interrupt requests using the signal level.

For specific information on interrupt factor, interrupt flags, and interrupt enable bits, refer to the individual peripheral module descriptions.

## 6.3.2 ITC Interrupt Request Processing

On receiving an interrupt signal from a peripheral module, the ITC sends interrupt request, interrupt level, and vector number signals to the S1C17 core.

Vector numbers are determined by the ITC internal hardware for each interrupt cause, as shown in Table 6.2.1.

The interrupt level is a value used by the S1C17 core to compare with the IL bit (PSR). This interrupt level is used in the S1C17 core to prohibit subsequently occurring interrupts with the same or lower level. (See section 6.3.3.) The default ITC settings are level 0 for all maskable interrupts. Interrupt requests are not accepted by the S1C17

core if the level is 0.

The ITC includes control bits for selecting the interrupt level, and these can be set to between 0 (low) and 7 (high) interrupt levels for each interrupt type.

| Table 6.3.2.1: Interrupt level setting bits |                                       |                  |  |  |  |  |  |  |
|---------------------------------------------|---------------------------------------|------------------|--|--|--|--|--|--|
| Hardware interrupt                          | Interrupt level setting bit           | Register address |  |  |  |  |  |  |
| P0 port interrupt                           | ILV0[2:0] (D[2:0]/ITC_LV0 register)   | 0x4306           |  |  |  |  |  |  |
| P1 port interrupt                           | ILV1[2:0] (D[10:8]/ITC_LV0 register)  | 0x4306           |  |  |  |  |  |  |
| Stopwatch timer interrupt                   | ILV2[2:0] (D[2:0]/ITC_LV1 register)   | 0x4308           |  |  |  |  |  |  |
| Clock timer interrupt                       | ILV3[2:0] (D[10:8]/ITC_LV1 register)  | 0x4308           |  |  |  |  |  |  |
| 8-bit OSC1 timer interrupt                  | ILV4[2:0] (D[2:0]/ITC_LV2 register)   | 0x430a           |  |  |  |  |  |  |
| SVD interrupt                               | ILV5[2:0] (D[10:8]/ITC_LV2 register)  | 0x430a           |  |  |  |  |  |  |
| LCD interrupt                               | ILV6[2:0] (D[2:0]/ITC_LV3 register)   | 0x430c           |  |  |  |  |  |  |
| PWM & capture timer Ch.0 interrupt          | ILV7[2:0] (D[10:8]/ITC_LV3 register)  | 0x430c           |  |  |  |  |  |  |
| 8-bit timer Ch.0 & Ch.1 interrupt           | ILV8[2:0] (D[2:0]/ITC_LV4 register)   | 0x430e           |  |  |  |  |  |  |
| 16-bit timer Ch.0 interrupt                 | ILV9[2:0] (D[10:8]/ITC_LV4 register)  | 0x430e           |  |  |  |  |  |  |
| 16-bit timer Ch.1 interrupt                 | ILV10[2:0] (D[2:0]/ITC_LV5 register)  | 0x4310           |  |  |  |  |  |  |
| 16-bit timer Ch.2 interrupt                 | ILV11[2:0] (D[10:8]/ITC_LV5 register) | 0x4310           |  |  |  |  |  |  |
| UART Ch.0 interrupt                         | ILV12[2:0] (D[2:0]/ITC_LV6 register)  | 0x4312           |  |  |  |  |  |  |
| UART Ch.0 interrupt                         | ILV13[2:0] (D[10:8]/ITC_LV6 register) | 0x4312           |  |  |  |  |  |  |
| SPI interrupt                               | ILV14[2:0] (D[2:0]/ITC_LV7 register)  | 0x4314           |  |  |  |  |  |  |
| I <sup>2</sup> C interrupt                  | ILV15[2:0] (D[10:8]/ITC_LV7 register) | 0x4314           |  |  |  |  |  |  |
| Remote controller interrupt                 | ILV16[2:0] (D[2:0]/ITC_LV8 register)  | 0x4316           |  |  |  |  |  |  |
| PWM & capture timer Ch.1 interrupt          | ILV17[2:0] (D[10:8]/ITC_LV8 register) | 0x4316           |  |  |  |  |  |  |

#### **6 INTERRUPT CONTROLLER**

If interrupt requests are input to the ITC simultaneously from multiple peripheral modules, the ITC outputs the interrupt request with the highest priority to the S1C17 core in accordance with the following conditions.

- 1. Interrupts with the highest interrupt level take precedence.
- 2. If multiple interrupt requests are input with the same interrupt level, the interrupt with the lowest vector number takes precedence.

The other interrupts occurring at the same time are held until all have been accepted by the S1C17 core, in descending order of priority.

If an interrupt cause with higher priority occurs while the ITC is outputting an interrupt request signal to the S1C17 core (before being accepted by the S1C17 core), the ITC alters the vector number and interrupt level signal to the setting information on the more recent interrupt. The previously occurring interrupt is held.

No interrupt is generated if the interrupt flag is reset via software within the peripheral module outputting an interrupt request held.

## 6.3.3 S1C17 Core Interrupt Processing

Maskable interrupts for the S1C17 core occur when all of the following conditions are met:

- Interrupts are permitted by the interrupt control bit inside the peripheral module.
- The PSR (S1C17 core internal processor status register) IE (interrupt enable) bit has been set to 1.
- The interrupt factor has a higher interrupt level set than that set for the PSR IL (interrupt level).
- No other interrupt factors having higher precedence (e.g., NMI) are present.

If an interrupt cause permitted inside the peripheral module occurs, the corresponding interrupt flag is set to 1, and this state is maintained until it is reset by the program. This means the interrupt cause is not cleared even if the conditions listed above are not met when the interrupt cause occurs. An interrupt occurs if the above conditions are met.

If multiple maskable interrupt factor arise simultaneously, the interrupt cause with the highest interrupt level and lowest vector number becomes the subject of the interrupt request to the S1C17 core. Interrupts with lower levels are held until the above conditions are subsequently met.

The S1C17 core samples interrupt requests for each cycle. On accepting an interrupt request, the S1C17 core switches to interrupt processing when execution of the current instruction is complete.

Interrupt processing involves the following steps:

- (1) The PSR and current program counter (PC) value is moved to the stack.
- (2) The PSR IE bit is reset to 0 (preventing subsequent maskable interrupts).
- (3) The PSR IL is set to the received interrupt level. (The NMI does not affect interrupt levels.)
- (4) The vector for the interrupt factor occurring is loaded to the PC to execute the interrupt handler routine.

When an interrupt is received, (2) prevents subsequent maskable interrupts. Setting the IE bit to 1 within the interrupt handler routine allows handling of multiple interrupts. In this case, IL is changed by (3), and only interrupts with higher levels than those already being processed will be accepted.

Ending interrupt handler routines using a reti instruction returns the PSR to the state before the interrupt. The program resumes processing following the instruction being executed at the time the interrupt occurred via the next branch.

# 6.4 NMI

The S1C17702 can generate NMIs (non-maskable interrupts) using the watchdog timer. The vector number for NMIs is 2, and the vector address is set in the vector table initial address + 8 bytes. These interrupts take precedence over other interrupt factors and are accepted unconditionally by the S1C17 core.

For detailed information on generating NMIs, refer to "17 Watchdog Timer (WDT)."

# 6.5 Software Interrupts

Interrupts can be generated via software with S1C17 core int *imm5* or intl *imm5* and *imm3* instructions. The vector table vector number (0 to 31) is specified by the operand immediate *imm5*. With the intl instruction, *imm3* can be used to specify an interrupt level (0 to 7) for the PSR IL fields.

Details of the processor interrupt processing are the same as for when an interrupt generated by hardware occurs.

# 6.6 HALT and SLEEP Mode Cancellation

HALT and SLEEP modes are cleared by the following signals, which start the CPU.

- Interrupt request for CPU from ITC
- NMI from watchdog timer
- Debug interrupt
- Reset
- Note: If the CPU is able to receive interrupts when the HALT or SLEEP modes have been cleared by an interrupt request for the CPU from the ITC, processing branches to an interrupt handler routine immediately after cancellation. In all other cases, commands are executed following the halt and slp commands.
  - HALT or SLEEP mode clearing due to interrupt requests cannot be masked (prohibited) using ITC interrupt level settings.

For more information, refer to "C.1 Clock Control Power Saving" in Appendix C.

# 6.7 Control Register Details

#### Table 6.7.1: ITC registers

| Address |         | Register name                    | Function                                         |
|---------|---------|----------------------------------|--------------------------------------------------|
| 0x4306  | ITC_LV0 | Interrupt Level Setup Register 0 | P0 and P1 interrupt level setting                |
| 0x4308  | ITC_LV1 | Interrupt Level Setup Register 1 | SWT and CT interrupt level setting               |
| 0x430a  | ITC_LV2 | Interrupt Level Setup Register 2 | T8OSC1 and SVD interrupt level setting           |
| 0x430c  | ITC_LV3 | Interrupt Level Setup Register 3 | LCD and T16E Ch.0 interrupt level setting        |
| 0x430e  | ITC_LV4 | Interrupt Level Setup Register 4 | T8F and T16 Ch.0 interrupt level setting         |
| 0x4310  | ITC_LV5 | Interrupt Level Setup Register 5 | T16 Ch.1 and Ch.2 interrupt level setting        |
| 0x4312  | ITC_LV6 | Interrupt Level Setup Register 6 | UART Ch.0 and Ch.1 interrupt level setting       |
| 0x4314  | ITC_LV7 | Interrupt Level Setup Register 7 | SPI and I <sup>2</sup> C interrupt level setting |
| 0x4316  | ITC_LV8 | Interrupt Level Setup Register 8 | REMC and T16E Ch.1 interrupt level setting       |

The ITC registers are described in detail below. These are 16-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

## 0x4306: Interrupt Level Setup Register 0 (ITC\_LV0)

| Register name    | Address   | Bit    | Name      | Function           | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|-----------|--------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4306    | D15-11 | -         | reserved           | -       | -     | -   | 0 when being read. |
| Setup Register 0 | (16 bits) | D10-8  | ILV1[2:0] | P1 interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV0)        |           | D7–3   | -         | reserved           | -       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV0[2:0] | P0 interrupt level | 0 to 7  | 0x0   | R/W |                    |

#### D[15:11] Reserved

#### D[10:8] ILV1[2:0]: P1 Port Interrupt Level Bits

Set the P1 port interrupt level (0 to 7). (Default: 0)

The S1C17 core does not accept interrupts with levels set lower than the PSR IL value.

The ITC uses the interrupt level when multiple interrupt factors occur simultaneously.

If multiple interrupts occur at the same time permitted by the interrupt enable bit, the ITC sends the interrupt request with the highest level set by the ITC\_LVx registers (0x4306 to 0x4316) to the S1C17 core.

If multiple interrupt factors with the same interrupt level occur simultaneously, the interrupt with the lowest vector number is processed first.

The other interrupts are held until all have been accepted by the S1C17 core in descending order of priority.

If an interrupt factor of higher priority occurs while the ITC outputs an interrupt request signal to the S1C17 core (before acceptance by the S1C17 core), the ITC alters the vector number and interrupt level signal to the setting details of the most recent interrupt. The immediately preceding interrupt is held.

### D[7:3] Reserved

### D[2:0] ILV0[2:0]: P0 Port Interrupt Level Bits

Set the P0 port interrupt level (0 to 7). (Default: 0) Refer to the ILV1[2:0] (D[10:8]) description.

| 0x4308: Interrupt Le | evel Setup Register | 1 (ITC_LV1) |
|----------------------|---------------------|-------------|
|----------------------|---------------------|-------------|

| Register name    | Address   | Bit    | Name      | Function            | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|-----------|---------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4308    | D15-11 | -         | reserved            | -       | -     | -   | 0 when being read. |
| Setup Register 1 | (16 bits) | D10-8  | ILV3[2:0] | CT interrupt level  | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV1)        |           | D7–3   | -         | reserved            | -       | -     | -   | 0 when being read. |
|                  |           | D2-0   | ILV2[2:0] | SWT interrupt level | 0 to 7  | 0x0   | R/W |                    |

## D[15:11] Reserved

## D[10:8] ILV3[2:0]: Clock Timer Interrupt Level Bits Set the clock timer interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

## D[7:3] Reserved

D[2:0] ILV2[2:0]: Stopwatch Timer Interrupt Level Bits Set the stopwatch timer interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

## 0x430a: Interrupt Level Setup Register 2 (ITC\_LV2)

| Register name    | Address   | Bit    | Name      | Function               | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|-----------|------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x430a    | D15-11 | -         | reserved               | -       | -     | -   | 0 when being read. |
| Setup Register 2 | (16 bits) | D10-8  | ILV5[2:0] | SVD interrupt level    | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV2)        |           | D7–3   | -         | reserved               | -       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV4[2:0] | T8OSC1 interrupt level | 0 to 7  | 0x0   | R/W |                    |

### D[15:11] Reserved

## D[10:8] ILV5[2:0]: SVD Interrupt Level Bits

Set the SVD interrupt level (0 to 7). (Default: 0) Refer to the discussion of ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]).

## D[7:3] Reserved

## D[2:0] ILV4[2:0]: 8-bit OSC1 Timer Interrupt Level Bits Set the 8-bit OSC1 timer interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

## 0x430c: Interrupt Level Setup Register 3 (ITC\_LV3)

| Register name    | Address   | Bit    | Name      | Function                  | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|-----------|---------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x430c    | D15-11 | -         | reserved                  | -       | -     | -   | 0 when being read. |
| Setup Register 3 | (16 bits) | D10-8  | ILV7[2:0] | T16E Ch.0 interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV3)        |           | D7–3   | -         | reserved                  | -       | -     | -   | 0 when being read. |
|                  |           | D2-0   | ILV6[2:0] | LCD interrupt level       | 0 to 7  | 0x0   | R/W |                    |

## D[15:11] Reserved

## D[10:8] ILV7[2:0]: PWM & Capture Timer Interrupt Level Bits Set the PWM & capture timer interrupt level (0 to 7). (Default: 0)

Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

## D[7:3] Reserved

## D[2:0] ILV6[2:0]: LCD Interrupt Level Bits

Set the LCD interrupt level (0 to 7). (Default: 0) Refer to the discussion of ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]).

## 0x430e: Interrupt Level Setup Register 4 (ITC\_LV4)

| Register name    | Address   | Bit    | Name      | Function                 | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|-----------|--------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x430e    | D15-11 | -         | reserved                 | -       | -     | -   | 0 when being read. |
| Setup Register 4 | (16 bits) | D10-8  | ILV9[2:0] | T16 Ch.0 interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV4)        |           | D7–3   | -         | reserved                 | -       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV8[2:0] | T8F interrupt level      | 0 to 7  | 0x0   | R/W |                    |

### D[15:11] Reserved

## D[10:8] ILV9[2:0]: 16-bit Timer Ch.0 Interrupt Level Bits

Set the 16-bit timer Ch.0 interrupt level (0 to 7). (Default: 0) Refer to the discussion of ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]).

## D[7:3] Reserved

D[2:0] ILV8[2:0]: 8-bit Timer Interrupt Level Bits Set the 8-bit timer Ch.0 & Ch.1 interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

## 0x4310: Interrupt Level Setup Register 5 (ITC\_LV5)

| Register name    | Address   | Bit    | Name       | Function                 | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|------------|--------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4310    | D15-11 | -          | reserved                 | _       | -     | -   | 0 when being read. |
| Setup Register 5 | (16 bits) | D10-8  | ILV11[2:0] | T16 Ch.2 interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV5)        |           | D7–3   | -          | reserved                 | -       | -     | -   | 0 when being read. |
|                  |           | D2-0   | ILV10[2:0] | T16 Ch.1 interrupt level | 0 to 7  | 0x0   | R/W |                    |

### D[15:11] Reserved

## D[10:8] ILV11[2:0]: 16-bit Timer Ch.2 Interrupt Level Bits Set the 16-bit timer Ch.2 interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

## D[7:3] Reserved

D[2:0] ILV10[2:0]: 16-bit Timer Ch.1 Interrupt Level Bits Set the 16-bit timer Ch.1 interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

#### 0x4312: Interrupt Level Setup Register 6 (ITC\_LV6)

| Register name    | Address   | Bit    | Name       | Function             | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|------------|----------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4312    | D15-11 | -          | reserved             | -       | -     | -   | 0 when being read. |
| Setup Register 6 | (16 bits) | D10-8  | ILV13[2:0] | REMC interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV6)        |           | D7–3   | -          | reserved             | -       | -     | -   | 0 when being read. |
|                  |           | D2-0   | ILV12[2:0] | UART interrupt level | 0 to 7  | 0x0   | R/W |                    |

#### D[15:11] Reserved

#### D[10:8] ILV13[2:0]: UART Ch.1 Interrupt Level Bits

Set the UART Ch.1 interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

#### D[7:3] Reserved

#### D[2:0] ILV12[2:0]: UART Ch.0 Interrupt Level Bits Set the UART Ch.0 interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

#### 0x4314: Interrupt Level Setup Register 7 (ITC\_LV7)

| Register name    | Address   | Bit    | Name       | Function                         | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|------------|----------------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4314    | D15-11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 7 | (16 bits) | D10-8  | ILV15[2:0] | I <sup>2</sup> C interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV7)        |           | D7–3   | -          | reserved                         | -       | -     | -   | 0 when being read. |
|                  |           | D2-0   | ILV14[2:0] | SPI interrupt level              | 0 to 7  | 0x0   | R/W |                    |

#### D[15:11] Reserved

#### D[10:8] ILV15[2:0]: I<sup>2</sup>C Interrupt Level Bits

Set the I<sup>2</sup>C interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

#### D[7:3] Reserved

#### D[2:0] ILV14[2:0]: SPI Interrupt Level Bits Set the SPI interrupt level (0 to 7). (Default: 0) Refer to the ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]) description.

#### 0x4316: Interrupt Level Setup Register 8 (ITC\_LV8)

| Register name    | Address   | Bit    | Name       | Function                  | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|------------|---------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4316    | D15-11 | -          | reserved                  | -       | -     | -   | 0 when being read. |
| Setup Register 8 | (16 bits) | D10-8  | ILV17[2:0] | T16E Ch.1 interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV8)        |           | D7–3   | -          | reserved                  | -       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV16[2:0] | REMC interrupt level      | 0 to 7  | 0x0   | R/W |                    |

#### D[15:11] Reserved

#### D[10:8] ILV17[2:0]: PWM & Capture Timer Ch.1 Interrupt Level Bits

Set the PWM & capture timer Ch.1 interrupt level (0 to 7). (Default: 0) Refer to the discussion of ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]).

#### D[7:3] Reserved

#### D[2:0] ILV16[2:0]: REMC Interrupt Level Bits

Set the remote controller interrupt level (0 to 7). (Default: 0) Refer to the discussion of ITC\_LV0 register (0x4306) ILV1[2:0] (D[10:8]).

## 6.8 Precautions

To prevent the recurrence of interrupts due to the same interrupt factor, always reset the interrupt flag before permitting interrupts, resetting PSR, or executing the reti instruction.

# 7 Oscillator Circuit (OSC)

## 7.1 OSC Module Configuration

The S1C17702 contains three internal oscillator circuits (IOSC, OSC3, and OSC1). The IOSC and OSC3 oscillator circuits generate the main clock for high-speed operation of the S1C17 core and peripheral circuits. The OSC1 oscillator circuit generates a sub-clock for timer and low-power operations.

The IOSC clock is selected as the system clock after initial resetting.

Oscillator circuit on/off switching and system clock selection (between IOSC/OSC3 and OSC1) is controlled by software. External clock output is also possible.



Figure 7.1.1 illustrates the clock system and OSC module configuration.

Figure 7.1.1: OSC module configuration

To reduce power consumption, control the clock in conjunction with processing and use standby mode. For more information on reducing power consumption, refer to "Appendix C: Power Saving."

## 7.2 IOSC Oscillator Circuit

The IOSC oscillator circuit initiates high-speed oscillation without external components. It initiates oscillation when power is turned on. The S1C17 core and peripheral circuits operate with this oscillator clock after an initial reset.

#### **IOSC** oscillation on/off

The IOSC oscillator circuit stops oscillating if IOSCEN (D2/OSC\_CTL register) is set to 0 and begins oscillating if set to 1. The IOSC oscillator circuit also stops oscillating in SLEEP mode.

\* IOSCEN: IOSC Enable Bit in the Oscillation Control (OSC\_CTL) Register (D2/0x5061)

Following initial resetting, IOSCEN is set to 1 to turn the IOSC oscillator circuit on. Since the IOSC clock is used as the system clock, the S1C17 core begins operating using the IOSC clock.

The S1C17702 also contains an OSC3 oscillator circuit for high-speed clock generation. Selection of IOSC or OSC3 as the high-speed clock can occur after startup. For specific information on selecting the clock, refer to "7.5.1 High-speed Clock (HSCLK) Selection."

#### Stabilization wait time when IOSC oscillation begins

When using the IOSC clock, the IOSC oscillator circuit incorporates an oscillation stabilization wait timer to prevent malfunctions due to unstable clock operations when IOSC oscillation begins—e.g., when waking from SLEEP, or when the IOSC oscillator circuit is turned on via software. The IOSC clock is not fed to the system until the time set for this timer has elapsed.

Use IOSCWT[1:0] (D[7:6]/OSC\_CTL register) to select one of four oscillation stabilization wait times.

\* IOSCWT[1:0]: IOSC Wait Cycle Select Bits in the Oscillation Control (OSC\_CTL) Register (D[7:6]/0x5061)

| abic 7.2.1. 1000 03cilla | the rizer war time setting          |  |  |  |  |  |  |  |  |  |
|--------------------------|-------------------------------------|--|--|--|--|--|--|--|--|--|
| IOSCWT[1:0]              | Oscillation stabilization wait time |  |  |  |  |  |  |  |  |  |
| 0x3                      | 8 cycles                            |  |  |  |  |  |  |  |  |  |
| 0x2                      | 16 cycles                           |  |  |  |  |  |  |  |  |  |
| 0x1                      | 32 cycles                           |  |  |  |  |  |  |  |  |  |
| 0x0                      | 64 cycles                           |  |  |  |  |  |  |  |  |  |
|                          |                                     |  |  |  |  |  |  |  |  |  |

Table 7.2.1: IOSC oscillation stabilization wait time settings

(Default: 0x0)

This is set to 64 cycles (IOSC clock) after an initial reset. This means the CPU begins operating following the reset only after the duration indicated below (at a maximum) has elapsed.

CPU operation start time on initial reset  $\leq$  IOSC oscillation start time (max.) + IOSC oscillation stabilization wait time (64 cycles)

When the system clock is switched to IOSC on waking from SLEEP or immediately after turning on the IOSC oscillator circuit, the IOSC clock is fed to the system only after the duration indicated below (at a maximum) has elapsed. If the power supply voltage VDD has stabilized sufficiently, IOSCWT[1:0] can be set to 0x3 to reduce the oscillation stabilization wait time.

IOSC clock system feed wait time  $\leq$  IOSC oscillation start time (max.) + IOSC oscillation stabilization wait time

## 7.3 OSC3 Oscillator Circuit

The OSC3 oscillator circuit is a high-precision, high-speed oscillator circuit that uses either a crystal or ceramic oscillator. It can be switched for use with the IOSC oscillator circuit.

Figure 7.3.1 illustrates the OSC3 oscillator circuit configuration.



Figure 7.3.1: OSC3 oscillator circuit

A crystal oscillator (X'tal3) or ceramic oscillator (Ceramic) and feedback resistor (Rf) should be connected between the OSC3 and OSC4 pins. Additionally, two capacitors (CG3 and CD3) should be connected between the OSC3/ OSC4 pins and Vss.

#### OSC3 oscillation on/off

The OSC3 oscillator circuit stops oscillating if OSC3EN (D0/OSC\_CTL register) is set to 0 and starts oscillating if set to 1. The OSC3 oscillator circuit also stops oscillating in SLEEP mode.

\* OSC3EN: OSC3 Enable Bit in the Oscillation Control (OSC\_CTL) Register (D0/0x5061)

After an initial resetting, OSC3EN is set to 0 and the OSC3 oscillator circuit is halted. The IOSC clock is used as the default high-speed clock. To use the OSC3 clock, the clock must also be switched, in addition to the on/ off controls described above. For specific information on switching, see "7.5 System Clock Switching."

#### Stabilization wait time at start of OSC3 oscillation

When using the OSC3 clock, the OSC3 oscillator circuit incorporates an oscillation stabilization wait timer to prevent malfunctions due to unstable clock operations at the start of OSC3 oscillation-e.g., when waking from SLEEP, or when the OSC3 oscillator circuit is switched on via software. The OSC3 clock is not fed to the system until the time set for this timer has elapsed.

Use OSC3WT[1:0] (D[5:4]/OSC\_CTL register) to select one of four oscillation stabilization wait times.

\* OSC3WT[1:0]: OSC3 Wait Cycle Select Bits in the Oscillation Control (OSC\_CTL) Register (D[5:4]/0x5061)

| OSC3WT[1:0] | Oscillation stabilization wait time |
|-------------|-------------------------------------|
| 0x3         | 128 cycles                          |
| 0x2         | 256 cycles                          |
| 0x1         | 512 cycles                          |
| 0x0         | 1,024 cycles                        |

Table 7.3.1: OSC3 oscillation stabilization wait time settings

(Default: 0x0)

This is set to 1,024 cycles (OSC3 clock) after initial resetting.

Note: Oscillation stability will vary, depending on the oscillator and other external components. Carefully consider the OSC3 oscillation stabilization wait time before reducing the time. When the system clock is switched to OSC3 immediately after the OSC3 oscillator circuit is switched on, the OSC3 clock is fed to the system only after the duration indicated below (at a maximum) has elapsed.

OSC3 clock system feed wait time < OSC3 oscillation start time (max.) + OSC3 oscillation stabilization wait time

#### OSC3 external clock input

An external clock can be input to the OSC3 pin. When disabling the external clock supply, make sure the clock signal level is a Vss level (do not stop while the clock signal is in a VDD period). For more information on the input clock waveform, see "27 Electrical Characteristics."

## 7.4 OSC1 Oscillator Circuit

The OSC1 oscillator circuit is a high-precision, low-speed oscillator circuit that uses a 32.768 kHz crystal oscillator. The OSC1 clock is generally used as the timer operation clock (for the clock timer, stopwatch timer, watchdog timer, and 8-bit OSC1 timer). It reduces power consumption and can be used as the system clock instead of the IOSC or OSC3 clock when no high-speed processing is required.

Figure 7.4.1 illustrates the OSC1 oscillator circuit configuration.



A crystal oscillator (X'tal1) (typ. 32.768 kHz) should be connected between the OSC1 and OSC2 pins. Additionally, trimmer capacitor CG1 (0 to 25 pF) should be connected between the OSC1 pin and Vss.

#### OSC1 oscillation on/off

The OSC1 oscillator circuit stops oscillating if OSC1EN (D1/OSC\_CTL register) is set to 0 and starts oscillating if set to 1. The OSC1 oscillator circuit also stops oscillating in SLEEP mode.

\* OSC1EN: OSC1 Enable Bit in the Oscillation Control (OSC\_CTL) Register (D1/0x5061)

Following initial resetting, OSC1EN is set to 0, and the OSC1 oscillator circuit is halted.

#### Stabilization wait time at start of OSC1 oscillation

The OSC1 oscillator circuit incorporates an oscillation stabilization wait timer (256 cycles) to prevent malfunctions caused by unstable clock operations at the start of OSC1 oscillation—for example, on initial power-up, on waking from SLEEP, or when the OSC1 oscillator circuit is turned on via software. When the system clock is switched to OSC1 immediately after the OSC1 oscillator circuit is turned on, the OSC1 clock is fed to the system only after the duration indicated below (at a maximum) has elapsed.

OSC1 clock system feed wait time  $\leq$  OSC1 oscillation start time (max.) + OSC1 oscillation stabilization wait time (256 cycles)

## 7.5 System Clock Switching

The S1C17702 system clock selector consists of high-speed clock (HSCLK) selection and OSC1 or HSCLK selection, as shown in Figure 7.5.1.



Figure 7.5.1: System clock selector

### 7.5.1 High-speed Clock (HSCLK) Selection

The S1C17702 incorporates IOSC and OSC3 oscillator circuits to generate the high-speed clock (HSCLK). The IOSC oscillator circuit is turned on following an initial reset, and the S1C17702 begins operating with the IOSC clock selected as HSCLK.

To select OSC3 as HSCLK, turn on the OSC3 oscillator circuit (see section 7.3) and write 1 to HSCLKSEL (D1/ OSC\_SRC register). To select IOSC as HSCLK, turn on the IOSC oscillator circuit (see section 7.2) and write 0 to HSCLKSEL.

\* HSCLKSEL: High-speed Clock Select Bit in the Clock Source Select (OSC\_SRC) Register (D1/0x5060)

Note: Both the IOSC and OSC3 oscillator circuits must be turned on when selecting HSCLK. Otherwise, the system will fail to switch to HSCLK even when HSCLKSEL is written to, and the HSCLKSEL value will remain unchanged. When selecting HSCLK, make sure PCKEN[1:0] (D[1:0]/CLG\_PCLK register) is set to 0x3 (on) before writing to HSCLKSEL.

\* PCKEN[1:0]: PCLK Enable Bits in the PCLK Control (CLG\_PCLK) Register (D[1:0]/0x5080)

### 7.5.2 System Clock (OSC1 or HSCLK) Selection

The S1C17702 incorporates an OSC1 oscillator circuit to generate the low-speed clock. Either OSC1 or HSCLK can be selected as the system clock. Operations begin with HSCLK selected after an initial reset.

To select OSC1 as the system clock, turn on the OSC1 oscillator circuit (see section 7.4) and write 1 to CLKSRC (D0/ OSC\_SRC register). To select HSCLK as the system clock, write 0 to CLKSRC with HSCLK running.

When switch the system clock between the HSCLK and OSC1 clocks, it takes switching time from one cycle of HSCLK (min.) to one cycle of OSC1 (max.).

\* CLKSRC: System Clock Source Select Bit in the Clock Source Select (OSC\_SRC) Register (D0/0x5060)

Oscillator circuits other than those selected as the system clock can be shut down to reduce consumption current, provided they are not used as operating clocks for peripheral circuits.

Note: • Both OSC1 and HSCLK must be operating when the system clock is selected (OSC1 or HSCLK). Otherwise, the system will not switch system clocks, even when CLKSRC is written to, and the CLKSRC value will remain unchanged.

Table 7.5.2.1 shows the combinations of clock operating states and register settings enabling system clock (OSC1 or HSCLK) selection.

| IOSC | OSC3 | OSC1 | HSCLKSEL | System clock      |  |  |  |  |  |  |  |
|------|------|------|----------|-------------------|--|--|--|--|--|--|--|
| On   | On   | On   | *        | IOSC/OSC3 or OSC1 |  |  |  |  |  |  |  |
| On   | Off  | On 0 |          | IOSC or OSC1      |  |  |  |  |  |  |  |
| Off  | On   | On   | 1        | OSC3 or OSC1      |  |  |  |  |  |  |  |

Table 7.5.2.1: System clock (OSC1/HSCLK) switching conditions

- The oscillator circuit selected as the system clock cannot be turned off.
- Continuous write/read access to CLKSRC is prohibited. At least one command unrelated to CLKSRC access must be inserted between the write and read commands.

## 7.6 LCD Clock Control

The OSC module incorporates an LCD clock generator for generating the LCD driver operating clock (LCLK). For specific information on the LCD driver, see "22. LCD Driver LCD."



#### **Clock source selection**

Use LCKSRC (D1/OSC\_LCLK register) to select whether OSC1 or HSCLK is used to generate the LCD clock. OSC1 is selected when LCKSRC is 1 (default), while HSCLK is selected when set to 0.

\* LCKSRC: LCD Clock Source Select Bit in the LCD Clock Setup (OSC\_LCLK) Register (D1/0x5063)

#### **Clock division ratio selection**

OSC1 clock

No division ratio needs to be selected if OSC1 has been selected for the clock source. The OSC1 clock (Typ 32.768 kHz) is sent to the LCD driver unchanged.

#### HSCLK clock

If HSCLK has been selected for the clock source, use LCKDV[2:0] (D[4:2]/OSC\_LCLK register) to select the division ratio.

\* LCKDV[2:0]: LCD Clock Division Ratio Select Bits in the LCD Clock Setup (OSC\_LCLK) Register (D[4:2]/0x5063)

| LCKDV[2:0] | Division ratio |
|------------|----------------|
| 0x7 to 0x5 | Reserved       |
| 0x4        | HSCLK-1/512    |
| 0x3        | HSCLK-1/256    |
| 0x2        | HSCLK-1/128    |
| 0x1        | HSCLK-1/64     |
| 0x0        | HSCLK-1/32     |

#### Table 7.6.1: LCD clock division ratio selection

(Default: 0x0)

#### Clock feed control

Clock feed to the LCD driver is controlled using LCKEN (D0/OSC\_LCLK register).

The LCKEN default setting is 0, which stops the clock feed. Setting LCKEN to 1 sends the clock generated as above to the LCD driver.

\* LCKEN: LCD Clock Enable Bit in the LCD Clock Setup (OSC\_LCLK) Register (D0/0x5063)

Note: Be sure to wait at least one LCLK clock cycle before setting LCKEN to 0 to stop the LCLK clock feed immediately after setting DSPC[1:0] (D[1:0]/LCD\_DCTL register) to 0x0 (display off). When resuming display with no wait time inserted after the LCLK feed is disabled, wait at least one LCLK clock cycle until DSPC[1:0] is set to a value other than 0x0 after LCKEN is set to 1 to resume clock feed.

\* DSPC[1:0]: LCD Display Control Bits in the LCD Display Control (LCD\_DCTL) Register (D[1:0]/0x50a0)

## 7.7 8-bit OSC1 Timer Clock Control

The OSC module consists of a division circuit for generating the 8-bit OSC1 timer operation clock and a device for controlling the feed. The 8-bit OSC1 timer is a programmable timer that operates only using the OSC1 division clock. For detailed information, refer to "14 8-bit OSC1 Timer (T8OSC1)."



#### Clock division ratio selection

Select the OSC1 clock division ratio using T8O1CK[2:0] (D[3:1]/OSC T8OSC1 register).

\* T8O1CK[2:0]: T8OSC1 Clock Division Ratio Select Bits in the T8OSC1 Clock Control (OSC T8OSC1) Register (D[3:1]/0x5065)

| clock division ratio selection |  |  |  |
|--------------------------------|--|--|--|
| Division ratio                 |  |  |  |
| Reserved                       |  |  |  |
| OSC1-1/32                      |  |  |  |
| OSC1-1/16                      |  |  |  |
| OSC1-1/8                       |  |  |  |
| OSC1-1/4                       |  |  |  |
| OSC1-1/2                       |  |  |  |
| OSC1-1/1                       |  |  |  |
|                                |  |  |  |

## Table 7.7.1, TROSC1 clock division ratio selection

(Default: 0x0)

#### Clock feed control

The clock feed to the 8-bit OSC1 timer is controlled using T8O1CE (D0/OSC\_T8OSC1 register).

The T8O1CE default setting is 0, which stops the clock feed. Setting T8O1CE to 1 sends the clock generated as above to the 8-bit OSC1 timer. Stop the clock feed to reduce power consumption if 8-bit OSC1 timer operation is not required.

\* T8O1CE: T8OSC1 Clock Enable Bit in the T8OSC1 Clock Control (OSC\_T8OSC1) Register (D0/0x5065)

## 7.8 Clock External Output (FOUTH, FOUT1)

The HSCLK division clock (FOUTH) and OSC1 clock (FOUT1) can be output to devices outside the chip.



Figure 7.8.1: Clock output circuit

#### **FOUTH** output

FOUTH is the HSCLK division clock.

#### Output pin setting

The FOUTH output pin is combined with the P30 port. This functions as the P30 port pin by default, so the pin function should be changed by writing 1 to P30MUX (D0/P3\_PMUX register) if use is required for FOUTH output.

\* P30MUX: P30 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D0/0x52a3)

#### FOUTH clock frequency selection

Three different clock output frequencies can be selected. Select the division ratio for the HSCLK clock using FOUTHD[1:0] (D[3:2]/OSC\_FOUT register).

#### \* FOUTHD[1:0]: FOUTH Clock Division Ratio Select Bits in the FOUT Control (OSC\_FOUT) Register (D[3:2]/0x5064)

| FOUTHD[1:0] | Division ratio |
|-------------|----------------|
| 0x3         | Reserved       |
| 0x2         | HSCLK-1/4      |
| 0x1         | HSCLK-1/2      |
| 0x0         | HSCLK-1/1      |
|             |                |

#### Table 7.8.1: FOUTH clock division ratio selection

(Default: 0x0)

#### Clock output control

The clock output is controlled using the FOUTHE (D1/OSC\_FOUT register). Setting FOUTHE to 1 outputs the FOUTH clock from the FOUTH pin. Setting it to 0 halts output.

\* FOUTHE: FOUTH Output Enable Bit in the FOUT Control (OSC\_FOUT) Register (D1/0x5064)



#### Figure 7.8.2: FOUTH output

Note: Since the FOUTH signal is not synchronized with FOUTHE writing, switching output on or off will generate certain hazards.

#### FOUT1 output

FOUT1 is the OSC1 clock.

#### Output pin setting

The FOUT1 output pin is combined with the P13 port. This functions as the P13 port pin by default, so the pin function should be changed by writing 1 to P13MUX (D3/P1\_PMUX register) if use is required for FOUT1 output.

\* P13MUX: P13 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D3/0x52a1)

#### Clock output control

The clock output is controlled using the FOUT1E (D0/OSC\_FOUT register). Setting FOUT1E to 1 outputs the FOUT1 clock from the FOUT1 pin. Setting it to 0 halts output.

\* FOUT1E: FOUT1 Output Enable Bit in the FOUT Control (OSC\_FOUT) Register (D1/0x5064)



Figure 7.8.3: FOUT1 output

Note: Since the FOUT1 signal is not synchronized with FOUT1E writing, switching output on or off will generate certain hazards.

## 7.9 RESET and NMI Input Noise Filters

Since accidental activation of RESET or NMI by noise in the S1C17 core input signal will cause unintended resetting or NMI processing, the OSC module incorporates noise filters operated by the system clock. The filters remove noise from these signals before they reach the S1C17 core.

Separate noise filters are used for each signal. You can select to use or bypass them individually. All are active immediately after the initial resetting.

RESET input noise filter: Filters noise when RSTFE (D1/OSC\_NFEN register) = 1; bypassed when RSTFE = 0 NMI input noise filter: Filters noise when NMIFE (D0/OSC\_NFEN register) = 1; bypassed when NMIFE = 0

- \* RSTFE: Reset Noise Filter Enable Bit in the Noise Filter Enable (OSC\_NFEN) Register (D1/0x5062)
- \* NMIFE: NMI Noise Filter Enable Bit in the Noise Filter Enable (OSC\_NFEN) Register (D0/0x5062)

The noise filters operate using the system clock (HSCLK or OSC1 clock) divided to 1/8. When activated, they filter out noise with pulses not exceeding two clock cycles.

This means the pulse width must be at least 16 cycles of the system clock to input as a valid signal.

Note: • The RESET input noise filter should normally be enabled.

• The S1C17702 does not feature external NMI input pins, but the watchdog timer NMI request signal passes through these filters.

## 7.10 Control Register Details

| Address |                                          | Register name                | Function                       |  |  |  |  |  |  |  |
|---------|------------------------------------------|------------------------------|--------------------------------|--|--|--|--|--|--|--|
| 0x5060  | OSC_SRC                                  | Clock Source Select Register | Clock source selection         |  |  |  |  |  |  |  |
| 0x5061  | OSC_CTL                                  | Oscillation Control Register | Oscillation control            |  |  |  |  |  |  |  |
| 0x5062  | OSC_NFEN                                 | Noise Filter Enable Register | Noise filter on/off            |  |  |  |  |  |  |  |
| 0x5063  | OSC_LCLK                                 | LCD Clock Setup Register     | LCD clock setting              |  |  |  |  |  |  |  |
| 0x5064  | OSC_FOUT                                 | FOUT Control Register        | Clock external output control  |  |  |  |  |  |  |  |
| 0x5065  | OSC_T8OSC1 T8OSC1 Clock Control Register |                              | 8-bit OSC1 timer clock setting |  |  |  |  |  |  |  |

#### Table 7.10.1 OSC register list

The OSC module registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x5060: Clock Source Select Register (OSC\_SRC)

| Register name   | Address  | Bit  | Name     | Function                   |   | Setting |   | Init. | R/W                | Remarks |  |
|-----------------|----------|------|----------|----------------------------|---|---------|---|-------|--------------------|---------|--|
| Clock Source    | 0x5060   | D7–2 | -        | reserved                   | _ |         | - | _     | 0 when being read. |         |  |
| Select Register | (8 bits) | D1   | HSCLKSEL | High-speed clock select    | 1 | OSC3    | 0 | IOSC  | 0                  | R/W     |  |
| (OSC_SRC)       |          | D0   | CLKSRC   | System clock source select | 1 | OSC1    | 0 | HSCLK | 0                  | R/W     |  |

#### D[7:2] Reserved

- D1 HSCLKSEL: High-speed Clock Select Bit Selects the high-speed clock (HSCLK). 1 (R/W): OSC3 0 (R/W): IOSC (default)
- Note: Both IOSC and OSC3 oscillator circuits must be turned on when selecting HSCLK. Otherwise, the system will not switch to HSCLK, even when HSCLKSEL is written to, and the HSCLKSEL value will remain unchanged. When selecting HSCLK, make sure PCKEN[1:0] (D[1:0]/CLG\_ PCLK register) is set to 0x3 (on) before writing to HSCLKSEL.

\* PCKEN[1:0]: PCLK Enable Bits in the PCLK Control (CLG\_PCLK) Register (D[1:0]/0x5080)

#### D0 CLKSRC: System Clock Source Select Bit

Selects the system clock source. 1 (R/W): OSC1 0 (R/W): HSCLK (default)

HSCLK (IOSC or OSC3) is selected for normal (high-speed) operations. If the HSCLK clock is not required, OSC1 can be set as the system clock and HSCLK (IOSC or OSC3) stopped to reduce power consumption.

Note: • Both OSC1 and HSCLK must be operating when the system clock is selected (OSC1 or HSCLK). Otherwise, the system will not switch system clocks, even when CLKSRC is written to, and the CLKSRC value will remain unchanged.

Table 7.10.2 shows the combinations of clock operating states and register settings enabling system clock (OSC1 or HSCLK) selection.

|      | -    | -    | -        | -                 |
|------|------|------|----------|-------------------|
| IOSC | OSC3 | OSC1 | HSCLKSEL | System clock      |
| On   | On   | On   | *        | IOSC/OSC3 or OSC1 |
| On   | Off  | On   | 0        | IOSC or OSC1      |
| Off  | On   | On   | 1        | OSC3 or OSC1      |

Table 7.10.2: System clock (OSC1/HSCLK) switching conditions

- The oscillator circuit selected as the system clock cannot be turned off.
- Continuous write/read access to CLKSRC is prohibited. At least one command unrelated to CLKSRC access must be inserted between the write and read commands.

| Register name    | Address  | Bit  | Name        | Function               |       | Sett      | ting |            | Init. | R/W | Remarks            |
|------------------|----------|------|-------------|------------------------|-------|-----------|------|------------|-------|-----|--------------------|
| Oscillation      | 0x5061   | D7–6 | IOSCWT[1:0] | IOSC wait cycle select | 105   | SCWT[1:0] | ٧    | Nait cycle | 0x0   | R/W |                    |
| Control Register | (8 bits) |      |             |                        |       | 0x3       |      | 8 cycles   |       |     |                    |
| (OSC_CTL)        |          |      |             |                        |       | 0x2       |      | 16 cycles  |       |     |                    |
|                  |          |      |             |                        |       | 0x1       | :    | 32 cycles  |       |     |                    |
|                  |          |      |             |                        |       | 0x0       | (    | 64 cycles  |       |     |                    |
|                  |          | D5–4 | OSC3WT[1:0] | OSC3 wait cycle select | OS    | C3WT[1:0] | ۱    | Nait cycle | 0x0   | R/W |                    |
|                  |          |      |             |                        |       | 0x3       | 1    | 28 cycles  |       |     |                    |
|                  |          |      |             |                        |       | 0x2       | 2    | 256 cycles |       |     |                    |
|                  |          |      |             |                        |       | 0x1       | 5    | 512 cycles |       |     |                    |
|                  |          |      |             |                        |       | 0x0       | 1(   | 024 cycles |       |     |                    |
|                  |          | D3   | -           | reserved               |       |           |      |            | -     | -   | 0 when being read. |
|                  |          | D2   | IOSCEN      | IOSC enable            | 1 E   | Enable    | 0    | Disable    | 1     | R/W |                    |
|                  |          | D1   | OSC1EN      | OSC1 enable            | 1   E | Enable    | 0    | Disable    | 0     | R/W |                    |
|                  |          | D0   | OSC3EN      | OSC3 enable            | 1 E   | Enable    | 0    | Disable    | 0     | R/W |                    |

#### 0x5061: Oscillation Control Register (OSC\_CTL)

#### D[7:6] IOSCWT[1:0]: IOSC Wait Cycle Select Bits

An oscillation stabilization wait time is set to prevent malfunctions due to unstable clock operations when IOSC oscillation begins.

The IOSC clock is not fed to the system immediately after IOSC oscillation starts—e.g., when power is first turned on, when waking from SLEEP, or the IOSC oscillator circuit is switched on via software, until the time set here has elapsed.

| IOSCWT[1:0] | Oscillation stabilization wait time |
|-------------|-------------------------------------|
| 0x3         | 8 cycles                            |
| 0x2         | 16 cycles                           |
| 0x1         | 32 cycles                           |
| 0x0         | 64 cycles                           |
|             |                                     |

#### Table 7.10.3: IOSC oscillation stabilization wait time settings

(Default: 0x0)

Since this is set to 64 cycles (IOSC clock) after an initial reset, the CPU begins operating following the reset only after the duration indicated below (at a maximum) has elapsed.

CPU operation start time on an initial reset  $\leq$  IOSC oscillation start time (max.) + IOSC oscillation stabilization wait time (64 cycles)

When the system clock is switched to IOSC on waking from SLEEP or immediately after turning on the IOSC oscillator circuit, the IOSC clock is fed to the system only after the duration indicated below (at a maximum) has elapsed. If the power supply voltage VDD has stabilized sufficiently, IOSCWT[1:0] can be set to 0x3 to reduce the oscillation stabilization wait time.

IOSC clock system feed wait time  $\leq$  IOSC oscillation start time (max.) + IOSC oscillation stabilization wait time

#### D[5:4] OSC3WT[1:0]: OSC3 Wait Cycle Select Bits

An oscillation stabilization wait timer is set to prevent malfunctions due to unstable clock operation at the start of OSC3 oscillation.

The OSC3 clock is not fed to the system immediately after OSC3 oscillation starts—for example, when power is first turned on, on awaking from SLEEP, or when the OSC3 oscillator circuit is turned on via software—until the time set here has elapsed.

| OSC3WT[1:0] | Oscillation stabilization wait time |  |  |  |  |  |  |  |  |
|-------------|-------------------------------------|--|--|--|--|--|--|--|--|
| 0x3         | 128 cycles                          |  |  |  |  |  |  |  |  |
| 0x2         | 256 cycles                          |  |  |  |  |  |  |  |  |
| 0x1         | 512 cycles                          |  |  |  |  |  |  |  |  |
| 0x0         | 1,024 cycles                        |  |  |  |  |  |  |  |  |
|             | (Default: 0x0)                      |  |  |  |  |  |  |  |  |

Table 7.10.4: OSC3 oscillation stabilization wait time settings

(Default: 0x0)

This is set to 1,024 cycles (OSC3 clock) after initial resetting. The CPU does not begin operating immediately after resetting until this time has elapsed.

#### 7 OSCILLATOR CIRCUIT (OSC)

Note: Note: Oscillation stability will vary, depending on the oscillator and other external components. Carefully consider the OSC3 oscillation stabilization wait time before reducing the time. When the system clock is switched to OSC3 immediately after the OSC3 oscillator circuit is turned on, the OSC3 clock is fed to the system only after the duration indicated below (at a maximum) has elapsed.

OSC3 clock system feed wait time  $\leq$  OSC3 oscillation start time (max.) + OSC3 oscillation stabilization wait time

#### D3 Reserved

#### D2 IOSCEN: IOSC Enable Bit

Permits or prevents IOSC oscillator circuit operations. 1 (R/W): Permitted (on) (default) 0 (R/W): Prohibited (off)

Note: The IOSC oscillator circuit cannot be stopped if the IOSC clock is being used as the system clock.

#### D1 OSC1EN: OSC1 Enable Bit

Permits or prohibits OSC1 oscillator circuit operation. 1 (R/W): Permitted (on) (default)

- 0 (R/W): Prohibited (off)
- Note: The OSC1 oscillator circuit cannot be stopped if the OSC1 clock is being used as the system clock.
  - When the system clock is switched to OSC1 immediately after the OSC1 oscillator circuit is turned on, the OSC1 clock is fed to the system only after the duration indicated below (at a maximum) has elapsed.

OSC1 clock system feed wait time  $\leq$  OSC1 oscillation start time (max.) + OSC1 oscillation stabilization wait time (256 cycles)

#### D0 OSC3EN: OSC3 Enable Bit

Permits or prohibits OSC3 oscillator circuit operation. 1 (R/W): Permitted (on) (default) 0 (R/W): Prohibited (off)

Note: The OSC3 oscillator circuit cannot be stopped if the OSC3 clock is being used as the system clock.

#### 0x5062: Noise Filter Enable Register (OSC\_NFEN)

| Register name   | Address  | Bit  | Name  | Function                  | Setting                 |        | Init.              | R/W     | Remarks |     |  |
|-----------------|----------|------|-------|---------------------------|-------------------------|--------|--------------------|---------|---------|-----|--|
| Noise Filter    | 0x5062   | D7–2 | -     | reserved                  | – – – 0 when being read |        | 0 when being read. |         |         |     |  |
| Enable Register | (8 bits) | D1   | RSTFE | Reset noise filter enable | 1                       | Enable | 0                  | Disable | 1       | R/W |  |
| (OSC_NFEN)      |          | D0   | NMIFE | NMI noise filter enable   | 1                       | Enable | 0                  | Disable | 0       | R/W |  |

#### D[7:2] Reserved

#### D1 RSTFE: Reset Noise Filter Enable Bit

Enables or disables the RESET input noise filter.

1 (R/W): Enabled (noise filtering) (default)

0 (R/W): Disabled (bypass)

This noise filter inputs only RESET pulses of not less than 16 cycles of the system clock (OSC3 or OSC1 clock) to the S1C17 core. Pulses having widths of less than 16 cycles are filtered out as noise. This should normally be enabled.

#### D0 NMIFE: NMI Noise Filter Enable Bit

Enables or disables the NMI input noise filter. 1 (R/W): Enabled (noise filtering) (default) 0 (R/W): Disabled (bypass)

This noise filter inputs only NMI pulses of not less than 16 cycles of the system clock (OSC3 or OSC1 clock) to the S1C17 core. Pulses having widths of less than 16 cycles are filtered out as noise. This should normally be enabled.

## Note: The S1C17702 does not feature external NMI input pins, but the watchdog timer NMI request signal passes through these filters.

| Register name  | Address  | Bit  | Name       | Function                        |   | Setting   |                | Init. | R/W | Remarks            |
|----------------|----------|------|------------|---------------------------------|---|-----------|----------------|-------|-----|--------------------|
| LCD Clock      | 0x5063   | D7–5 | -          | reserved                        |   | -         | -              | -     | -   | 0 when being read. |
| Setup Register | (8 bits) | D4–2 | LCKDV[2:0] | LCD clock division ratio select | L | CKDV[2:0] | Division ratio | 0x0   | R/W |                    |
| (OSC_LCLK)     |          |      |            |                                 |   | 0x7–0x5   | reserved       |       |     |                    |
|                |          |      |            |                                 |   | 0x4       | HSCLK-1/512    |       |     |                    |
|                |          |      |            |                                 |   | 0x3       | HSCLK-1/256    |       |     |                    |
|                |          |      |            |                                 |   | 0x2       | HSCLK-1/128    |       |     |                    |
|                |          |      |            |                                 |   | 0x1       | HSCLK-1/64     |       |     |                    |
|                |          |      |            |                                 |   | 0x0       | HSCLK-1/32     |       |     |                    |
|                |          | D1   | LCKSRC     | LCD clock source select         | 1 | OSC1      | 0 HSCLK        | 1     | R/W |                    |
|                |          | D0   | LCKEN      | LCD clock enable                | 1 | Enable    | 0 Disable      | 0     | R/W |                    |

#### 0x5063: LCD Clock Setup Register (OSC\_LCLK)

#### D[7:5] Reserved

#### D[4:2] LCKDV[2:0]: LCD Clock Division Ratio Select Bits

Select the division ratio here when HSCLK has been selected for the LCD clock source.

| LCKDV[2:0] | Division ratio |
|------------|----------------|
| 0x7 to 0x5 | Reserved       |
| 0x4        | HSCLK-1/512    |
| 0x3        | HSCLK-1/256    |
| 0x2        | HSCLK-1/128    |
| 0x1        | HSCLK-1/64     |
| 0x0        | HSCLK-1/32     |
|            |                |

#### Table 7.10.5: LCD clock division ratio selection

(Default: 0x0)

No division ratio needs to be selected if OSC1 has been selected for the LCD clock source.

#### D1 LCKSRC: LCD Clock Source Select Bit

Selects the LCD clock source. 1 (R/W): OSC1 (default) 0 (R/W): HSCLK

#### D0 LCKEN: LCD Clock Enable Bit

Permits or prevents the LCD clock feed to the LCD driver. 1 (R/W): Permitted (on) 0 (R/W): Prohibited (off) (default)

The LCKEN default setting is 0, which stops the clock feed. Setting LCKEN to 1 sends the clock selected as above to the LCD driver. If no LCD display is required, stop the clock feed to minimize current consumption.

#### 0x5064: FOUT Control Register (OSC\_FOUT)

| Register name | Address  | Bit  | Name        | Function                          | Set         | ting           | Init. | R/W | Remarks            |
|---------------|----------|------|-------------|-----------------------------------|-------------|----------------|-------|-----|--------------------|
| FOUT Control  | 0x5064   | D7-4 | -           | reserved                          | -           |                | -     | -   | 0 when being read. |
| Register      | (8 bits) | D3–2 | FOUTHD[1:0] | FOUTH clock division ratio select | FOUTHD[1:0] | Division ratio | 0x0   | R/W |                    |
| (OSC_FOUT)    |          |      |             |                                   | 0x3         | reserved       |       |     |                    |
|               |          |      |             |                                   | 0x2         | HSCLK-1/4      |       |     |                    |
|               |          |      |             |                                   | 0x1         | HSCLK-1/2      |       |     |                    |
|               |          |      |             |                                   | 0x0         | HSCLK-1/1      |       |     |                    |
|               |          | D1   | FOUTHE      | FOUTH output enable               | 1 Enable    | 0 Disable      | 0     | R/W | 1                  |
|               |          | D0   | FOUT1E      | FOUT1 output enable               | 1 Enable    | 0 Disable      | 0     | R/W |                    |

#### D[7:4] Reserved

#### D[3:2] FOUTHD[1:0]: FOUTH Clock Division Ratio Select Bits

Select the HSCLK clock division ratio to set the FOUTH clock frequency.

| Table 7.10.6: FOUTH | clock division ratio selection |
|---------------------|--------------------------------|
|                     | Division ratio                 |

| FOUTHD[1:0] | Division ratio |  |  |  |  |  |
|-------------|----------------|--|--|--|--|--|
| 0x3         | Reserved       |  |  |  |  |  |
| 0x2         | HSCLK-1/4      |  |  |  |  |  |
| 0x1         | HSCLK-1/2      |  |  |  |  |  |
| 0x0         | HSCLK-1/1      |  |  |  |  |  |

(Default: 0x0)

#### D1 FOUTHE: FOUTH Output Enable Bit

Permits or prohibits FOUTH clock (HSCLK division clock) external output. 1 (R/W): Permitted (on)

0 (R/W): Prohibited (off) (default)

Setting FOUTHE to 1 outputs the FOUTH clock from the FOUTH pin. Setting it to 0 stops the output. The FOUTH output pin is combined with the P30 port. This functions as the P30 port pin by default, so the pin function should be changed by writing 1 to P30MUX (D0/P3\_PMUX register) if use is required for FOUTH output.

\* **P30MUX**: P30 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D0/0x52a3)

#### D0 FOUT1E: FOUT1 Output Enable Bit

Permits or prohibits FOUT1 clock (OSC1 clock) external output. 1 (R/W): Permitted (on) 0 (R/W): Prohibited (off) (default)

Setting FOUT1E to 1 outputs the FOUT1 clock from the FOUT1 pin. Setting it to 0 stops the output. The FOUT1 output pin is combined with the P13 port. This functions as the P13 port pin by default, so the pin function should be changed by writing 1 to P13MUX (D3/P1\_PMUX register) if use is required for FOUT1 output.

\* **P13MUX**: P13 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D3/0x52a1)

#### 0x5065: T8OSC1 Clock Control Register (OSC\_T8OSC1)

| Register name    | Address  | Bit  | Name        | Function                           | Setting     |                | Init. | R/W | Remarks            |
|------------------|----------|------|-------------|------------------------------------|-------------|----------------|-------|-----|--------------------|
| T8OSC1 Clock     | 0x5065   | D7-4 | -           | reserved                           | -           | _              | -     | -   | 0 when being read. |
| Control Register | (8 bits) | D3–1 | T8O1CK[2:0] | T8OSC1 clock division ratio select | T8O1CK[2:0] | Division ratio | 0x0   | R/W |                    |
| (OSC_T8OSC1)     |          |      |             |                                    | 0x7-0x6     | reserved       |       |     |                    |
|                  |          |      |             |                                    | 0x5         | OSC1-1/32      |       |     |                    |
|                  |          |      |             |                                    | 0x4         | OSC1-1/16      |       |     |                    |
|                  |          |      |             |                                    | 0x3         | OSC1-1/8       |       |     |                    |
|                  |          |      |             |                                    | 0x2         | OSC1-1/4       |       |     |                    |
|                  |          |      |             |                                    | 0x1         | OSC1-1/2       |       |     |                    |
|                  |          |      |             |                                    | 0x0         | OSC1-1/1       |       |     |                    |
|                  |          | D0   | T8O1CE      | T8OSC1 clock output enable         | 1 Enable    | 0 Disable      | 0     | R/W |                    |

#### D[7:4] Reserved

#### D[3:1] T8O1CK[2:0]: T8OSC1 Clock Division Ratio Select Bits

Select the OSC1 clock division ratio and set the 8-bit OSC1 timer operation clock.

| T8O1CK[2:0] | Division ratio                        |  |  |  |  |  |  |  |
|-------------|---------------------------------------|--|--|--|--|--|--|--|
| 0x7 to 0x6  | Reserved                              |  |  |  |  |  |  |  |
| 0x5         | OSC1-1/32                             |  |  |  |  |  |  |  |
| 0x4         | OSC1-1/16                             |  |  |  |  |  |  |  |
| 0x3         | OSC1-1/8                              |  |  |  |  |  |  |  |
| 0x2         | OSC1-1/4                              |  |  |  |  |  |  |  |
| 0x1         | OSC1-1/2                              |  |  |  |  |  |  |  |
| 0x0         | OSC1-1/1                              |  |  |  |  |  |  |  |
|             | · · · · · · · · · · · · · · · · · · · |  |  |  |  |  |  |  |

#### Table 7.10.7: T8OSC1 clock division ratio selection

(Default: 0x0)

#### D0 T8O1CE: T8OSC1 Clock Output Enable Bit

Permits or prohibits clock feed to the 8-bit OSC1 timer.

1 (R/W): Permitted (on)

0 (R/W): Prohibited (off) (default)

The T8O1CE default setting is 0, which stops the clock feed. Setting T8O1CE to 1 sends the clock selected by the above bit to the 8-bit OSC1 timer. Stop the clock feed to reduce power consumption if 8-bit OSC1 timer operation is not required.

## 7.11 Precautions

OSC3 oscillation stability will vary, depending on the oscillator and other external components. Carefully
consider the OSC3 oscillation stabilization wait time before reducing the time. When the system clock is
switched to OSC3 immediately after the OSC3 oscillator circuit is turned on, the OSC3 clock is fed to the system
only after the duration indicated below (at a maximum) has elapsed.

OSC3 clock system feed wait time  $\leq$  OSC3 oscillation start time (max.) + OSC3 oscillation stabilization wait time

• When the system clock is switched to OSC1 immediately after the OSC1 oscillator circuit is turned on, the OSC1 clock is fed to the system only after the duration indicated below (at a maximum) has elapsed.

OSC1 clock system feed wait time  $\leq$  OSC1 oscillation start time (max.) + OSC1 oscillation stabilization wait time (256 cycles)

- The IOSC oscillator circuit cannot be stopped if the IOSC clock is being used as the system clock.
- The OSC3 oscillator circuit cannot be stopped if the OSC3 clock is being used as the system clock.
- The OSC1 oscillator circuit cannot be stopped if the OSC1 clock is being used as the system clock.
- Since the FOUTH/FOUT1 signal is not synchronized with FOUTHE/FOUT1E writing, switching output on or off will generate certain hazards.
- Both the IOSC and OSC3 oscillator circuits must be turned on when selecting HSCLK. Otherwise, the system will fail to switch to HSCLK even when HSCLKSEL is written to, and the HSCLKSEL value will remain unchanged. When selecting HSCLK, make sure PCKEN[1:0] (D[1:0]/CLG\_PCLK register) is set to 0x3 (on) before writing to HSCLKSEL.
- Both OSC1 and HSCLK must be operating when the system clock is selected (OSC1 or HSCLK). Otherwise, the system will not switch system clocks, even when CLKSRC is written to, and the CLKSRC value will remain unchanged.

Table 7.11.1 shows the combinations of clock operating states and register settings enabling system clock (OSC1 or HSCLK) selection.

| IOSC | OSC3 | OSC1 | HSCLKSEL | System clock      |
|------|------|------|----------|-------------------|
| On   | On   | On   | *        | IOSC/OSC3 or OSC1 |
| On   | Off  | On   | 0        | IOSC or OSC1      |
| Off  | On   | On   | 1        | OSC3 or OSC1      |

Table 7.11.1: System clock (OSC1/HSCLK) switching conditions

- The oscillator circuit selected as the system clock cannot be turned off.
- Continuous write/read access to CLKSRC is prohibited. At least one command unrelated to CLKSRC access must be inserted between the write and read commands.
- Be sure to wait at least one LCLK clock cycle before setting LCKEN (D0/OSC\_LCLK register) to 0 to stop the LCLK clock feed immediately after setting DSPC[1:0] (D[1:0]/LCD\_DCTL register) to 0x0 (display off). When resuming display with no wait time inserted after the LCLK feed is disabled, wait at least one LCLK clock cycle until DSPC[1:0] is set to a value other than 0x0 after LCKEN is set to 1 to resume clock feed.

# 8 Clock Generator (CLG)

## 8.1 Clock Generator Configuration

The clock generator controls the system clock feed to the S1C17 core and peripheral modules. Figure 8.1.1 illustrates the clock system and CLG module configuration.



Figure 8.1.1: CLG module configuration

To reduce power consumption, control the clock in conjunction with processing and use standby mode. For more information on reducing power consumption, refer to "Appendix C: Power Saving."

## 8.2 CPU Core Clock (CCLK) Control

The CLG module incorporates a clock gear to slow down the system clock to send to the S1C17 core. To reduce power consumption, operate the S1C17 core with the slowest possible clock speed. The halt instruction can be executed to stop the clock feed from the CLG to the S1C17 core for power savings.



#### **Clock gear settings**

CCLKGR[1:0] (D[1:0]/CLG\_CCLK register) is used to select the gear ratio to reduce system clock speeds.

\* CCLKGR[1:0]: CCLK Clock Gear Ratio Select Bits in the CCLK Control (CLG\_CCLK) Register (D[1:0]/0x5081)

|             | -          |  |  |  |
|-------------|------------|--|--|--|
| CCLKGR[1:0] | Gear ratio |  |  |  |
| 0x3         | 1/8        |  |  |  |
| 0x2         | 1/4        |  |  |  |
| 0x1         | 1/2        |  |  |  |
| 0x0         | 1/1        |  |  |  |
|             |            |  |  |  |

Table 8.2.1: CCLK gear ratio selection

(Default: 0x0)

#### Clock feed control

The CCLK clock feed is stopped by executing the halt instruction. Since this does not stop the system clock, peripheral modules will continue to operate.

HALT mode is cleared by resetting, NMI, or other interrupts. The CCLK feed resumes when HALT mode is cleared.

Executing the slp instruction suspends system clock feed to the CLG, thereby halting the CCLK feed as well. Clearing SLEEP mode with an external interrupt restarts the system clock feed and the CCLK feed.

For more information on system clock control, refer to "7 Oscillator Circuit (OSC)."

## 8.3 Peripheral Module Clock (PCLK) Control

The CLG module also controls the clock feed to peripheral modules. The system clock is used unmodified for the peripheral module clock (PCLK).



Figure 8.3.1: Peripheral module clock control circuit

#### **Clock feed control**

PCLK feed is controlled by PCKEN[1:0] (D[1:0]/CLG\_PCLK register).

| Table 8.3.1: PCLK control |                    |  |  |  |  |  |
|---------------------------|--------------------|--|--|--|--|--|
| PCKEN[1:0]                | PCLK feed          |  |  |  |  |  |
| 0x3                       | Permitted (on)     |  |  |  |  |  |
| 0x2                       | Setting prohibited |  |  |  |  |  |
| 0x1                       | Setting prohibited |  |  |  |  |  |
| 0x0                       | Prohibited (off)   |  |  |  |  |  |
|                           |                    |  |  |  |  |  |

#### \* PCKEN[1:0]: PCLK Enable Bits in the PCLK Control (CLG\_PCLK) Register (D[1:0]/0x5080)

(Default: 0x3)

The default setting is 0x3, which enables the clock feed. Stop the clock feed to reduce power consumption unless all peripheral modules (modules listed above) within the internal peripheral circuit area need to be running.

## Note: Do not set PCKEN[1:0] (D[1:0]/CLG\_PCLK register) to 0x2 or 0x1, since doing so will stop the operation of certain peripheral modules.

#### Peripheral modules not operating on PCLK

With the exception of control register access, the following peripheral modules operate using a clock other than PCLK. Thus, PCLK is not required after setting the control register and initiating operations.

#### **OSC1** peripheral module

The clock timer, stopwatch timer, watchdog timer, and 8-bit OSC1 timer operate using the OSC1 division clock. Stopping PCLK prevents read/program access to/from the control register, but operations will continue.

#### LCD driver

The LCD driver operates using the OSC1 clock or HSCLK division clock. Stopping PCLK prevents read/ program access to/from the control register, but operations will continue. PCLK is not required to access the display memory.

## 8.4 Control Register Details

#### Table 8.4.1 CLG register list

|          |                       | -                              |
|----------|-----------------------|--------------------------------|
|          | Register name         | Function                       |
| CLG_PCLK | PCLK Control Register | PCLK feed control              |
| CLG_CCLK | CCLK Control Register | CCLK division ratio setting    |
|          |                       | CLG_PCLK PCLK Control Register |

The CLG module registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x5080: PCLK Control Register (CLG\_PCLK)

| Register name | Address  | Bit  | Name       | Function    | Setting    |             | Init. | R/W | Remarks            |
|---------------|----------|------|------------|-------------|------------|-------------|-------|-----|--------------------|
| PCLK Control  | 0x5080   | D7–2 | -          | reserved    | -          |             | -     | -   | 0 when being read. |
| Register      | (8 bits) | D1–0 | PCKEN[1:0] | PCLK enable | PCKEN[1:0] | PCLK supply | 0x3   | R/W |                    |
| (CLG_PCLK)    |          |      |            |             | 0x3        | Enable      |       |     |                    |
|               |          |      |            |             | 0x2        | Not allowed |       |     |                    |
|               |          |      |            |             | 0x1        | Not allowed |       |     |                    |
|               |          |      |            |             | 0x0        | Disable     |       |     |                    |

#### D[7:2] Reserved

#### D[1:0] PCKEN[1:0]: PCLK Enable Bits

Permits or prohibits clock (PCLK) feed to internal peripheral modules.

| PCKEN[1:0] | PCLK feed          |
|------------|--------------------|
| 0x3        | Permitted (on)     |
| 0x2        | Setting prohibited |
| 0x1        | Setting prohibited |
| 0x0        | Prohibited (off)   |
|            |                    |

#### Table 8.4.2: PCLK control

(Default: 0x3)

The PCKEN[1:0] default setting is 0x3, which enables clock feed. Stop the clock feed to reduce power consumption if the peripheral modules listed below are not required.

Peripheral modules operated using PCLK

- Prescaler (PWM & capture timer, remote controller, P port)
- UART
- 8-bit timer Ch.0 & Ch.1
- 16-bit timer Ch.0 to Ch.2
- SPI
- I<sup>2</sup>C
- SVD circuit
- P port & port MUX
- PWM & capture timer
- MISC register
- Remote controller

Since the following peripheral modules are not operated using PCLK except for control register access, PCLK is not required after setting the control register to start operations.

- Clock timer
- Stopwatch timer
- Watchdog timer
- 8-bit OSC1 timer
- LCD driver

Note: Do not set PCKEN[1:0] to 0x2 or 0x1, since doing so will stop the operation of certain peripheral modules.

| Register name | Address  | Bit  | Name        | Function                     | Setting     |            | Init. | R/W | Remarks            |
|---------------|----------|------|-------------|------------------------------|-------------|------------|-------|-----|--------------------|
| CCLK Control  | 0x5081   | D7–2 | -           | reserved                     | -           |            | -     | -   | 0 when being read. |
| Register      | (8 bits) | D1–0 | CCLKGR[1:0] | CCLK clock gear ratio select | CCLKGR[1:0] | Gear ratio | 0x0   | R/W |                    |
| (CLG_CCLK)    |          |      |             | _                            | 0x3         | 1/8        |       |     |                    |
|               |          |      |             |                              | 0x2         | 1/4        |       |     |                    |
|               |          |      |             |                              | 0x1         | 1/2        |       |     |                    |
|               |          |      |             |                              | 0x0         | 1/1        |       |     |                    |

#### 0x5081: CCLK Control Register (CLG\_CCLK)

#### D[7:2] Reserved

#### D[1:0] CCLKGR[1:0]: CCLK Clock Gear Ratio Select Bits

Select the gear ratio for reducing system clock speed and set the CCLK clock speed for operating the S1C17 core. To reduce power consumption, operate the S1C17 core using the slowest possible clock speed.

| CCLKGR[1:0] | Gear ratio |  |  |  |
|-------------|------------|--|--|--|
| 0x3         | 1/8        |  |  |  |
| 0x2         | 1/4        |  |  |  |
| 0x1         | 1/2        |  |  |  |
| 0x0         | 1/1        |  |  |  |

#### Table 8.4.3: CCLK gear ratio selection

(Default: 0x0)

## 8.5 Precautions

(1) The default settings enable PCLK feed to peripheral modules. To reduce power consumption, stop the clock feed if the peripheral modules listed below are not used.

Peripheral modules operated using PCLK

- Prescaler (PWM & capture timer, remote controller, P port)
- UART
- 8-bit timer Ch.0 & Ch.1
- 16-bit timer Ch.0 to Ch.2
- SPI
- I<sup>2</sup>C
- SVD circuit
- P port & port MUX
- PWM & capture timer
- MISC register
- Remote controller

Since the following peripheral modules are not operated using PCLK except for control register access, PCLK is not required after setting the control register to start operations.

- Clock timer
- Stopwatch timer
- Watchdog timer
- 8-bit OSC1 timer
- LCD driver
- (2) Do not set PCKEN[1:0] (D[1:0]/CLG\_PCLK register) to 0x2 or 0x1, since doing so will stop the operation of certain peripheral modules.
  - \* PCKEN[1:0]: PCLK Enable Bits in the PCLK Control (CLG\_PCLK) Register (D[1:0]/0x5080)

# 9 Prescaler (PSC)

## 9.1 Prescaler Configuration

The S1C17702 incorporates a prescaler to generate a clock for timer operations. The prescaler generates 15 different frequencies by dividing the PCLK clock fed from the clock generator into 1/1 to 1/16K. The peripheral modules to which the clock is fed include clock selection registers enabling selection of one as a count or operation clock.



Figure 9.1.1: Prescaler

The prescaler is controlled by the PRUN bit (D0/PSC\_CTL register). To operate the prescaler, program 1 to PRUN. Writing 0 to PRUN stops the prescaler. Stopping the prescaler while the timer and interface module are halted enables the current consumption to be reduced. The prescaler is stopped immediately after initial resetting.

\* **PRUN**: Prescaler Run/Stop Control Bit in the Prescaler Control (PSC\_CTL) Register (D0/0x4020)

#### Note: PCLK must be fed from the clock generator to use the prescaler.

The prescaler features another control bit, PRUND (D1/PSC\_CTL register), which specifies prescaler operations in Debug mode. Setting PRUND to 1 also operates the prescaler in Debug mode. Setting it to 0 stops the prescaler once the S1C17 core switches to Debug mode. Set PRUND to 1 if the timer and interface module are to be used during debugging.

\* PRUND: Prescaler Run/Stop Setting Bit in Debug Mode in the Prescaler Control (PSC\_CTL) Register (D1/0x4020)

## 9.2 Control Register Details

#### Table 9.2.1: Prescaler register

|         |         |                            | 5                            |
|---------|---------|----------------------------|------------------------------|
| Address |         | Register name              | Function                     |
| 0x4020  | PSC_CTL | Prescaler Control Register | Prescaler start/stop control |

The prescaler register is an 8-bit register.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x4020: Prescaler Control Register (PSC\_CTL)

| Register name  | Address  | Bit  | Name  | Function Setting                 |   | Init. | R/W | Remarks |   |     |                    |
|----------------|----------|------|-------|----------------------------------|---|-------|-----|---------|---|-----|--------------------|
| Prescaler Con- | 0x4020   | D7–2 | -     | reserved                         |   | -     | -   |         | - | -   | 0 when being read. |
| trol Register  | (8 bits) | D1   | PRUND | Prescaler run/stop in debug mode | 1 | Run   | 0   | Stop    | 0 | R/W |                    |
| (PSC_CTL)      |          | D0   | PRUN  | Prescaler run/stop control       | 1 | Run   | 0   | Stop    | 0 | R/W |                    |

#### D[7:2] Reserved

#### D1 PRUND: Prescaler Run/Stop Setting Bit for Debug Mode

Selects prescaler operations in Debug mode. 1 (R/W): Operate

0 (R/W): Stop (default)

Setting PRUND to 1 operates the prescaler even in Debug mode. Setting it to 0 stops the prescaler once the S1C17 core switches to Debug mode. Set PRUND to 1 to use the timer and interface module during debugging.

#### D0 PRUN: Prescaler Run/Stop Control Bit

Starts or stops prescaler operation. 1 (R/W): Start operation 0 (R/W): Stop (default)

Program 1 to PRUN to operate the prescaler. Program 0 to PRUN to stop the prescaler. To reduce current consumption, stop the prescaler if the timer and interface module are already stopped.

## 9.3 Precautions

PCLK must be fed from the clock generator to use the prescaler.

# **10 Input/Output Port (P)**

## 10.1 Input/Output Port Configuration

The S1C17702 includes 28 input/output ports (P0[7:0], P1[7:0], P2[7:0], P3[3:0]) to allow software switching of input/output direction. These share internal peripheral module input/output pins (with certain exceptions), but pins not used for peripheral modules can be used as general purpose input/output ports. Figure 10.1.1 illustrates the input/output port configuration.



Figure 10.1.1: Input/output port configuration

The P0 and P1 ports can generate input interrupts.

The P0[3:0] port can be used for key entry resets. (For more information, refer to "5.1.2 P0 Port Key Entry Reset.")

Note: The PCLK clock must be fed from the clock generator to access the input/output port. The prescaler output clock is also needed to operate the P0/P1 port chattering filter. Switch on the prescaler when using this function.

## 10.2 Input/Output Pin Function Selection (Port MUX)

The input/output port pins share peripheral module input/output pins (with certain exceptions). Each pin can be set for use as an input/output port or for peripheral modules via the corresponding port function selection bits for each port. Pins not used for peripheral modules can be used as general purpose input/output ports.

| Pin function 1   | Pin function 2 | Port function | Control register                                    |
|------------------|----------------|---------------|-----------------------------------------------------|
| PxxMUX = 0       | PxxMUX = 1     | selection bit | Control register                                    |
| P00/EXCL3 (T16E) | -              | -             | -                                                   |
| P01/EXCL4 (T16E) | -              | -             | -                                                   |
| P02              | REMI (REMC)    | P02MUX (D2)   | P0 Port Function Select (P0_PMUX) Register (0x52a0) |
| P03              | REMO (REMC)    | P03MUX (D3)   |                                                     |
| P04              | TOUT4 (T16E)   | P04MUX (D4)   |                                                     |
| P05              | TOUTN4 (T16E)  | P05MUX (D5)   |                                                     |
| P06/EXCL2 (T16)  | -              | -             | _                                                   |
| P07/EXCL1 (T16)  | -              | -             | -                                                   |
| P10              | SIN1 (UART)    | P10MUX (D0)   | P1 Port Function Select (P1_PMUX) Register (0x52a1) |
| P11              | SOUT1 (UART)   | P11MUX (D1)   |                                                     |
| P12              | SCLK1 (UART)   | P12MUX (D2)   |                                                     |
| P13              | FOUT1 (OSC)    | P13MUX (D3)   |                                                     |
| P14              | SDA (I2C)      | P14MUX (D4)   |                                                     |
| P15              | SCL (I2C)      | P15MUX (D5)   |                                                     |
| P16/EXCL0 (T16)  | TOUT5 (T8OSC1) | P16MUX (D6)   |                                                     |
| P17              | #SPISS (SPI)   | P17MUX (D7)   |                                                     |
| P20              | SDI (SPI)      | P20MUX (D0)   | P2 Port Function Select (P2_PMUX) Register (0x52a2) |
| P21              | SDO (SPI)      | P21MUX (D1)   |                                                     |
| P22              | SPICLK (SPI)   | P22MUX (D2)   |                                                     |
| P23              | SIN0 (UART)    | P23MUX (D3)   |                                                     |
| P24              | SOUT0 (UART)   | P24MUX (D4)   |                                                     |
| P25              | SCLK0 (UART)   | P25MUX (D5)   |                                                     |
| P26              | TOUT3 (T16E)   | P26MUX (D6)   |                                                     |
| P27              | TOUTN3 (T16E)  | P27MUX (D7)   |                                                     |
| P30              | FOUTH (OSC)    | P30MUX (D0)   | P3 Port Function Select (P3_PMUX) Register (0x52a3) |
| DCLK (DBG)       | P31            | P31MUX (D1)   |                                                     |
| DST2 (DBG)       | P32            | P32MUX (D2)   |                                                     |
| DSIO (DBG)       | P33            | P33MUX (D3)   |                                                     |

Resetting the input/output port pins (Pxx) resets them to their default functions (pin function 1 in Table 10.2.1).

Pins P00, P01, P06, P07, and P16 can also be used as 16-bit timer external clock input pins by setting them to input mode. They are simultaneously set to function as general purpose input ports.

For information on functions other than the input/output ports, refer to the discussion of the peripheral modules indicated in parentheses. The sections below discuss port functions with the pins set as general purpose input/output ports.

## 10.3 Data Input/Output

#### Data input/output control

The input/output ports permit selection of the data input/output direction for each bit using PxOEN[7:0] ( $Px_OEN$  register) and PxIEN[7:0] ( $Px_IEN$  register). PxOEN[7:0] permits and prohibits data output, while PxIEN[7:0] permits and prohibits data input.

- \* P0OEN[7:0]: P0[7:0] Port Output Enable Bits in the P0 Port Output Enable (P0\_OEN) Register (D[7:0]/0x5202)
- \* P1OEN[7:0]: P1[7:0] Port Output Enable Bits in the P1 Port Output Enable (P1\_OEN) Register (D[7:0]/0x5212)
- \* P2OEN[7:0]: P2[7:0] Port Output Enable Bits in the P2 Port Output Enable (P2\_OEN) Register (D[7:0]/0x5222)
- \* P3OEN[3:0]: P3[3:0] Port Output Enable Bits in the P3 Port Output Enable (P3\_OEN) Register (D[3:0]/0x5232)
- \* P0IEN[7:0]: P0[7:0] Port Input Enable Bits in the P0 Port Input Enable (P0\_IEN) Register (D[7:0]/0x520a)
- \* P1IEN[7:0]: P1[7:0] Port Input Enable Bits in the P1 Port Input Enable (P1\_IEN) Register (D[7:0]/0x521a)
- \* P2IEN[7:0]: P2[7:0] Port Input Enable Bits in the P2 Port Input Enable (P2\_IEN) Register (D[7:0]/0x522a)
- \* P3IEN[3:0]: P3[3:0] Port Input Enable Bits in the P3 Port Input Enable (P3\_IEN) Register (D[3:0]/0x523a)

| PxOEN[7:0]     | PxIEN[7:0]    | PxPU[7:0]       | Port status                                                      |
|----------------|---------------|-----------------|------------------------------------------------------------------|
| output control | input control | pull-up control | i ori otatuo                                                     |
| 0              | 1             | 0               | Functions as input port (pull-up off).                           |
|                |               |                 | Port pin (external input signal) value can be read out from      |
|                |               |                 | PxIN[7:0] (input data). Output is prohibited.                    |
| 0              | 1             | 1               | Functions as input port (pull-up on). (Default)                  |
|                |               |                 | Port pin (external input signal) value can be read out from      |
|                |               |                 | PxIN[7:0] (input data). Output is prohibited.                    |
| 1              | 0             | 1 or 0          | Functions as output port (pull-up off).                          |
|                |               |                 | Input is prohibited. The value read from PxIN[7:0] (input data)  |
|                |               |                 | is 0.                                                            |
| 1              | 1             | 1 or 0          | Functions as output port (pull-up off).                          |
|                |               |                 | Input is also permitted. The port pin value (output value) can   |
|                |               |                 | be read out from PxIN[7:0] (input data).                         |
| 0              | 0             | 0               | Pin switches to high-impedance (pull-up off).                    |
|                |               |                 | Output/input is prohibited. The value read from PxIN[7:0] (input |
|                |               |                 | data) is 0.                                                      |
| 0              | 0             | 1               | Pin switches to high-impedance (pull-up on).                     |
|                |               |                 | Output/input is prohibited. The value read from PxIN[7:0] (input |
|                |               |                 | data) is 0.                                                      |

| Tahla | 10.3.1: | Data | innut/ | outout | tahla |
|-------|---------|------|--------|--------|-------|
| lable | 10.0.1. | Dala | input  | output | lable |

The input/output direction of ports with peripheral module function selected is controlled by the peripheral module. PxOEN[7:0] and PxIEN[7:0] settings are ignored.

#### Data input

To input the port pin state and read out the value, set PxIEN[7:0] to 1 (default) and permit input.

To input an external signal, PxOEN[7:0] should also be set to 0 (default). This will switch the input/output port to high-impedance and function as an input port (input mode). The port will be pulled up if pull-up is enabled by the Px\_PU register.

In input mode, the input pin state can be read out directly from PxIN[7:0] ( $Px_IN$  register). The value read will be 1 when the input pin is at High (HVDD) level and 0 when it is at Low (Vss) level.

- \* POIN[7:0]: P0[7:0] Port Input Data Bits in the P0 Port Input Data (P0\_IN) Register (D[7:0]/0x5200)
- \* P1IN[7:0]: P1[7:0] Port Input Data Bits in the P1 Port Input Data (P1\_IN) Register (D[7:0]/0x5210)
- \* P2IN[7:0]: P2[7:0] Port Input Data Bits in the P2 Port Input Data (P2\_IN) Register (D[7:0]/0x5220)
- \* P3IN[3:0]: P3[3:0] Port Input Data Bits in the P3 Port Input Data (P3\_IN) Register (D[3:0]/0x5230)

The port pin state will be input if PxIEN[7:0] is 1, even when output is permitted (PxOEN[7:0] = 1) (output mode). In this case, the value actually output can be read out from PxIN[7:0].

If PxIEN[7:0] is set to 0, input will be prohibited, and the value read out from PxIN[7:0] is 0.

#### Data output

To output data from the port pin, PxOEN[7:0] should be set to 1 and output permitted (set to output mode). The input/output port then functions as the output port, and the value set in the PxOUT[7:0] ( $Px_OUT$  register) is output from the port pin. The port pin outputs High (VDD) level if PxOUT[7:0] is set to 1 and Low (Vss) level if set to 0. Note that the port will not be pulled up in output mode, even if pull-up is enabled by the  $Px_PU$  register.

- \* POOUT[7:0]: P0[7:0] Port Output Data Bits in the P0 Port Output Data (P0\_OUT) Register (D[7:0]/0x5201)
- \* P1OUT[7:0]: P1[7:0] Port Output Data Bits in the P1 Port Output Data (P1\_OUT) Register (D[7:0]/0x5211)
- \* P2OUT[7:0]: P2[7:0] Port Output Data Bits in the P2 Port Output Data (P2\_OUT) Register (D[7:0]/0x5221)
- \* P3OUT[3:0]: P3[3:0] Port Output Data Bits in the P3 Port Output Data (P3\_OUT) Register (D[3:0]/0x5231)

Writing to PxOUT[7:0] is possible without affecting pin status, even in input mode.

# 10.4 Pull-up Control

The input/output port contains a pull-up resistor, which you can choose to use or not use individually for each bit using the PxPU[7:0] ( $Px_PU$  register).

\* POPU[7:0]: P0[7:0] Port Pull-up Enable Bits in the P0 Port Pull-up Control (P0\_PU) Register (D[7:0]/0x5203)

- \* P1PU[7:0]: P1[7:0] Port Pull-up Enable Bits in the P1 Port Pull-up Control (P1\_PU) Register (D[7:0]/0x5213)
- \* P2PU[7:0]: P2[7:0] Port Pull-up Enable Bits in the P2 Port Pull-up Control (P2\_PU) Register (D[7:0]/0x5223)
- \* P3PU[3:0]: P3[3:0] Port Pull-up Enable Bits in the P3 Port Pull-up Control (P3\_PU) Register (D[3:0]/0x5233)

Setting PxPU[7:0] to 1 (default) enables the pull-up resistor and pulls up the port pin in input mode. It will not be pulled up if set to 0.

The PxPU[7:0] setting is disabled and not pulled up in output mode, regardless of the PxIEN[7:0] setting.

Input/output ports that are not used should be set with pull-up enabled.

This pull-up setting is also enabled for ports for which the peripheral module function has been selected.

A delay will occur in the waveform rising edge depending on time constants such as pull-up resistance and pin load capacitance if the port pin is switched from Low level to High level by the internal pull-up resistor. An appropriate wait time must be set for the input/output port loading. The wait time set should be a value not less than that calculated from the following equation.

Wait time = RIN × (CIN + load capacitance on board) × 1.6 [s] RIN: pull-up resistance maximum value CIN: pin capacitance maximum value

# 10.5 Input Interface Level

The input/output port input interface level can be selected individually for each bit using PxSM[7:0] (Px\_SM register).

- \* **P0SM[7:0]**: P0[7:0] Port Schmitt Trigger Input Enable Bits in the P0 Port Schmitt Trigger Control (P0\_SM) Register (D[7:0]/0x5204)
- \* **P1SM[7:0]**: P1[7:0] Port Schmitt Trigger Input Enable Bits in the P1 Port Schmitt Trigger Control (P1\_SM) Register (D[7:0]/0x5214)
- \* **P2SM[7:0]**: P2[7:0] Port Schmitt Trigger Input Enable Bits in the P2 Port Schmitt Trigger Control (P2\_SM) Register (D[7:0]/0x5224)
- \* P3SM[3:0]: P3[3:0] Port Schmitt Trigger Input Enable Bits in the P3 Port Schmitt Trigger Control (P3\_SM) Register (D[3:0]/0x5234)

Setting PxSM[7:0] to 1 (default) selects CMOS Schmitt level; setting to 0 selects CMOS level.

# 10.6 P0 and P1 Port Chattering Filter Function

The P0 and P1 port includes a chattering filter circuit for key entry, which you can select to use or not use (and for which you can select a check time if used) individually for the four P0[3:0] and P0[7:4] ports using PxCF1[2:0] (D[2:0]/Px\_CHAT register), PxCF2[2:0] (D[6:4]/Px\_CHAT register).

- \* **P0CF1[2:0]**: P0[3:0] Chattering Filter Time Select Bits in the P0 Port Chattering Filter Control (P0\_CHAT) Register (D[2:0]/0x5208)
- \* **P0CF2[2:0]**: P0[7:4] Chattering Filter Time Select Bits in the P0 Port Chattering Filter Control (P0\_CHAT) Register (D[6:4]/0x5208)
- \* **P1CF1[2:0]**: P1[3:0] Chattering Filter Time Select Bits in the P1 Port Chattering Filter Control (P1\_CHAT) Register (D[2:0]/0x5218)
- \* **P1CF2[2:0]**: P1[7:4] Chattering Filter Time Select Bits in the P1 Port Chattering Filter Control (P1\_CHAT) Register (D[6:4]/0x5218)

| liter function settings |
|-------------------------|
| Check time *            |
| 16384/fpclk (8 ms)      |
| 8192/fpclk (4 ms)       |
| 4096/fpclk (2 ms)       |
| 2048/fpclk (1 ms)       |
| 1024/fpclk (512 µs)     |
| 512/fpclk (256 µs)      |
| 256/fpclk (128 µs)      |
| No check time (Off)     |
|                         |

| Tahla | 1061.   | Chattering | filtor | function | eattinge |
|-------|---------|------------|--------|----------|----------|
| lable | 10.0.1. | Unattering | niter  | Tunction | seunys   |

(Default: 0x0, \*when HSCLK = 2 MHz and PCLK = HSCLK)

- Note: The chattering filter check time refers to the maximum pulse width that can be filtered. Generating an input interrupt requires a minimum input time of the check time and a maximum input time of twice the check time.
  - Input interrupts will not be accepted for a transition into SLEEP mode with the chattering filter left on. The chattering filter should be set off (no check time) before executing the slp instruction.
  - P0/P1 port interrupts must be blocked when Px\_CHAT register (0x5208/0x5218) settings are being changed. Changing the setting while interrupts are permitted may generate inadvertent P0/P1 interrupts.
  - A phenomenon may occur in which the internal signal oscillates due to the time elapsed until the signal reaches the threshold value if the input signal rising edge/drop-off time is delayed. Since input interrupts will malfunction under these conditions, the input signal rising edge/drop-off time should normally be set to 25 ns or less.

# 10.7 Port Input Interrupt

Ports P0 and P1 include input interrupt functions.

Select which of the 16 ports are to be used for interrupts based on requirements. You can also select whether interrupts are generated for either the rising edge or falling edge of input signals.

Figure 10.7.1 illustrates the port input interrupt circuit configuration.



Figure 10.7.1: Port input interrupt circuit configuration

#### Interrupt port selection

Select the port generating an interrupt using PxIE[7:0] (Px\_IMSK register).

\* **POIE[7:0]**: P0[7:0] Port Interrupt Enable Bits in the P0 Port Interrupt Mask (P0\_IMSK) Register (D[7:0]/0x5205) \* **PIIE[7:0]**: P1[7:0] Port Interrupt Enable Bits in the P1 Port Interrupt Mask (P1\_IMSK) Register (D[7:0]/0x5215)

Setting PxIE[7:0] to 1 enables interrupt generation by the corresponding port. Setting to 0 (default) disables interrupt generation.

#### Interrupt edge selection

Port input interrupts can be generated at either the rising edge or falling edge of the input signal. Select the edge used to generate interrupts using PxEDGE[7:0] (Px\_EDGE register).

- \* **P0EDGE[7:0]**: P0[7:0] Port Interrupt Edge Select Bits in the P0 Port Interrupt Edge Select (P0\_EDGE) Register (D[7:0]/0x5206)
- \* P1EDGE[7:0]: P1[7:0] Port Interrupt Edge Select Bits in the P1 Port Interrupt Edge Select (P1\_EDGE) Register (D[7:0]/0x5216)

Setting PxEDGE[7:0] to 1 generates port input interrupts at the input signal falling edge. Setting it to 0 (default) generates interrupts at the rising edge.

#### Interrupt flags

The ITC is able to accept interrupt requests for both P0 and P1 port interrupts, and the P port module contains interrupt flags PxIF[7:0] corresponding to the individual 16 ports to enable individual control of the 16 P0[7:0] and P1[7:0] port interrupts. PxIF[7:0] is set to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port interrupt request signal is also output to the ITC at the same time if the corresponding PxIE[7:0] is set to 1. Meeting the ITC and S1C17 core interrupt conditions generates an interrupt.

- \* P0IF[7:0]: P0[7:0] Port Interrupt Flags in the P0 Port Interrupt Flag (P0\_IFLG) Register (D[7:0]/0x5207)
- \* P1IF[7:0]: P1[7:0] Port Interrupt Flags in the P1 Port Interrupt Flag (P1\_IFLG) Register (D[7:0]/0x5217)

PxIF[7:0] is reset by writing as 1.

- Note: The P port module interrupt flag PxIF[7:0] must be reset within the interrupt handler routine following a port interrupt to prevent recurring interrupts.
  - To prevent generating unnecessary interrupts, reset the relevant P*x*IF[7:0] before permitting interrupts for the required port using P*x*IE[7:0] (P*x*\_IMSK register).

#### Interrupt vector

The port interrupt vector numbers and vector addresses are as shown below.

| Port | Vector number | Vector address |
|------|---------------|----------------|
| P0   | 4 (0x04)      | TTBR + 0x10    |
| P1   | 5 (0x05)      | TTBR + 0x14    |

Table 10.7.1: Port interrupt vectors

#### Other interrupt settings

The ITC allows the precedence of P0 and P1 port interrupts to be set between level 0 (default) and level 7. The PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1 to generate actual interrupts.

For specific information on interrupt processing, see "6 Interrupt Controller (ITC)."

# **10.8 Control Register Details**

|         |         | Table 10.8.1: Input/output po                  | rt control register list                          |
|---------|---------|------------------------------------------------|---------------------------------------------------|
| Address |         | Register name                                  | Function                                          |
| 0x5200  | P0_IN   | P0 Port Input Data Register                    | P0 port input data                                |
| 0x5201  | P0_OUT  | P0 Port Output Data Register                   | P0 port output data                               |
| 0x5202  | P0_OEN  | P0 Port Output Enable Register                 | P0 port output enable                             |
| 0x5203  | P0_PU   | P0 Port Pull-up Control Register               | P0 port pull-up control                           |
| 0x5204  | P0_SM   | P0 Port Schmitt Trigger Control Register       | P0 port Schmitt trigger control                   |
| 0x5205  | P0_IMSK | P0 Port Interrupt Mask Register                | P0 port interrupt mask setting                    |
| 0x5206  | P0_EDGE | P0 Port Interrupt Edge Select Register         | P0 port interrupt edge selection                  |
| 0x5207  | P0_IFLG | P0 Port Interrupt Flag Register                | P0 port interrupt occurrence status display/reset |
| 0x5208  | P0_CHAT | P0 Port Chattering Filter Control Register     | P0 port chattering filter control                 |
| 0x5209  | P0_KRST | P0 Port Key-Entry Reset Configuration Register | P0 port key entry reset setting                   |
| 0x520a  | P0_IEN  | P0 Port Input Enable Register                  | P0 port input enable                              |
| 0x5210  | P1_IN   | P1 Port Input Data Register                    | P1 port input data                                |
| 0x5211  | P1_OUT  | P1 Port Output Data Register                   | P1 port output data                               |
| 0x5212  | P1_OEN  | P1 Port Output Enable Register                 | P1 port output enable                             |
| 0x5213  | P1_PU   | P1 Port Pull-up Control Register               | P1 port pull-up control                           |
| 0x5214  | P1_SM   | P1 Port Schmitt Trigger Control Register       | P1 port Schmitt trigger control                   |
| 0x5215  | P1_IMSK | P1 Port Interrupt Mask Register                | P1 port interrupt mask setting                    |
| 0x5216  | P1_EDGE | P1 Port Interrupt Edge Select Register         | P1 port interrupt edge selection                  |
| 0x5217  | P1_IFLG | P1 Port Interrupt Flag Register                | P1 port interrupt occurrence status display/reset |
| 0x5218  | P1_CHAT | P1 Port Chattering Filter Control Register     | P1 port chattering filter control                 |
| 0x521a  | P1_IEN  | P1 Port Input Enable Register                  | P1 port input enable                              |
| 0x5220  | P2_IN   | P2 Port Input Data Register                    | P2 port input data                                |
| 0x5221  | P2_OUT  | P2 Port Output Data Register                   | P2 port output data                               |
| 0x5222  | P2_OEN  | P2 Output Enable Register                      | P2 port output enable                             |
| 0x5223  | P2_PU   | P2 Port Pull-up Control Register               | P2 port pull-up control                           |
| 0x5224  | P2_SM   | P2 Port Schmitt Trigger Control Register       | P2 port Schmitt trigger control                   |
| 0x522a  | P2_IEN  | P2 Port Input Enable Register                  | P2 port input enable                              |
| 0x5230  | P3_IN   | P3 Port Input Data Register                    | P3 port input data                                |
| 0x5231  | P3_OUT  | P3 Port Output Data Register                   | P3 port output data                               |
| 0x5232  | P3_OEN  | P3 Port Output Enable Register                 | P3 port output enable                             |
| 0x5233  | P3_PU   | P3 Port Pull-up Control Register               | P3 port pull-up control                           |
| 0x5234  | P3_SM   | P3 Port Schmitt Trigger Control Register       | P3 port Schmitt trigger control                   |
| 0x523a  | P3_IEN  | P3 Port Input Enable Register                  | P3 port input enable                              |
| 0x52a0  | P0_PMUX | P0 Port Function Select Register               | P0 port function selection                        |
| 0x52a1  | P1_PMUX | P1 Port Function Select Register               | P1 port function selection                        |
| 0x52a2  | P2_PMUX | P2 Port Function Select Register               | P2 port function selection                        |
| 0x52a3  | P3_PMUX | P3 Port Function Select Register               | P3 port function selection                        |

Table 10.8.1: Input/output port control register list

The input/output port registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

| Register name | Address  | Bit  | Name      | Function                |        | Setting    | Init. | R/W | Remarks            |
|---------------|----------|------|-----------|-------------------------|--------|------------|-------|-----|--------------------|
| P0 Port Input | 0x5200   | D7-0 | P0IN[7:0] | P0[7:0] port input data | 1 1 (H | H) 0 0 (L) | ×     | R   |                    |
| Data Register | (8 bits) |      |           |                         |        |            |       |     |                    |
| (P0_IN)       |          |      |           |                         |        |            |       |     |                    |
| P1 Port Input | 0x5210   | D7–0 | P1IN[7:0] | P1[7:0] port input data | 1 1 (H | H) 0 0 (L) | ×     | R   |                    |
| Data Register | (8 bits) |      |           |                         |        |            |       |     |                    |
| (P1_IN)       |          |      |           |                         |        |            |       |     |                    |
| P2 Port Input | 0x5220   | D7-0 | P2IN[7:0] | P2[7:0] port input data | 11(    | H) 0 0 (L) | ×     | R   |                    |
| Data Register | (8 bits) |      |           |                         |        |            |       |     |                    |
| (P2_IN)       |          |      |           |                         |        |            |       |     |                    |
| P3 Port Input | 0x5230   | D7–4 | -         | reserved                |        | -          | -     | -   | 0 when being read. |
| Data Register | (8 bits) | D3-0 | P3IN[3:0] | P3[3:0] port input data | 11(    | H) 0 0 (L) | ×     | R   |                    |
| (P3_IN)       |          |      |           |                         |        |            |       |     |                    |

#### 0x5200/0x5210/0x5220/0x5230: Px Port Input Data Registers (Px\_IN)

#### Note: The "x" in the bit names indicates the port number (0 to 3).

#### D[7:0] PxIN[7:0]: Px[7:0] Port Input Data Bits (P3 port is P3IN[3:0])

Read out the P port pin status. (Default: external pin status)

1(R): High level

0(R): Low level

PxIN[7:0] correspond directly to the Px[7:0] pins. The pin voltage level can be read out when input is permitted (PxIEN[7:0] = 1) (even when output is permitted (PxOEN[7:0] = 1)). The value read out will be 1 when the pin voltage is High and 0 when Low.

The value read out is 0 when input is prohibited (PxIEN[7:0] = 0).

Writing operations to the read-only PxIN[7:0] are disabled.

| Register name  | Address  | Bit  | Name       | Function                 |   | Set   | tin | g     | Init. | R/W | Remarks            |
|----------------|----------|------|------------|--------------------------|---|-------|-----|-------|-------|-----|--------------------|
| P0 Port Output | 0x5201   | D7-0 | P0OUT[7:0] | P0[7:0] port output data | 1 | 1 (H) | 0   | 0 (L) | 0     | R/W |                    |
| Data Register  | (8 bits) |      |            |                          |   |       |     |       |       |     |                    |
| (P0_OUT)       |          |      |            |                          |   |       |     |       |       |     |                    |
| P1 Port Output | 0x5211   | D7–0 | P1OUT[7:0] | P1[7:0] port output data | 1 | 1 (H) | 0   | 0 (L) | 0     | R/W |                    |
| Data Register  | (8 bits) |      |            |                          |   |       |     |       |       |     |                    |
| (P1_OUT)       |          |      |            |                          |   |       |     |       |       |     |                    |
| P2 Port Output | 0x5221   | D7–0 | P2OUT[7:0] | P2[7:0] port output data | 1 | 1 (H) | 0   | 0 (L) | 0     | R/W |                    |
| Data Register  | (8 bits) |      |            |                          |   |       |     |       |       |     |                    |
| (P2_OUT)       |          |      |            |                          |   |       |     |       |       |     |                    |
| P3 Port Output | 0x5231   | D7–4 | -          | reserved                 |   | -     | -   |       | -     | -   | 0 when being read. |
| Data Register  | (8 bits) | D3–0 | P3OUT[3:0] | P3[3:0] port output data | 1 | 1 (H) | 0   | 0 (L) | 0     | R/W |                    |
| (P3_OUT)       |          |      |            |                          |   |       |     |       |       |     |                    |

#### 0x5201/0x5211/0x5221/0x5231: Px Port Output Data Registers (Px\_OUT)

#### Note: The "x" in the bit names indicates the port number (0 to 3).

#### D[7:0] PxOUT[7:0]: Px[7:0] Port Output Data Bits (P3 port is P3OUT[3:0])

Set the data to be output from the port pin. 1(R/W): High level 0(R/W): Low level (default)

PxOUT [7:0] correspond directly to the Px[7:0] pins. The data written will be output unchanged from the port pins when output is permitted (PxOEN[7:0] = 1). The port pin will be High when the data bit is set to 1 and Low when set to 0.

Port data can also be written when output is prohibited (PxOEN[7:0] = 0) (the pin state is unaffected).

|               |          |      |            |                            |   | -      |    |         |       | -   |                    |
|---------------|----------|------|------------|----------------------------|---|--------|----|---------|-------|-----|--------------------|
| Register name | Address  | Bit  | Name       | Function                   |   | Sett   | in | g       | Init. | R/W | Remarks            |
| P0 Port       | 0x5202   | D7-0 | P0OEN[7:0] | P0[7:0] port output enable | 1 | Enable | 0  | Disable | 0     | R/W |                    |
| Output Enable | (8 bits) |      |            |                            |   |        |    |         |       |     |                    |
| Register      |          |      |            |                            |   |        |    |         |       |     |                    |
| (P0_OEN)      |          |      |            |                            |   |        |    |         |       |     |                    |
| P1 Port       | 0x5212   | D7–0 | P10EN[7:0] | P1[7:0] port output enable | 1 | Enable | 0  | Disable | 0     | R/W |                    |
| Output Enable | (8 bits) |      |            |                            |   |        |    |         |       |     |                    |
| Register      |          |      |            |                            |   |        |    |         |       |     |                    |
| (P1_OEN)      |          |      |            |                            |   |        |    |         |       |     |                    |
| P2 Port       | 0x5222   | D7–0 | P2OEN[7:0] | P2[7:0] port output enable | 1 | Enable | 0  | Disable | 0     | R/W |                    |
| Output Enable | (8 bits) |      |            |                            |   |        |    |         |       |     |                    |
| Register      |          |      |            |                            |   |        |    |         |       |     |                    |
| (P2_OEN)      |          |      |            |                            |   |        |    |         |       |     |                    |
| P3 Port       | 0x5232   | D7–4 | -          | reserved                   |   | _      |    |         | -     | -   | 0 when being read. |
| Output Enable | (8 bits) | D3–0 | P3OEN[3:0] | P3[3:0] port output enable | 1 | Enable | 0  | Disable | 0     | R/W |                    |
| Register      |          |      |            |                            |   |        |    |         |       |     |                    |
| (P3_OEN)      |          |      |            |                            |   |        |    |         |       |     |                    |

#### 0x5202/0x5212/0x5222/0x5232: Px Port Output Enable Registers (Px\_OEN)

Note: The "x" in the bit names indicates the port number (0 to 3).

#### D[7:0] PxOEN[7:0]: Px[7:0] Port Output Enable Bits (P3 port is P3OEN[3:0])

Set the input/output mode for the input/output port. 1(R/W): Permitted

0(R/W): Prohibited (default)

PxOEN[7:0] are output enable bits that correspond directly to Px[7:0] ports. Setting to 1 permits output and outputs the corresponding PxOUT[7:0] setting from the port pin. Output is prohibited when set to 0, and the port pin is set to high-impedance. The peripheral module determines whether output is permitted or prohibited when the port is used for peripheral modules.

Refer to Table 10.3.1 for more information on input/output states for ports, including settings other than for the PxOEN register.

| Register name    | Address  | Bit  | Name      | Function                    |   | Sett   | ing | g       | Init.  | R/W | Remarks            |
|------------------|----------|------|-----------|-----------------------------|---|--------|-----|---------|--------|-----|--------------------|
| P0 Port Pull-up  | 0x5203   | D7–0 | P0PU[7:0] | P0[7:0] port pull-up enable | 1 | Enable | 0   | Disable | 1      | R/W |                    |
| Control Register | (8 bits) |      |           |                             |   |        |     |         | (0xff) |     |                    |
| (P0_PU)          |          |      |           |                             |   |        |     |         |        |     |                    |
| P1 Port Pull-up  | 0x5213   | D7–0 | P1PU[7:0] | P1[7:0] port pull-up enable | 1 | Enable | 0   | Disable | 1      | R/W |                    |
| Control Register | (8 bits) |      |           |                             |   |        |     |         | (0xff) |     |                    |
| (P1_PU)          |          |      |           |                             |   |        |     |         |        |     |                    |
| P2 Port Pull-up  | 0x5223   | D7–0 | P2PU[7:0] | P2[7:0] port pull-up enable | 1 | Enable | 0   | Disable | 1      | R/W |                    |
| Control Register | (8 bits) |      |           |                             |   |        |     |         | (0xff) |     |                    |
| (P2_PU)          |          |      |           |                             |   |        |     |         |        |     |                    |
| P3 Port Pull-up  | 0x5233   | D7–4 | -         | reserved                    |   | _      |     |         | -      | -   | 0 when being read. |
| Control Register | (8 bits) | D3–0 | P3PU[3:0] | P3[3:0] port pull-up enable | 1 | Enable | 0   | Disable | 1      | R/W |                    |
| (P3_PU)          |          |      |           |                             |   |        |     |         | (0xff) |     |                    |

#### 0x5203/0x5213/0x5223/0x5233: Px Port Pull-up Control Registers (Px\_PU)

#### Note: The "x" in the bit names indicates the port number (0 to 3).

#### D[7:0] PxPU[7:0]: Px[7:0] Port Pull-up Enable Bits (P3 port is P3PU[3:0])

Enable or disable the pull-up resistor included in each port.

1 (R/W): Enabled (default)

0 (R/W): Disabled

PxPU[7:0] are the pull-up control bits that correspond directly to the Px[7:0] ports. Setting to 1 enables pull-up resistance and pulls up the port pin when output is prohibited (PxOEN[7:0] = 0). When setting to 0, the pin is not pulled up.

When output is permitted (PxOEN[7:0] = 1), the PxPU[7:0] setting is disabled, and the pin is not pulled up.

Input/output ports that are not used should be set with pull-up enabled.

This pull-up setting is also enabled for ports for which the peripheral module input function is selected.

A delay will occur in the waveform rising edge depending on time constants such as pull-up resistance and pin load capacitance if the port pin is switched from Low level to High level by the internal pull-up resistor. An appropriate wait time must be set for the input/output port loading. The wait time set should be a value not less than that calculated from the following equation.

Wait time =  $R_{IN} \times (C_{IN} + \text{load capacitance on board}) \times 1.6 [s]$ 

RIN: pull-up resistance maximum value

CIN: pin capacitance maximum value

|                 |          |      |           |                                    |   | 0         |      | •       |        | •   |                    |
|-----------------|----------|------|-----------|------------------------------------|---|-----------|------|---------|--------|-----|--------------------|
| Register name   | Address  | Bit  | Name      | Function                           |   | Set       | ting | 9       | Init.  | R/W | Remarks            |
| P0 Port Schmitt | 0x5204   | D7–0 | P0SM[7:0] | P0[7:0] port Schmitt trigger input | 1 | Enable    | 0    | Disable | 1      | R/W |                    |
| Trigger Control | (8 bits) |      |           | enable                             |   | (Schmitt) |      | (CMOS)  | (0xff) |     |                    |
| Register        |          |      |           |                                    |   |           |      |         |        |     |                    |
| (P0_SM)         |          |      |           |                                    |   |           |      |         |        |     |                    |
| P1 Port Schmitt | 0x5214   | D7–0 | P1SM[7:0] | P1[7:0] port Schmitt trigger input | 1 | Enable    | 0    | Disable | 1      | R/W |                    |
| Trigger Control | (8 bits) |      |           | enable                             |   | (Schmitt) |      | (CMOS)  | (0xff) |     |                    |
| Register        |          |      |           |                                    |   |           |      |         |        |     |                    |
| (P1_SM)         |          |      |           |                                    |   |           |      |         |        |     |                    |
| P2 Port Schmitt | 0x5224   | D7–0 | P2SM[7:0] | P2[7:0] port Schmitt trigger input | 1 | Enable    | 0    | Disable | 1      | R/W |                    |
| Trigger Control | (8 bits) |      |           | enable                             |   | (Schmitt) |      | (CMOS)  | (0xff) |     |                    |
| Register        |          |      |           |                                    |   |           |      |         |        |     |                    |
| (P2_SM)         |          |      |           |                                    |   |           |      |         |        |     |                    |
| P3 Port Schmitt | 0x5234   | D7–4 | -         | reserved                           |   | -         | -    |         | -      | -   | 0 when being read. |
| Trigger Control | (8 bits) | D3–0 | P3SM[3:0] | P3[3:0] port Schmitt trigger input | 1 | Enable    | 0    | Disable | 1      | R/W |                    |
| Register        |          |      |           | enable                             |   | (Schmitt) |      | (CMOS)  | (0xff) |     |                    |
| (P3_SM)         |          |      |           |                                    |   |           |      |         |        |     |                    |

#### 0x5204/0x5214/0x5224/0x5234: Px Port Schmitt Trigger Control Registers (Px\_SM)

Note: The "x" in bit names indicates the port number (0 to 3).

#### D[7:0] PxSM[7:0]: Px[7:0] Port Schmitt Trigger Input Enable Bits (P3 port is P3SM[3:0]) Enable or disable the Schmitt trigger input buffer for each port.

1(R/W): Enable (Schmitt input) (Default) 0(R/W): Disable (CMOS level)

PxSM[7:0] are Schmitt input control bits that correspond directly to the Px[7:0] ports. Setting to 1 enables the Schmitt input buffer, and setting to 0 uses the CMOS level input buffer.

#### 0x5205/5215: Px Port Interrupt Mask Registers (Px\_IMSK)

| Register name  | Address  | Bit  | Name      | Function                      | Setting |        |   |         | Init. | R/W | Remarks |
|----------------|----------|------|-----------|-------------------------------|---------|--------|---|---------|-------|-----|---------|
| P0 Port        | 0x5205   | D7–0 | P0IE[7:0] | P0[7:0] port interrupt enable | 1       | Enable | 0 | Disable | 0     | R/W |         |
| Interrupt Mask | (8 bits) |      |           |                               |         |        |   |         |       |     |         |
| Register       |          |      |           |                               |         |        |   |         |       |     |         |
| (P0_IMSK)      |          |      |           |                               |         |        |   |         |       |     |         |
| P1 Port        | 0x5215   | D7–0 | P1IE[7:0] | P1[7:0] port interrupt enable | 1       | Enable | 0 | Disable | 0     | R/W |         |
| Interrupt Mask | (8 bits) |      |           |                               |         |        |   |         |       |     |         |
| Register       |          |      |           |                               |         |        |   |         |       |     |         |
| (P1_IMSK)      |          |      |           |                               |         |        |   |         |       |     |         |

Note: The "*x*" in the bit names indicates the port number (0 or 1).

#### D[7:0] PxIE[7:0]: Px[7:0] Port Interrupt Enable Bits

Permit or prohibit P0[7:0] and P1[7:0] port interrupt.

1 (R/W): Interrupt permitted

0 (R/W): Interrupt prohibited (default)

Setting PxIE[7:0] to 1 permits the corresponding interrupt, while setting to 0 blocks interrupts. Status changes for the input pin with interrupt blocked do not affect interrupt occurrence.

#### 0x5206/5216: Px Port Interrupt Edge Select Registers (Px\_EDGE)

| Register name   | Address  | Bit  | Name        | Function                           |   | Setting          |             | Init. | R/W | Remarks |
|-----------------|----------|------|-------------|------------------------------------|---|------------------|-------------|-------|-----|---------|
| P0 Port         | 0x5206   | D7–0 | P0EDGE[7:0] | P0[7:0] port interrupt edge select | 1 | Falling edge 0 F | Rising edge | 0     | R/W |         |
| Interrupt Edge  | (8 bits) |      |             |                                    |   |                  |             |       |     |         |
| Select Register |          |      |             |                                    |   |                  |             |       |     |         |
| (P0_EDGE)       |          |      |             |                                    |   |                  |             |       |     |         |
| P1 Port         | 0x5216   | D7–0 | P1EDGE[7:0] | P1[7:0] port interrupt edge select | 1 | Falling edge 0   | Rising edge | 0     | R/W |         |
| Interrupt Edge  | (8 bits) |      |             |                                    |   |                  |             |       |     |         |
| Select Register |          |      |             |                                    |   |                  |             |       |     |         |
| (P1_EDGE)       |          |      |             |                                    |   |                  |             |       |     |         |

Note: The "*x*" in the bit names indicates the port number (0 or 1).

#### D[7:0] PxEDGE[7:0]: Px[7:0] Port Interrupt Edge Select Bits

Select the input signal edge for generating P0[7:0] and P1[7:0] port interrupts.

1 (R/W): Falling edge

0 (R/W): Rising edge (default)

Port interrupts are generated at the input signal falling edge if PxEDGE[7:0] are set to 1 and at the rising edge if set to 0.

| Register name                                      | Address                   | Bit  | Name      | Function                    | Set                               | ting | g                                     | Init. | R/W | Remarks             |
|----------------------------------------------------|---------------------------|------|-----------|-----------------------------|-----------------------------------|------|---------------------------------------|-------|-----|---------------------|
| P0 Port<br>Interrupt Flag<br>Register<br>(P0_IFLG) | <b>0x5207</b><br>(8 bits) | D7-0 | P0IF[7:0] | P0[7:0] port interrupt flag | Cause of<br>interrupt<br>occurred | -    | Cause of<br>interrupt not<br>occurred |       | R/W | Reset by writing 1. |
| P1 Port<br>Interrupt Flag<br>Register<br>(P1_IFLG) | 0x5217<br>(8 bits)        | D7–0 | P1IF[7:0] | P1[7:0] port interrupt flag | Cause of<br>interrupt<br>occurred |      | Cause of<br>interrupt not<br>occurred |       | R/W | Reset by writing 1. |

Note: The "*x*" in the bit names indicates the port number (0 or 1).

#### D[7:0] PxIF[7:0]: Px[7:0] Port Interrupt Flags

These are interrupt flags indicating the interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

PxIF[7:0] are interrupt flags corresponding to the individual 16 ports of P0[7:0] and P1[7:0]. PxIF[7:0] is set to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port interrupt request signal is also output to the ITC at the same time if the corresponding PxIE[7:0] ( $Px_IMSK$  register) is set to 1. This interrupt request signal causes the P0/P1 port interrupt flag inside the ITC to be set to 1. Meeting the ITC and S1C17 core interrupt conditions generates an interrupt. PxIF[7:0] is reset by writing as 1.

Note: • The P port module interrupt flag PxIF[7:0] must be reset within the interrupt handler routine following a port interrupt to prevent recurring interrupts.

# • To prevent generating unnecessary interrupts, reset the relevant PxIF[7:0] before permitting interrupts for the required port using PxIE[7:0] (Px\_IMSK register).

- \* POIE[7:0]: P0[7:0] Port Interrupt Enable Bits in the P0 Port Interrupt Mask (P0\_IMSK) Register (D[7:0]/0x5205)
- \* P1IE[7:0]: P1[7:0] Port Interrupt Enable Bits in the P1 Port Interrupt Mask (P1\_IMSK) Register (D[7:0]/0x5215)

| Register name  | Address  | Bit  | Name       | Function                              | Set        | ting        | Init. | R/W | Remarks            |
|----------------|----------|------|------------|---------------------------------------|------------|-------------|-------|-----|--------------------|
| P0 Port        | 0x5208   | D7   | -          | reserved                              | -          | _           | -     | -   | 0 when being read. |
| Chattering     | (8 bits) | D6-4 | P0CF2[2:0] | P0[7:4] chattering filter time select | P0CF2[2:0] | Filter time | 0     | R/W | -                  |
| Filter Control |          |      |            |                                       | 0x7        | 16384/fpclk | 0x0   | R/W |                    |
| Register       |          |      |            |                                       | 0x6        | 8192/fpclk  |       |     |                    |
| (P0_CHAT)      |          |      |            |                                       | 0x5        | 4096/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x4        | 2048/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x3        | 1024/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x2        | 512/fpclk   |       |     |                    |
|                |          |      |            |                                       | 0x1        | 256/fpclk   |       |     |                    |
|                |          |      |            |                                       | 0x0        | None        |       |     |                    |
|                |          | D3   | -          | reserved                              |            | -           | -     | -   | 0 when being read. |
|                |          | D2-0 | P0CF1[2:0] | P0[3:0] chattering filter time select | P0CF1[2:0] | Filter time | 0x0   | R/W |                    |
|                |          |      |            |                                       | 0x7        | 16384/fpclk |       |     |                    |
|                |          |      |            |                                       | 0x6        | 8192/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x5        | 4096/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x4        | 2048/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x3        | 1024/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x2        | 512/fpclk   |       |     |                    |
|                |          |      |            |                                       | 0x1        | 256/fpclk   |       |     |                    |
|                |          |      |            |                                       | 0x0        | None        |       |     |                    |
| P1 Port        | 0x5218   | D7   | -          | reserved                              | -          | -           | -     | -   | 0 when being read. |
| Chattering     | (8 bits) | D6–4 | P1CF2[2:0] | P1[7:4] chattering filter time select | P1CF2[2:0] | Filter time | 0     | R/W |                    |
| Filter Control |          |      |            |                                       | 0x7        | 16384/fpclk | 0x0   | R/W |                    |
| Register       |          |      |            |                                       | 0x6        | 8192/fpclk  |       |     |                    |
| (P1_CHAT)      |          |      |            |                                       | 0x5        | 4096/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x4        | 2048/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x3        | 1024/fpclk  |       |     |                    |
|                |          |      |            |                                       | 0x2        | 512/fpclk   |       |     |                    |
|                |          |      |            |                                       | 0x1        | 256/fpclk   |       |     |                    |
|                |          |      |            |                                       | 0x0        | None        |       |     |                    |
|                |          | D3   | -          | reserved                              | -          | -           | -     | -   | 0 when being read. |
|                |          | D2–0 | P1CF1[2:0] | P1[3:0] chattering filter time select | P1CF1[2:0] | Filter time | 0x0   | R/W |                    |
|                |          |      |            |                                       | 0x7        | 16384/fpclk |       |     |                    |
|                |          |      |            |                                       | 0x6        | 8192/fpclk  |       |     |                    |
|                |          |      | [          |                                       | 0x5        | 4096/fpcLk  |       |     |                    |
|                |          |      |            |                                       | 0x4        | 2048/fpcLk  |       |     |                    |
|                |          |      | [          |                                       | 0x3        | 1024/fpcLk  |       |     |                    |
|                |          |      |            |                                       | 0x2        | 512/fpcLk   |       |     |                    |
|                |          |      |            |                                       | 0x1        | 256/fpclk   |       |     |                    |
|                |          |      |            | 1                                     | 0x0        | None        |       |     |                    |

#### 0x5208/0x5218: Px Port Chattering Filter Control Register (Px\_CHAT)

Note: The "x" in the bit names indicates the port number (0 or 1).

#### D7 Reserved

#### D[6:4] PxCF2[2:0]: Px[7:4] Chattering Filter Time Select Bits

Set the chattering filter circuit included in the P0[7:4] or P1[7:4] ports.

#### D3 Reserved

#### D[2:0] PxCF1[2:0]: Px[3:0] Chattering Filter Time Select Bits

Set the chattering filter circuit included in the P0[3:0] or P1[3:0]ports.

The P0 and P1 port include a chattering filter circuit for key entry, which you can select to use or not use (and for which you can select a check time if used) individually for the four Px[3:0] and Px[7:4] ports using PxCF1[2:0], PxCF2[2:0].

| •                      | •                   |
|------------------------|---------------------|
| PxCF1[2:0], PxCF2[2:0] | Check time *        |
| 0x7                    | 16384/fpclк (8 ms)  |
| 0x6                    | 8192/fpclk (4 ms)   |
| 0x5                    | 4096/fpclk (2 ms)   |
| 0x4                    | 2048/fpclk (1 ms)   |
| 0x3                    | 1024/fpclk (512 µs) |
| 0x2                    | 512/fpclk (256 µs)  |
| 0x1                    | 256/fpclk (128 µs)  |
| 0x0                    | No check time (Off) |

#### Table 10.8.2: Chattering filter function settings

(Default: 0x0, \*when OSC3 = 2 MHz and PCLK = OSC3)

- Note: The chattering filter check time refers to the maximum pulse width that can be filtered. Generating an input interrupt requires a minimum input time of the check time and a maximum input time of twice the check time.
  - Input interrupts will not be accepted for a transition into SLEEP mode with the chattering filter left on. The chattering filter should be set off (no check time) before executing the slp instruction.
  - P0/P1 port interrupts must be blocked when Px\_CHAT register settings are being changed. Changing the setting while interrupts are permitted may generate inadvertent P0/P1 interrupts.
  - A phenomenon may occur in which the internal signal oscillates due to the time elapsed until the signal reaches the threshold value if the input signal rising edge/drop-off time is delayed. Since input interrupts will malfunction under these conditions, the input signal rising edge/drop-off time should normally be set to 25 ns or less.

#### 0x5209: P0 Port Key-Entry Reset Configuration Register (P0\_KRST)

| Register name | Address  | Bit  | Name        | Function                | Set         | Init.         | R/W | Remarks            |  |
|---------------|----------|------|-------------|-------------------------|-------------|---------------|-----|--------------------|--|
| P0 Port Key-  | 0x5209   | D7–2 | -           | reserved                | -           | -             | -   | 0 when being read. |  |
| Entry Reset   | (8 bits) | D1–0 | P0KRST[1:0] | P0 port key-entry reset | P0KRST[1:0] | Configuration | 0x0 | R/W                |  |
| Configuration |          |      |             | configuration           | 0x3         | P0[3:0] = 0   |     |                    |  |
| Register      |          |      |             |                         | 0x2         | P0[2:0] = 0   |     |                    |  |
| (P0_KRST)     |          |      |             |                         | 0x1         | P0[1:0] = 0   |     |                    |  |
|               |          |      |             |                         | 0x0         | Disable       |     |                    |  |

#### D[7:2] Reserved

#### D[1:0] P0KRST[1:0]: P0 Port Key-Entry Reset Configuration Bits

Select the port combination used for P0 port key entry resetting.

| Table 10.8.3: P0 port key | entry input reset settings |
|---------------------------|----------------------------|
|---------------------------|----------------------------|

| P0KRST[1:0] | Ports used         |
|-------------|--------------------|
| 0x3         | P00, P01, P02, P03 |
| 0x2         | P00, P01, P02      |
| 0x1         | P00, P01           |
| 0x0         | Not used           |
|             |                    |

(Default: 0x0)

The key entry reset function performs an initial reset by inputting Low level simultaneously from externally to the port selected here.

For example, if P0KRST[1:0] is set to 0x3, an initial reset is performed when the four ports P00 to P03 are simultaneously set to Low level.

Set P0KRST[1:0] to 0x0 when this reset function is not used.

- Note: Make sure the specified ports are not simultaneously switched to Low during normal operations when using the P0 port key-entry reset function.
  - The P0 port key entry reset function is disabled on initial resetting and cannot be used for resetting at power-on.
  - The P0 port key-entry reset function cannot be used in SLEEP state.

| Register name   | Address  | Bit  | Name       | Function                  |   | Sett   | ting | g       | Init. | R/W | Remarks            |
|-----------------|----------|------|------------|---------------------------|---|--------|------|---------|-------|-----|--------------------|
| P0 Port Input   | 0x520a   | D7–0 | P0IEN[7:0] | P0[7:0] port input enable | 1 | Enable | 0    | Disable | 0xff  | R/W |                    |
| Enable Register | (8 bits) |      |            |                           |   |        |      |         |       |     |                    |
| (P0_IEN)        |          |      |            |                           |   |        |      |         |       |     |                    |
| P1 Port Input   | 0x521a   | D7–0 | P1IEN[7:0] | P1[7:0] port input enable | 1 | Enable | 0    | Disable | 0xff  | R/W |                    |
| Enable Register | (8 bits) |      |            |                           |   |        |      |         |       |     |                    |
| (P1_IEN)        |          |      |            |                           |   |        |      |         |       |     |                    |
| P2 Port Input   | 0x522a   | D7–0 | P2IEN[7:0] | P2[7:0] port input enable | 1 | Enable | 0    | Disable | 0xff  | R/W |                    |
| Enable Register | (8 bits) |      |            |                           |   |        |      |         |       |     |                    |
| (P2_IEN)        |          |      |            |                           |   |        |      |         |       |     |                    |
| P3 Port Input   | 0x523a   | D7–4 | -          | reserved                  |   |        | -    |         | -     | -   | 0 when being read. |
| Enable Register | (8 bits) | D3–0 | P3IEN[3:0] | P3[3:0] port input enable | 1 | Enable | 0    | Disable | 0xff  | R/W |                    |
| (P3_IEN)        |          |      |            |                           |   |        |      |         |       |     |                    |

#### 0x520a/0x521a/0x522a/0x523a: Px Port Input Enable Registers (Px\_IEN)

#### Note: The "x" in the bit names indicates the port number (0 to 3).

#### D[7:0] PxIEN[7:0]: Px[7:0] Port Input Enable Bits (P3 port is P3IEN[3:0])

Permits or prevents port input. 1(R/W): Permit (Default) 0(R/W): Prohibit

PxIEN[7:0] are input enable bits that correspond directly to the Px[7:0] ports. Setting to 1 permits input and reads the corresponding port pin input or output signal level from the  $Px_IN$  register. Setting to 0 prohibits input.

Refer to Table 10.3.1 for more information on port input/output states, including settings other than for the PxIEN register.

| Register name   | Address  | Bit  | Name   | Function                 | Setting |        | Init.              | R/W | Remarks            |     |  |
|-----------------|----------|------|--------|--------------------------|---------|--------|--------------------|-----|--------------------|-----|--|
| P0 Port         | 0x52a0   | D7–6 | -      | reserved                 | -       |        | -                  | -   | 0 when being read. |     |  |
| Function Select | (8 bits) | D5   | P05MUX | P05 port function select | 1       | TOUTN4 | 0                  | P05 | 0                  | R/W |  |
| Register        |          | D4   | P04MUX | P04 port function select | 1       | TOUT4  | 0                  | P04 | 0                  | R/W |  |
| (P0_PMUX)       |          | D3   | P03MUX | P03 port function select | 1       | REMO   | 0                  | P03 | 0                  | R/W |  |
|                 | Í        | D2   | P02MUX | P02 port function select | 1       | REMI   | 0                  | P02 | 0                  | R/W |  |
|                 |          | D1–0 | -      | reserved                 | 0 when  |        | 0 when being read. |     |                    |     |  |

#### 0x52a0: P0 Port Function Select Register (P0\_PMUX)

The P02 to P05 input/output port pins are shared with the peripheral module pins. This register is used to select how the pins are used.

#### D[7:6] Reserved

- D5 P05MUX: P05 Port Function Select Bit 1 (R/W): TOUTN4 (T16E Ch.1) 0 (R/W): P05 port (default)
- D4 P04MUX: P04 Port Function Select Bit 1 (R/W): TOUT4 (T16E Ch.1) 0 (R/W): P04 port (default)
- D3 P03MUX: P03 Port Function Select Bit 1 (R/W): REMO (REMC) 0 (R/W): P03 port (default)
- D2 P02MUX: P02 Port Function Select Bit 1 (R/W): REMI (REMC) 0 (R/W): P02 port (default)
- D[1:0] Reserved

| Register name   | Address  | Bit | Name   | Function                 | Setting |        |             | Init. | R/W | Remarks |
|-----------------|----------|-----|--------|--------------------------|---------|--------|-------------|-------|-----|---------|
| P1 Port         | 0x52a1   | D7  | P17MUX | P17 port function select | 1       | #SPISS | 0 P17       | 0     | R/W |         |
| Function Select | (8 bits) | D6  | P16MUX | P16 port function select | 1       | TOUT5  | 0 P16/EXCL0 | 0     | R/W |         |
| Register        | [        | D5  | P15MUX | P15 port function select | 1       | SCL    | 0 P15       | 0     | R/W |         |
| (P1_PMUX)       | [        | D4  | P14MUX | P14 port function select | 1       | SDA    | 0 P14       | 0     | R/W |         |
|                 | ſ        | D3  | P13MUX | P13 port function select | 1       | FOUT1  | 0 P13       | 0     | R/W |         |
|                 | ſ        | D2  | P12MUX | P12 port function select | 1       | SCLK1  | 0 P12       | 0     | R/W |         |
|                 | [        | D1  | P11MUX | P11 port function select | 1       | SOUT1  | 0 P11       | 0     | R/W |         |
|                 |          | D0  | P10MUX | P10 port function select | 1       | SIN1   | 0 P10       | 0     | R/W |         |

#### 0x52a1: P1 Port Function Select Register (P1\_PMUX)

The P10 to P17 input/output port pins are shared with the peripheral module pins. This register is used to select how the pins are used.

| D7       | P17MUX: P17 Port Function Select Bit<br>1 (R/W): #SPISS (SPI)<br>0 (R/W): P17 port (default)               |
|----------|------------------------------------------------------------------------------------------------------------|
| D6       | P16MUX: P16 Port Function Select Bit<br>1 (R/W): TOUT5 (T8OSC1)<br>0 (R/W): P16 port/EXCL0 (T16) (default) |
| D5       | P15MUX: P15 Port Function Select Bit<br>1 (R/W): SCL (I2C)<br>0 (R/W): P15 port (default)                  |
| D4       | P14MUX: P14 Port Function Select Bit<br>1 (R/W): SDA (I2C)<br>0 (R/W): P14 port (default)                  |
| D3       | P13MUX: P13 Port Function Select Bit<br>1 (R/W): FOUT1 (OSC)<br>0 (R/W): P13 port (default)                |
|          |                                                                                                            |
| D2       | P12MUX: P12 Port Function Select Bit<br>1 (R/W): SCLK1 (UART Ch.1)<br>0 (R/W): P12 port (default)          |
| D2<br>D1 | 1 (R/W): SCLK1 (UART Ch.1)                                                                                 |

| Register name   | Address  | Bit | Name   | Function                 |   | Setting |   | Init. | R/W | Remarks |  |
|-----------------|----------|-----|--------|--------------------------|---|---------|---|-------|-----|---------|--|
| P2 Port         | 0x52a2   | D7  | P27MUX | P27 port function select | 1 | TOUTN3  | 0 | P27   | 0   | R/W     |  |
| Function Select | (8 bits) | D6  | P26MUX | P26 port function select | 1 | TOUT3   | 0 | P26   | 0   | R/W     |  |
| Register        |          | D5  | P25MUX | P25 port function select | 1 | SCLK0   | 0 | P25   | 0   | R/W     |  |
| (P2_PMUX)       |          | D4  | P24MUX | P24 port function select | 1 | SOUT0   | 0 | P24   | 0   | R/W     |  |
|                 |          | D3  | P23MUX | P23 port function select | 1 | SIN0    | 0 | P23   | 0   | R/W     |  |
|                 |          | D2  | P22MUX | P22 port function select | 1 | SPICLK  | 0 | P22   | 0   | R/W     |  |
|                 |          | D1  | P21MUX | P21 port function select | 1 | SDO     | 0 | P21   | 0   | R/W     |  |
|                 |          | D0  | P20MUX | P20 port function select | 1 | SDI     | 0 | P20   | 0   | R/W     |  |

#### 0x52a2: P2 Port Function Select Register (P2 PMUX)

The P20 to P27 input/output port pins are shared with the peripheral module pins. This register is used to select how the pins are used.

| D7 | P27MUX: P27 Port Function Select Bit<br>1 (R/W): TOUTN3 (T16E Ch.0)<br>0 (R/W): P27 port (default) |
|----|----------------------------------------------------------------------------------------------------|
| D6 | P26MUX: P26 Port Function Select Bit<br>1 (R/W): TOUT3 (T16E Ch.0)<br>0 (R/W): P26 port (default)  |
| D5 | P25MUX: P25 Port Function Select Bit<br>1 (R/W): SCLK0 (UART Ch.0)<br>0 (R/W): P25 port (default)  |
| D4 | P24MUX: P24 Port Function Select Bit<br>1 (R/W): SOUT0 (UART Ch.0)<br>0 (R/W): P24 port (default)  |
| D3 | <b>P23MUX: P23 Port Function Select Bit</b><br>1 (R/W): SIN0 (UART Ch.0)                           |

- 0 (R/W): P23 port (default)
- D2 P22MUX: P22 Port Function Select Bit 1 (R/W): SPICLK (SPI) 0 (R/W): P22 port (default)
- P21MUX: P21 Port Function Select Bit D1 1 (R/W): SDO (SPI) 0 (R/W): P21 port (default)
- D0 P20MUX: P20 Port Function Select Bit 1 (R/W): SDI (SPI) 0 (R/W): P20 port (default)

| Register name   | Address  | Bit  | Name   | Function                 |   | Sett  | ting | 9    | Init. | R/W | Remarks            |
|-----------------|----------|------|--------|--------------------------|---|-------|------|------|-------|-----|--------------------|
| P3 Port         | 0x52a3   | D7–4 | -      | reserved                 |   | _     | -    |      | -     | -   | 0 when being read. |
| Function Select | (8 bits) | D3   | P33MUX | P33 port function select | 1 | P33   | 0    | DSIO | 0     | R/W |                    |
| Register        |          | D2   | P32MUX | P32 port function select | 1 | P32   | 0    | DST2 | 0     | R/W |                    |
| (P3_PMUX)       |          | D1   | P31MUX | P31 port function select | 1 | P31   | 0    | DCLK | 0     | R/W |                    |
|                 |          | D0   | P30MUX | P30 port function select | 1 | FOUTH | 0    | P30  | 0     | R/W |                    |

#### 0x52a3: P3 Port Function Select Register (P3 PMUX)

The P30 to P33 input/output port pins are shared with the peripheral module pins. This register is used to select how the pins are used.

#### D[7:4] Reserved

- D3 P33MUX: P33 Port Function Select Bit 1 (R/W): P33 port 0 (R/W): DSIO (DBG) (default)
- D2 P32MUX: P32 Port Function Select Bit 1 (R/W): P32 port 0 (R/W): DST2 (DBG) (default)
- D1 P31MUX: P31 Port Function Select Bit 1 (R/W): P31 port 0 (R/W): DCLK (DBG) (default)
- D0 P30MUX: P30 Port Function Select Bit 1 (R/W): FOUTH (OSC) 0 (R/W): P30 port (default)

# **10.9 Precautions**

#### **Operation clock**

• The PCLK clock must be fed from the clock generator to access the input/output port. The prescaler output clock is also needed to operate the P0 and P1 port chattering filter. Switch on the prescaler when using this function.

#### Pull-up

• A delay will occur in the waveform rising edge depending on time constants such as pull-up resistance and pin load capacitance if the port pin is switched from Low level to High level by the internal pull-up resistor. An appropriate wait time must be set for the input/output port loading. The wait time set should be a value not less than that calculated from the following equation.

Wait time =  $R_{IN} \times (C_{IN} + load capacitance on board) \times 1.6 [s]$ 

RIN: pull-up resistance maximum value

CIN: pin capacitance maximum value

• Input/output ports that are not used should be set with pull-up resistance enabled.

#### P0 and P1 port interrupts

- Reset the corresponding interrupt flags P0IF[7:0] (0x5207) and P1IF[7:0] (0x5217) within the interrupt handler routine following a port interrupt to prevent recurring interrupts.
- To prevent generating unnecessary interrupts, reset the corresponding interrupt flag—P0IF[7:0] (0x5207) or P1IF[7:0] (0x5217)—before permitting interrupts for the required port with the P0\_IMSK register (0x5205) or P1\_IMSK register (0x5215).

#### P0/P1 Port chattering filter circuit

- Input interrupts will not be accepted for a transition into SLEEP mode with the chattering filter left on. The chattering filter should be set off (no check time) before executing the slp instruction.
- P0/P1 port interrupts must be blocked when Px\_CHAT register (0x5208/0x5218) settings are being changed. Changing the setting while interrupts are permitted may generate inadvertent P0/P1 interrupts.
- The chattering filter check time refers to the maximum pulse width that can be filtered. Generating an input interrupt requires a minimum input time of the check time and a maximum input time of twice the check time.
- A phenomenon may occur in which the internal signal oscillates due to the time elapsed until the signal reaches the threshold value if the input signal rising edge/drop-off time is delayed. Since input interrupts will malfunction under these conditions, the input signal rising edge/drop-off time should normally be set to 25 ns or less.

#### P0 port key-entry reset

- Make sure the specified ports are not simultaneously switched to Low during normal operations when using the P0 port key-entry reset function.
- The P0 port key entry reset function is disabled on initial resetting and cannot be used for resetting at poweron.
- The P0 port key-entry reset function cannot be used in SLEEP state.

# **11 16-bit Timer (T16)**

# 11.1 16-bit Timer Overview

The S1C17702 incorporates a 3-channel 16-bit timer (T16).

The 16-bit timer consists of a 16-bit presettable down counter and a 16-bit reload data register holding the preset values. The timer counts down from the initial value set in the reload data register and outputs an underflow signal when the counter underflows. The underflow signal is used to generate an interrupt and an internal serial interface clock. The underflow cycle can be programmed by selecting the prescaler clock and reload data, enabling the application program to obtain time intervals and serial transfer speeds as required.

The timer also combines an event counter function via the input/output port pins and the external input signal pulse width measurement function.

Figure 11.1.1 illustrates the 16-bit timer configuration.



Figure 11.1.1: 16-bit timer configuration (1-channel)

Note: The 3-channel 16-bit timer module has the same functions except for the control register address. The description in this section applies to all channels of the 16-bit timer. The "x" in the register name refers to the channel number (0 to 2). The register addresses are referenced as "Ch.0," "Ch.1," and "Ch.2."

Example: T16\_CTLx register (0x4226/0x4246/0x4266)

Ch.0: T16\_CTL0 register (0x4226) Ch.1: T16\_CTL1 register (0x4246)

Ch.2: T16\_CTL2 register (0x4266)

# 11.2 16-bit Timer Operating Modes

The 16-bit timer has the following three operating modes:

- 1. Internal clock mode (Normal timer counting internal clock)
- 2. External clock mode (Functions as event counter)
- 3. Pulse width measurement mode (Counts external input pulse width using internal clock)

The operating mode is selected using CKSL[1:0] (D[9:8]/T16\_CTLx register).

\* CKSL[1:0]: Input Clock and Pulse Width Count Mode Select Bits in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D[9:8]/0x4226/0x4246/0x4266)

| CKSL[1:0] | Operating mode               |
|-----------|------------------------------|
| 0x3       | Reserved                     |
| 0x2       | Pulse width measurement mode |
| 0x1       | External clock mode          |
| 0x0       | Internal clock mode          |
|           |                              |

| Table | 11.2.1: | Operating | mode | selection  |
|-------|---------|-----------|------|------------|
| iaoio |         | oporating | mouo | 0010011011 |

(Default: 0x0)

### 11.2.1 Internal Clock Mode

Internal clock mode uses the prescaler output clock as the count clock.

The timer counts down from the initial value set in the reload data register and outputs an underflow signal when the counter underflows. The underflow signal is used to generate an interrupt and an internal serial interface clock. The time until underflow occurs can be finely programmed by selecting the prescaler clock and initial counter value, making it useful for serial transfer clock generation and sporadic time measurement.

#### **Count clock selection**

The count clock is selected by the DF[3:0] (D[3:0]/T16\_CLKx register) from the 15 types generated by the prescaler dividing the PCLK clock into 1/1 to 1/16 K divisions.

\* **DF[3:0]**: Timer Input Clock Select Bits in the 16-bit Timer Ch.x Input Clock Select (T16\_CLKx) Register (D[3:0]/0x4220/0x4240/0x4260)

| DF[3:0] | Prescaler output clock | DF[3:0] | Prescaler output clock |
|---------|------------------------|---------|------------------------|
| Oxf     | Reserved               | 0x7     | PCLK-1/128             |
| 0xe     | PCLK-1/16384           | 0x6     | PCLK-1/64              |
| 0xd     | PCLK-1/8192            | 0x5     | PCLK-1/32              |
| Охс     | PCLK-1/4096            | 0x4     | PCLK-1/16              |
| 0xb     | PCLK-1/2048            | 0x3     | PCLK-1/8               |
| 0xa     | PCLK-1/1024            | 0x2     | PCLK-1/4               |
| 0x9     | PCLK-1/512             | 0x1     | PCLK-1/2               |
| 0x8     | PCLK-1/256             | 0x0     | PCLK-1/1               |

#### Table 11.2.1.1: Count clock selection

(Default: 0x0)

Note: • The prescaler must run before operating the 16-bit timer in internal clock mode.

• Make sure the 16-bit timer count is halted before changing count clock settings.

For detailed information on the prescaler control, see "9 Prescaler (PSC)."

### 11.2.2 External Clock Mode

External clock mode uses the clock and pulses input via the input/output port as a count clock. These inputs can also be used as an event counter. Timer operations other than the input clock are the same as for internal clock mode.

#### External clock input port

The following input ports are used for external clock or pulse input.

| Timer channel | Input signal name | Input/output port pin |
|---------------|-------------------|-----------------------|
| Ch.0          | EXCL0             | P16                   |
| Ch.1          | EXCL1             | P07                   |
| Ch.2          | EXCL2             | P06                   |

Confirm that the input/output ports used for external clock or pulse input are set to input mode (the default setting). No pin function selection is needed. While the input/output ports function as general purpose inputs, the input signal is also sent to the 16-bit timer.

The P16, P07, and P06 ports used by 16-bit timer Ch.1 and Ch.2 incorporate chattering filter circuits and can also be used as EXCL*x* inputs. For instructions on controlling chattering filter circuits, see "10.7 P0/P1 Port Chattering Filter Function."

#### Signal polarity selection

CKACTV (D10/T16\_CTLx register) is used in this mode to select the falling edge or rising edge of the input signal for counting.

\* CKACTV: External Clock Active Level Select Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D10/0x4226/0x4246/0x4266)

Counting down uses the rising edge when CKACTV is 1 (default) and uses the falling edge when set to 0.



The 16-bit timer does not use the prescaler in this mode. If no other peripheral modules use the prescaler clock, the prescaler can be stopped to reduce current consumption. (The prescaler clock is used for P0/P1 port chattering filtering.)

### 11.2.3 Pulse Width Measurement Mode

In pulse width measurement mode, when pulses with the specified polarity are input from the external clock port, the internal clock is fed only while the signal is active, enabling counting. This enables interrupt generation and input pulse width measurements for pulse inputs of the specified width or greater.

#### **Pulse input port**

The Input/output port used for external pulse input is the same as for external clock mode (see Table 11.2.2.1). Input pulses using the input/output port corresponding to the timer channel in input mode.

#### **Count clock selection**

Counting uses the prescaler output clock selected by DF[3:0] (D[3:0]/T16\_CLKx register) in the same way as for internal clock mode. Select the clock to suit approximate input pulse widths and counting accuracy.

#### Signal polarity selection

CKACTV (D10/T16\_CTLx register) is used to select the active level for the pulses counted. The High period is measured when CKACTV is 1 (default) and the Low period is measured when CKACTV is set to 0.



Figure 11.2.3.1: Pulse width measurement mode count operation

# 11.3 Count Mode

The 16-bit timer features two count modes: Repeat mode and One-shot mode. These modes are selected using the TRMD (D4/T16\_CTLx register).

\* TRMD: Count Mode Select Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D4/0x4226/0x4246/0x4266)

#### Repeat mode (TRMD = 0, default)

Setting TRMD to 0 sets the 16-bit timer to Repeat mode.

In this mode, once the count starts, the 16-bit timer continues running until stopped by the application program. If the counter underflows, the timer presets the reload data register value into the counter and continues the count. Thus, the timer periodically outputs an underflow pulse. The 16-bit timer should be set to this mode to generate periodic interrupts at desired intervals or to generate a serial transfer clock.

#### One-shot mode (TRMD = 1)

Setting TRMD to 1 sets the 16-bit timer to One-shot mode.

In this mode, the 16-bit timer stops automatically as soon as the counter underflows. This means only one interrupt can be generated after the timer starts. Note that the timer presets the reload data register value to the counter, then stops after an underflow has occurred. The 16-bit timer should be set to this mode to set a specific wait time or for pulse width measurement.

# 11.4 16-bit Timer Reload Register and Underflow Cycle

The reload data register T16\_TRx (0x4222/0x4242/0x4262) is used to set the initial value for the down counter. The initial counter value set in the reload data register is preset to the down counter if the 16-bit timer is reset or the counter underflows. If the 16-bit timer is started after resetting, the timer counts down from the reload value (initial value). This means this reload value and the input clock frequency determine the time elapsed from the point at which the timer starts until the underflow occurs (or between underflows). The time determined is used to obtain the specified wait time, the intervals between periodic interrupts, and the programmable serial interface transfer clock.



The underflow cycle can be calculated as follows:

Underflow interval =  $\frac{\text{TR} + 1}{\text{clk}_{in}}$  [s] Underflow cycle =  $\frac{\text{clk}_{in}}{\text{TR} + 1}$  [Hz] clk\_in: Count clock (prescaler output clock) frequency [Hz] TR: Reload data (0 to 65535)

# 11.5 16-bit Timer Reset

The 16-bit timer is reset by writing 1 to PRESER (D1/T16\_CTLx register). The reload data is preset and the counter is initialized.

\* PRESER: Timer Reset Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D1/0x4226/0x4246/0x4266)

# 11.6 16-bit Timer RUN/STOP Control

Make the following settings before starting the 16-bit timer.

- (1) Select the operating mode (Internal clock, External clock, or Pulse width measurement). See Section 11.2.
- (2) For Internal clock or Pulse width measurement mode, select the count clock (prescaler output clock). See Section 11.2.1.
- (3) Set the count mode (One-shot or Repeat). See Section 11.3.
- (4) Calculate the initial counter value and set the reload data register. See Section 11.4.
- (5) Reset the timer and preset the counter to the initial value. See Section 11.5.
- (6) If using timer interrupts, set the interrupt level and allow interrupts for the relevant timer channel. See Section 11.8.

To start the 16-bit timer, program 1 to PRUN (D0/T16 CTLx register).

\* PRUN: Timer Run/Stop Control Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D0/0x4226/0x4246/0x4266)

The timer starts counting down from the initial value or from the current counter value if no initial value was preset. When the counter underflows, the timer outputs an underflow pulse and presets the counter to the initial value. An interrupt request is sent simultaneously to the interrupt controller (ITC).

If One-shot mode is set, the timer stops the count.

If Repeat mode is set, the timer continues to count from the reloaded initial value.

Program 0 to PRUN to stop the 16-bit timer via the application program. The counter stops counting and retains the current counter value until either the timer is reset or restarted. To restart the count from the initial value, the timer should be reset before writing 1 to PRUN.



Figure 11.6.1: Count operation

In Pulse width measurement mode, the timer counts only while PRUN is set to 1 and the external input signal is at the specified active level. When the external input signal becomes inactive, the 16-bit timer stops counting and retains the counter value until the next active level input. (See Figure 11.2.3.1.)

# 11.7 16-bit Timer Output Signal

The 16-bit timer outputs underflow pulses when the counter underflows.

These pulses are used for timer interrupt requests.

These pulses are also used to generate the internal serial interface serial transfer clock.

The clock generated is sent to the internal serial interface, as shown below.

16-bit timer Ch.1 output clock  $\rightarrow$  SPI

16-bit timer Ch.2 output clock  $\rightarrow$  I<sup>2</sup>C

Use the following equations to calculate the reload data register value for obtaining the desired transfer rate:

SPI 
$$TR = \frac{\text{clk}_{\text{in}}}{\text{bps} \times 2} - 1$$
$$I^2C \qquad TR = \frac{\text{clk}_{\text{in}}}{\text{bps} \times 4} - 1$$

clk\_in: Count clock (prescaler output clock) frequency [Hz]

TR: Reload data (0 to 65535)

bps: Transfer rate (bit/s)

# 11.8 16-bit Timer Interrupts

The 16-bit timer outputs interrupt requests to the interrupt controller (ITC) when the counter underflows.

#### **Underflow interrupt**

Generated by a counter underflow, this interrupt request sets the interrupt flag T16IF (D0/T16\_INTx register) to 1 inside the T16 module provided for each channel.

\* T16IF: 16-bit Timer Interrupt Flag in the 16-bit Timer Ch.x Interrupt Control (T16\_INTx) Register (D0/0x4228/0x4248/0x4268)

To use this interrupt, set T16IE (D8/T16\_INTx register) to 1. If T16IE is set to 0 (default), T16IF will not be set to 1, and the interrupt request for this cause will not be sent to the ITC.

\* **T16IE**: 16-bit Timer Interrupt Enable Bit in the 16-bit Timer Ch.*x* Interrupt Control (T16\_INT*x*) Register (D8/0x4228/0x4248/0x4268)

If T16IF is set to 1, the T16 module outputs an interrupt request to the ITC. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core.

- Note: The T16 module interrupt flag T16IF must be reset within the interrupt handler routine following a 16-bit timer interrupt to prevent recurring interrupts.
  - Reset T16IF before permitting 16-bit timer interrupts with T16IE to prevent unwanted interrupts occurring.

#### Interrupt vectors

The timer interrupt vector numbers and vector addresses are listed below.

| Timer channel     | Vector number | Vector address |
|-------------------|---------------|----------------|
| 16-bit Timer Ch.0 | 13 (0x0d)     | TTBR + 0x34    |
| 16-bit Timer Ch.1 | 14 (0x0e)     | TTBR + 0x38    |
| 16-bit Timer Ch.2 | 15 (0x0f)     | TTBR + 0x3c    |

Table 11.8.2: Timer interrupt vectors

#### Other interrupt settings

The ITC allows the precedence of 16-bit timer interrupts to be set between level 0 (default) and level 7 for each channel. The PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1 to generate actual interrupts.

For specific information on interrupt processing, see "6 Interrupt Controller (ITC)."

# **11.9 Control Register Details**

| Address |          | Register name                                 | Function                              |  |  |  |  |  |
|---------|----------|-----------------------------------------------|---------------------------------------|--|--|--|--|--|
| 0x4220  | T16_CLK0 | 16-bit Timer Ch.0 Input Clock Select Register | Prescaler output clock selection      |  |  |  |  |  |
| 0x4222  | T16_TR0  | 16-bit Timer Ch.0 Reload Data Register        | Reload data setting                   |  |  |  |  |  |
| 0x4224  | T16_TC0  | 16-bit Timer Ch.0 Counter Data Register       | Counter data                          |  |  |  |  |  |
| 0x4226  | T16_CTL0 | 16-bit Timer Ch.0 Control Register            | Timer mode setting and timer RUN/STOP |  |  |  |  |  |
| 0x4228  | T16_INT0 | 16-bit Timer Ch.0 Interrupt Control Register  | Interrupt Control                     |  |  |  |  |  |
| 0x4240  | T16_CLK1 | 16-bit Timer Ch.1 Input Clock Select Register | Prescaler output clock selection      |  |  |  |  |  |
| 0x4242  | T16_TR1  | 16-bit Timer Ch.1 Reload Data Register        | Reload data setting                   |  |  |  |  |  |
| 0x4244  | T16_TC1  | 16-bit Timer Ch.1 Counter Data Register       | Counter data                          |  |  |  |  |  |
| 0x4246  | T16_CTL1 | 16-bit Timer Ch.1 Control Register            | Timer mode setting and timer RUN/STOP |  |  |  |  |  |
| 0x4248  | T16_INT1 | 16-bit Timer Ch.1 Interrupt Control Register  | Interrupt Control                     |  |  |  |  |  |
| 0x4260  | T16_CLK2 | 16-bit Timer Ch.2 Input Clock Select Register | Prescaler output clock selection      |  |  |  |  |  |
| 0x4262  | T16_TR2  | 16-bit Timer Ch.2 Reload Data Register        | Reload data setting                   |  |  |  |  |  |
| 0x4264  | T16_TC2  | 16-bit Timer Ch.2 Counter Data Register       | Counter data                          |  |  |  |  |  |
| 0x4266  | T16_CTL2 | 16-bit Timer Ch.2 Control Register            | Timer mode setting and timer RUN/STOP |  |  |  |  |  |
| 0x4268  | T16_INT2 | 16-bit Timer Ch.2 Interrupt Control Register  | Interrupt Control                     |  |  |  |  |  |

#### Table 11.9.1: 16-bit timer register list

The 16-bit timer registers are described in detail below. These are 16-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

| Register name | Address   | Bit   | Name    | Function                 | S       | Setting      |     | R/W | Remarks            |
|---------------|-----------|-------|---------|--------------------------|---------|--------------|-----|-----|--------------------|
| 16-bit Timer  | 0x4220    | D15–4 | -       | reserved                 |         | _            |     | -   | 0 when being read. |
| Ch.x Input    | 0x4240    | D3–0  | DF[3:0] | Timer input clock select | DF[3:0] | Clock        | 0x0 | R/W |                    |
| Clock Select  | 0x4260    |       |         | (Prescaler output clock) | 0xf     | reserved     | 1   |     |                    |
| Register      | (16 bits) |       |         |                          | 0xe     | PCLK-1/16384 |     |     |                    |
| (T16_CLKx)    | . ,       |       |         |                          | 0xd     | PCLK-1/8192  |     |     |                    |
| ,             |           |       |         |                          | 0xc     | PCLK-1/4096  |     |     |                    |
|               |           |       |         |                          | 0xb     | PCLK-1/2048  |     |     |                    |
|               |           |       |         |                          | 0xa     | PCLK-1/1024  |     |     |                    |
|               |           |       |         |                          | 0x9     | PCLK-1/512   |     |     |                    |
|               |           |       |         |                          | 0x8     | PCLK-1/256   |     |     |                    |
|               |           |       |         |                          | 0x7     | PCLK-1/128   |     |     |                    |
|               |           |       |         |                          | 0x6     | PCLK-1/64    |     |     |                    |
|               |           |       |         |                          | 0x5     | PCLK-1/32    |     |     |                    |
|               |           |       |         |                          | 0x4     | PCLK-1/16    |     |     |                    |
|               |           |       |         |                          | 0x3     | PCLK-1/8     |     |     |                    |
|               |           |       |         |                          | 0x2     | PCLK-1/4     |     |     |                    |
|               |           |       |         |                          | 0x1     | PCLK-1/2     |     |     |                    |
|               |           |       |         |                          | 0x0     | PCLK-1/1     |     |     |                    |

#### 0x4220/0x4240/0x4260: 16-bit Timer Ch.x Input Clock Select Registers (T16\_CLKx)

Note: The "x" in the register names indicates the channel number (0 to 2).

#### D[15:4] Reserved

#### D[3:0] DF[3:0]: Timer Input Clock Select Bits

Select the 16-bit timer count clock from the 15 different prescaler output clocks.

| DF[3:0] | Prescaler output clock | DF[3:0] | Prescaler output clock |
|---------|------------------------|---------|------------------------|
| Oxf     | Reserved               | 0x7     | PCLK-1/128             |
| 0xe     | PCLK-1/16384           | 0x6     | PCLK-1/64              |
| 0xd     | PCLK-1/8192            | 0x5     | PCLK-1/32              |
| Охс     | PCLK-1/4096            | 0x4     | PCLK-1/16              |
| 0xb     | PCLK-1/2048            | 0x3     | PCLK-1/8               |
| 0xa     | PCLK-1/1024            | 0x2     | PCLK-1/4               |
| 0x9     | PCLK-1/512             | 0x1     | PCLK-1/2               |
| 0x8     | PCLK-1/256             | 0x0     | PCLK-1/1               |

#### Table 11.9.2: Count clock selection

(Default: 0x0)

Note: Make sure the 16-bit timer count is halted before changing count clock settings.

#### 0x4222/0x4242/0x4262: 16-bit Timer Ch.x Reload Data Registers (T16\_TRx)

| Register name | Address   | Bit   | Name     | Function                 | Setting       | Init. | R/W | Remarks |
|---------------|-----------|-------|----------|--------------------------|---------------|-------|-----|---------|
| 16-bit Timer  | 0x4222    | D15-0 | TR[15:0] | 16-bit timer reload data | 0x0 to 0xffff | 0x0   | R/W |         |
| Ch.x Reload   | 0x4242    |       |          | TR15 = MSB               |               |       |     |         |
| Data Register | 0x4262    |       |          | TR0 = LSB                |               |       |     |         |
| (T16_TRx)     | (16 bits) |       |          |                          |               |       |     |         |

Note: The "x" in the register names indicates the channel number (0 to 2).

0x4222: 16-bit Timer Ch.0 Reload Data Register (T16\_TR0) 0x4242: 16-bit Timer Ch.1 Reload Data Register (T16\_TR1) 0x4262: 16-bit Timer Ch.2 Reload Data Register (T16\_TR2)

#### D[15:0] TR[15:0]: 16-bit Timer Reload Data

Sets the counter initial value. (Default: 0x0)

The reload data set in this register is preset to the counter if the timer is reset or the counter underflows. If the 16-bit timer is started after resetting, the timer counts down from the reload value (initial value). This means this reload value and the input clock frequency determine the time elapsed from the point at which the timer starts until the underflow occurs (or between underflows). The time determined is used to obtain the desired wait time, the intervals between periodic interrupts, and the programmable serial interface transfer clock.

#### 0x4224/0x4244/0x4264: 16-bit Timer Ch.x Counter Data Registers (T16\_TCx)

| Register name | Address   | Bit   | Name     | Function                  | Setting       | Init.  | R/W | Remarks |
|---------------|-----------|-------|----------|---------------------------|---------------|--------|-----|---------|
| 16-bit Timer  | 0x4224    | D15–0 | TC[15:0] | 16-bit timer counter data | 0x0 to 0xffff | 0xffff | R   |         |
| Ch.x Counter  | 0x4244    |       |          | TC15 = MSB                |               |        |     |         |
| Data Register | 0x4264    |       |          | TC0 = LSB                 |               |        |     |         |
| (T16_TCx)     | (16 bits) |       |          |                           |               |        |     |         |

Note: The "x" in the register names indicates the channel number (0 to 2).

0x4224: 16-bit Timer Ch.0 Counter Data Register (T16\_TC0) 0x4244: 16-bit Timer Ch.1 Counter Data Register (T16\_TC1) 0x4264: 16-bit Timer Ch.2 Counter Data Register (T16\_TC2)

D[15:0] TC[15:0]: 16-bit Timer Counter Data Reads out the counter data. (Default: 0xffff) This register is read-only and cannot be written to.

| Register name | Address   | Bit    | Name      | Function                           |     | Set       | ting           | Init. | R/W | Remarks            |
|---------------|-----------|--------|-----------|------------------------------------|-----|-----------|----------------|-------|-----|--------------------|
| 16-bit Timer  | 0x4226    | D15-11 | -         | reserved                           |     | -         | -              | -     | -   | 0 when being read. |
| Ch.x Control  | 0x4246    | D10    | CKACTV    | External clock active level select | 1   | High      | 0 Low          | 1     | R/W |                    |
| Register      | 0x4266    | D9-8   | CKSL[1:0] | Input clock and pulse width        | 0   | CKSL[1:0] | Mode           | 0x0   | R/W | 1                  |
| (T16_CTLx)    | (16 bits) |        |           | measurement mode select            |     | 0x3       | reserved       |       |     |                    |
|               |           |        |           |                                    |     | 0x2       | Pulse width    |       |     |                    |
|               |           |        |           |                                    |     | 0x1       | External clock |       |     |                    |
|               |           |        |           |                                    |     | 0x0       | Internal clock |       |     |                    |
|               |           | D7–5   | -         | reserved                           |     | -         | -              | -     | -   | 0 when being read. |
|               |           | D4     | TRMD      | Count mode select                  | 1 ( | One shot  | 0 Repeat       | 0     | R/W |                    |
|               |           | D3–2   | -         | reserved                           |     | -         | -              | -     | -   | 0 when being read. |
|               |           | D1     | PRESER    | Timer reset                        | 1   | Reset     | 0 Ignored      | 0     | W   |                    |
|               |           | D0     | PRUN      | Timer run/stop control             | 1   | Run       | 0 Stop         | 0     | R/W |                    |

#### 0x4226/0x4246/0x4266: 16-bit Timer Ch.x Control Registers (T16\_CTLx)

Note: The "x" in the register names indicates the channel number (0 to 2).

0x4226: 16-bit Timer Ch.0 Control Register (T16\_CTL0) 0x4246: 16-bit Timer Ch.1 Control Register (T16\_CTL1) 0x4266: 16-bit Timer Ch.2 Control Register (T16\_CTL2)

#### D[15:11] Reserved

#### D10 CKACTV: External Clock Active Level Select Bit

Selects the external input pulse polarity or external clock counting edge. 1 (R/W): Active High/Rising edge (default) 0 (R/W): Active Low/Falling edge

This setting determines whether the external input clock rising edge or falling edge is used for counting in external clock mode (when CKSL[1:0] = 0x1). In pulse width measurement mode (when CKSL[1:0] = 0x2), this setting determines external input pulse polarity.

#### D[9:8] CKSL[1:0]: Input Clock and Pulse Width Measurement Mode Select Bits Select the 16-bit timer operating mode.

| CKSL[1:0] | Operating mode               |
|-----------|------------------------------|
| 0x3       | Reserved                     |
| 0x2       | Pulse width measurement mode |
| 0x1       | External clock mode          |
| 0x0       | Internal clock mode          |
|           |                              |

Table 11.9.3: Operating mode selection

(Default: 0x0)

Internal clock mode uses the prescaler output clock as the count clock. The timer counts down from the initial value set in the reload data register and outputs an underflow signal when the counter underflows. The underflow signal is used to generate an interrupt and an internal serial interface clock. The time until underflow occurs can be finely programmed by selecting the prescaler clock and initial counter value, allowing its use for serial transfer clock generation and sporadic time measurement.

External clock mode uses the clock and pulses input via the input/output ports (Ch.0: P16, Ch.1: P07, Ch.2: P06) as a count clock and can also be used as an event counter. Timer operations other than the input clock are the same as for internal clock mode.

In pulse width measurement mode, when pulses with the specified polarity are input from the external clock port, the internal clock is fed only while the signal is active, enabling counting. This enables interrupt generation and input pulse width measurements for pulse inputs of the specified width or greater.

#### D[7:5] Reserved

#### D4 TRMD: Count Mode Select Bit

Selects the 16-bit timer count mode. 1 (R/W): One-shot mode 0 (R/W): Repeat mode (default)

Setting TRMD to 0 sets the 16-bit timer to Repeat mode. In this mode, once the count starts, the 16-bit timer continues to run until stopped by the application. If the counter underflows, the timer presets the counter to the reload data register value and continues the count. Thus, the timer periodically outputs an underflow pulse. Set the 16-bit timer to this mode to generate periodic interrupts at desired intervals or to generate a serial transfer clock.

Setting TRMD to 1 sets the 16-bit timer to One-shot mode. In this mode, the 16-bit timer stops automatically as soon as the counter underflows. This means only one interrupt can be generated after the timer starts. Note that the timer presets the counter to the reload data register value, then stops when an underflow occurs. Set the 16-bit timer to this mode to set a specific wait time or for pulse width measurement.

#### D[3:2] Reserved

#### D1 PRESER: Timer Reset Bit

- Resets the 16-bit timer.
- 1 (W): Reset
- 0 (W): Disabled
- 0 (R): Normally 0 when read out (default)

Writing 1 to this bit presets the counter to the reload data value.

#### D0 PRUN: Timer Run/Stop Control Bit

Controls the timer RUN/STOP. 1 (R/W): Run 0 (R/W): Stop (default)

The timer starts counting when PRUN is written as 1 and stops when written as 0. When the timer is stopped, the counter data is retained until reset or until the next RUN state.

#### 0x4228/0x4248/0x4268: 16-bit Timer Ch.x Interrupt Control Registers (T16\_INTx)

| Register name    | Address   | Bit   | Name  | Function                      | Setting |           | Init.         | R/W | Remarks |                     |
|------------------|-----------|-------|-------|-------------------------------|---------|-----------|---------------|-----|---------|---------------------|
| 16-bit Timer     | 0x4228    | D15–9 | -     | reserved                      |         | _         |               | -   | -       | 0 when being read.  |
| Ch.x Interrupt   | 0x4248    | D8    | T16IE | 16-bit timer interrupt enable | 1       | Enable    | 0 Disable     | 0   | R/W     |                     |
| Control Register | 0x4268    | D7–1  | -     | reserved                      |         | -         |               | -   | -       | 0 when being read.  |
| (T16_INTx)       | (16 bits) | D0    | T16IF | 16-bit timer interrupt flag   | 1       | Cause of  | 0 Cause of    | 0   | R/W     | Reset by writing 1. |
|                  |           |       |       |                               |         | interrupt | interrupt not |     |         |                     |
|                  |           |       |       |                               |         | occurred  | occurred      |     |         |                     |

#### Note: The "x" in register names indicates the channel number (0 to 2).

0x4228: 16-bit Timer Ch.0 Interrupt Control Register (T16\_INT0) 0x4248: 16-bit Timer Ch.1 Interrupt Control Register (T16\_INT1) 0x4268: 16-bit Timer Ch.2 Interrupt Control Register (T16\_INT2)

#### D[15:9] Reserved

#### D8 T16IE: 16-bit Timer Interrupt Enable Bit

Permits or prevents interrupts caused by counter underflows for each channel. 1 (R/W): Permit interrupt

0 (R/W): Prevent interrupt (default)

Setting T16IE to 1 enables 16-bit timer interrupt requests to the ITC; setting to 0 prevents interrupts.

#### D[7:1] Reserved

#### D0 T16IF: 16-bit Timer Interrupt Flag

Interrupt flag indicating the counter underflow interrupt cause occurrence status for each channel. 1 (R): Interrupt cause present

- 0 (R): No interrupt cause (default)
- 1 (W): Reset flag

0 (W): Disable

T16IF is the T16 module interrupt flag. Setting T16IE (D8) to 1 sets the counter to 1 if an underflow occurs during counting. A 16-bit timer interrupt request signal is output to the ITC at the same time. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core. Writing 1 to this bit resets T16IF.

## Note: • To prevent interrupt recurrences, the T16 module interrupt flag T16IF must be reset within the interrupt handler routine following a 16-bit timer interrupt.

• To prevent unwanted interrupts, reset T16IF before permitting 16-bit timer interrupts with T16IE.

### **11.10 Precautions**

- The prescaler must run before the 16-bit timer.
- Set the count clock and count mode only while the 16-bit timer count is stopped.
- To prevent interrupt recurrences, the T16 module interrupt flag T16IF (D0/T16\_INTx register) must be reset within the interrupt handler routine following a 16-bit timer interrupt.
  - \* **T16IF**: 16-bit Timer Interrupt Flag in 16-bit Timer Ch.*x* Interrupt Control (T16\_INT*x*) Register (D0/0x4228/0x4248/0x4268)
- To prevent unwanted interrupts, reset T16IF before permitting 16-bit timer interrupts with T16IE (D8/T16\_INTx register).
  - \* **T16IE**: 16-bit Timer Interrupt Enable Bit in 16-bit Timer Ch.*x* Interrupt Control (T16\_INT*x*) Register (D8/0x4228/0x4248/0x4268)

# **12 8-bit Timer (T8F)**

### 12.1 8-bit Timer Overview

The S1C17702 incorporates an 8-bit timer (two channels) with Fine mode.

The 8-bit timer consists of an 8-bit presettable down counter and an 8-bit reload data register holding the preset values. The timer counts down from the initial value set in the reload data register and outputs an underflow signal when the counter underflows. The underflow signal is used to generate an interrupt and UART clock. The underflow cycle can be programmed by selecting the prescaler clock and reload data, enabling the application program to obtain time intervals and serial transfer speeds as required. Fine mode provides a function that minimizes transfer rate errors.

Figure 12.1.1 illustrates the 8-bit timer configuration.



Figure 12.1.1: 8-bit timer configuration (One channel)

Note: The 2-channel 8-bit timer modules have the same functions for both channels. Only the control register addresses are different. The description in this section applies to all 8-bit timer channels. The "x" in the register name indicates the channel number (0 or 1). Register addresses are given in the format (Ch.0/Ch.1).

Example: T8F\_CTLx register (0x4206/0x4286) Ch.0: T8F\_CTL0 register (0x4206) Ch.1: T8F\_CTL1 register (0x4286)

### 12.2 8-bit Timer Count Mode

The 8-bit timer features two count modes: Repeat mode and One-shot mode. These modes are selected using the TRMD bit (D4/T8F\_CTLx register).

\* TRMD: Count Mode Select Bit in the 8-bit Timer Ch.x Control (T8F\_CTLx) Register (D4/0x4206/0x4286)

#### Repeat mode (TRMD = 0, default)

Setting TRMD to 0 sets the 8-bit timer to Repeat mode.

In this mode, once the count starts, the 8-bit timer continues running until stopped by the application program. If the counter underflows, the timer presets the reload data register value into the counter and continues the count. Thus, the timer periodically outputs an underflow pulse. The 8-bit timer should be set to this mode to generate periodic interrupts at desired intervals or to generate a serial transfer clock.

#### One-shot mode (TRMD = 1)

Setting TRMD to 1 sets the 8-bit timer to One-shot mode.

In this mode, the 8-bit timer stops automatically as soon as the counter underflows. This means only one interrupt can be generated after the timer starts. Note that the timer presets the reload data register value to the counter, then stops after an underflow has occurred. The 8-bit timer should be set to this mode to set a specific wait time.

Note: Make sure the 8-bit timer count is halted before changing count mode settings.

### 12.3 Count Clock

The 8-bit timer uses the prescaler output clock as the count clock. The prescaler generates 15 different clocks by dividing the PCLK clock into 1/1 to 1/16 K divisions. One of these is selected by the DF[3:0] bit (D[3:0]/ T8F\_CLKx register).

\* DF[3:0]: Timer Input Clock Select Bits in the 8-bit Timer Ch.x Input Clock Select (T8F\_CLKx) Register (D[3:0]/0x4200/0x4280)

| DF[3:0] | Prescaler output clock | DF[3:0] | Prescaler output clock |
|---------|------------------------|---------|------------------------|
| 0xf     | Reserved               | 0x7     | PCLK-1/128             |
| 0xe     | PCLK-1/16384           | 0x6     | PCLK-1/64              |
| 0xd     | PCLK-1/8192            | 0x5     | PCLK-1/32              |
| 0xc     | PCLK-1/4096            | 0x4     | PCLK-1/16              |
| 0xb     | PCLK-1/2048            | 0x3     | PCLK-1/8               |
| 0xa     | PCLK-1/1024            | 0x2     | PCLK-1/4               |
| 0x9     | PCLK-1/512             | 0x1     | PCLK-1/2               |
| 0x8     | PCLK-1/256             | 0x0     | PCLK-1/1               |

Table 12.3.1: Count clock selection

(Default: 0x0)

#### Note: • The prescaler must run before the 8-bit timer.

#### • Make sure the 8-bit timer count is halted before changing count clock settings.

For detailed information on the prescaler control, see "9 Prescaler (PSC)."

### 12.4 8-bit Timer Reload Register and Underflow Cycle

The reload data register T8F\_TRx (0x4202/0x4282) is used to set the initial value for the down counter.

The initial counter value set in the reload data register is preset to the down counter if the 8-bit timer is reset or the counter underflows. If the 8-bit timer is started after resetting, the timer counts down from the reload value (initial value). This means this reload value and the input clock frequency determine the time elapsed from the point at which the timer starts until the underflow occurs (or between underflows). The time determined is used to obtain the specified wait time, the intervals between periodic interrupts, and the programmable serial interface transfer clock.



The underflow cycle can be calculated as follows:

Underflow interval =  $\frac{\text{T8F}_{\text{TR}x + 1}}{\text{clk}_{\text{in}}}$  [s] Underflow cycle =  $\frac{\text{clk}_{\text{in}}}{\text{T8F}_{\text{TR}x + 1}}$  [Hz] clk\_in: Count clock (prescaler output clock) frequency [Hz] T8F\_TRx: Reload data (0 to 255)

## Note: The UART generates a sampling clock that divides the 8-bit timer output into 1/16 divisions. Be careful when setting the transfer rate.

### 12.5 8-bit Timer Reset

The 8-bit timer is reset by writing 1 to PRESER bit  $(D1/T8F\_CTLx \text{ register})$ . The reload data is preset and the counter is initialized.

\* **PRESER**: Timer Reset Bit in the 8-bit Timer Ch.x Control (T8F\_CTLx) Register (D1/0x4206/0x4286)

### 12.6 8-bit Timer RUN/STOP Control

Make the following settings before starting the 8-bit timer:

- (1) Set the count mode (One-shot or Repeat). See Section 12.2.
- (2) Select the count clock (prescaler output clock). See Section 12.3.
- (3) Calculate the initial counter value and set it to the reload data register. See Section 12.4.
- (4) Reset the timer and preset the initial value to the counter. See Section 12.5.
- (5) If using timer interrupts, set the interrupt level and permit interrupts. See Section 12.9.

To start the 8-bit timer, program 1 to PRUN (D0/T8F\_CTLx register).

\* PRUN: Timer Run/Stop Control Bit in the 8-bit Timer Ch.x Control (T8F\_CTLx) Register (D0/0x4206/0x4286)

The timer starts counting down from the initial value or from the current counter value if no initial value was preset. When the counter underflows, the timer outputs an underflow pulse and presets the counter to the initial value. An interrupt request is sent simultaneously to the interrupt controller (ITC).

If One-shot mode is set, the timer stops the count.

If Repeat mode is set, the timer continues to count from the reloaded initial value.

Program 0 to PRUN bit to stop the 8-bit timer via the application program. The counter stops counting and retains the current counter value until either the timer is reset or restarted. To restart the count from the initial value, the timer should be reset before writing 1 to PRUN.

Resetting the timer while counting is underway sets the counter to the reload register value and continues the count.



### 12.7 8-bit Timer Output Signal

The 8-bit timer outputs underflow pulses when the counter underflows. These pulses are used for timer interrupt requests.

The underflow pulses are also used to generate the serial transfer clock and are transmitted to the UART. Use the following equations to calculate the reload data register value for obtaining the desired transfer rate. 8-bit timer Ch.0 output clock  $\rightarrow$  UART Ch.0

8-bit timer Ch.1 output clock  $\rightarrow$  UART Ch.1

$$bps = \frac{clk\_in}{\{(T8F\_TR + 1) \times 16 + TFMD\}}$$
$$T8F\_TR = \left(\frac{clk\_in}{bps} - TFMD - 16\right) \div 16$$

clk\_in: Count clock (prescaler output clock) frequency [Hz]

T8F\_TR: Reload data (0 to 255)

bps: Transfer rate (bit/s)

TFMD: Fine mode setting (0 to15)

### 12.8 Fine Mode

Fine mode provides a function that minimizes transfer rate errors.

The 8-bit timer can output a programmable clock signal for use as the UART serial transfer clock. The timer output clock can be set to the required frequency by selecting the appropriate prescaler output clock and reload data. Note that errors may occur, depending on the transfer rate. Fine mode extends the output clock cycle by delaying the underflow pulse from the counter. This delay can be specified with the TFMD[3:0] bit (D[11:8]/T8F\_CTLx register).

#### \* TFMD[3:0]: Fine Mode Setup Bits in the 8-bit Timer Ch.x Control (T8F\_CTLx) Register (D[11:8]/0x4206/ 0x4286)

The TFMD[3:0] bit specifies the delay pattern to be inserted into the 16 underflow intervals. Inserting one delay extends the output clock cycle by one count clock cycle. This setting delays the interrupt timing in the same way.

| TEMPIO.01 |                              |                              |         |         |               |   | Un | derflov |   | ber  |               |        |         |         |         |        |
|-----------|------------------------------|------------------------------|---------|---------|---------------|---|----|---------|---|------|---------------|--------|---------|---------|---------|--------|
| TFMD[3:0] | 1                            | 2                            | 3       | 4       | 5             | 6 | 7  | 8       | 9 | 10   | 11            | 12     | 13      | 14      | 15      | 16     |
| 0x0       | -                            | -                            | -       | -       | -             | - | -  | -       | - | -    | -             | -      | -       | -       | -       | -      |
| 0x1       | -                            | -                            | -       | -       | -             | - | -  | -       | - | -    | -             | -      | -       | -       | -       | D      |
| 0x2       | -                            | -                            | -       | -       | -             | - | -  | D       | - | -    | _             | -      | -       | -       | _       | D      |
| 0x3       | -                            | _                            | -       | -       | _             | - | _  | D       | _ | -    |               | D      | -       | _       | _       | D      |
| 0x4       | -                            | D D -                        |         |         |               |   |    |         | - | _    | D             | -      | -       | _       | D       |        |
| 0x5       | -                            | _                            | -       | D       | _             | - | -  | D       | _ | -    | _             | D      | -       | D       | _       | D      |
| 0x6       | -                            | _                            | -       | D       | -             | D | -  | D       | _ | _    | _             | D      | -       | D       | _       | D      |
| 0x7       | -                            | _                            | -       | D       | -             | D | -  | D       | - | D    | -             | D      | -       | D       | _       | D      |
| 0x8       | -                            | D                            | -       | D       | -             | D | -  | D       | - | D    | -             | D      | -       | D       | -       | D      |
| 0x9       | -                            | D                            | -       | D       | -             | D | -  | D       | - | D    | -             | D      | -       | D       | D       | D      |
| 0xa       | – D – D – D D D              |                              |         |         |               |   | -  | D       | - | D    | -             | D      | D       | D       |         |        |
| 0xb       | - D - D - D D D - D D        |                              |         |         |               | D | -  | D       | D | D    |               |        |         |         |         |        |
| 0xc       | -                            | D                            | D       | D       | -             | D | D  | D       | - | D    | D             | D      | -       | D       | D       | D      |
| 0xd       | -                            | D                            | D       | D       | -             | D | D  | D       | _ | D    | D             | D      | D       | D       | D       | D      |
| 0xe       | -                            | D                            | D       | D       | D             | D | D  | D       | _ | D    | D             | D      | D       | D       | D       | D      |
| 0xf       | -                            | D                            | D       | D       | D             | D | D  | D       | D | D    | D             | D      | D       | D       | D       | D      |
|           |                              |                              |         |         | _             |   |    |         |   | D: I | ndicat        | es the | inserti | on of a | a delay | cycle. |
|           |                              |                              | Cou     | int clo | ck _  [<br>15 |   |    | ШЦΙ     |   |      | $\Box$ $\Box$ | ШЦΙ    |         | ⊔⊔      |         |        |
| Und       | erflow                       | rflow signal (no correction) |         |         |               |   |    |         |   |      |               |        |         |         |         |        |
| Under     | flow si                      | v signal (with correction)   |         |         |               |   |    |         |   |      |               |        |         |         |         |        |
| (         | Output clock (no correction) |                              |         |         |               |   |    |         |   |      |               |        |         |         |         |        |
| O         | utput c                      | lock (v                      | vith co | rrectio | n) _          |   |    |         |   |      |               |        |         | [       |         |        |

Figure 12.8.1: Delay cycle insertion in Fine mode

| Table 12.8 1. Dela  | v pattorne epocifio | d by TEMD[2:0] |
|---------------------|---------------------|----------------|
| Table 12.8.1: Delay | / patterns specifie |                |

After the initial resetting, TFMD[3:0] is set to 0x0, preventing insertion of delay cycles.

### 12.9 8-bit Timer Interrupts

The 8-bit timer outputs interrupt requests to the interrupt controller (ITC) when the counter underflows.

#### **Underflow interrupt**

This interrupt request generated by a counter underflow sets the interrupt flag T8IF (D0/T8F\_INTx register) to 1 within the T8F module.

\* **T8IF:** 8-bit Timer Interrupt Flag in the 8-bit Timer Ch.*x* Interrupt Control (T8F\_INT*x*) Register (D0/ 0x4208/0x4288)

To use this interrupt, set T8IE (D8/T8F\_INTx register) to 1. If T8IE is set to 0 (the default value), T8IF will not be set to 1, and interrupt request for this interrupt cause will not be sent to the ITC.

\* **T8IE**: 8-bit Timer Interrupt Enable Bit in the 8-bit Timer Ch.x Interrupt Control (T8F\_INTx) Register (D8/0x4208/0x4288)

If T8IF is set to 1, the T8F module outputs an interrupt request to the ITC. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core.

- Note: To prevent interrupt recurrences, the T8F module interrupt flag T8IF must be reset within the interrupt handler routine following an 8-bit timer interrupt.
  - To prevent unwanted interrupts, reset T8IF before permitting 8-bit timer interrupts with T8IE.
  - The 8-bit timer uses one interrupt signal for Ch.0 and Ch.1 interrupt requests to the ITC. The same interrupt processing routine is performed regardless of which interrupt is generated. When using both channel interrupts, read out the interrupt flag in the T8F module as part of the interrupt processing routine and check which channel generates the interrupt.

#### Interrupt vectors

The 8-bit timer interrupt vector numbers and vector addresses are listed below.

Vector number: 12 (0x0c) Vector address: TTBR + 0x30

#### Other interrupt settings

The ITC allows the priority of 8-bit timer interrupts to be set between level 0 (the default value) and level 7 for each channel. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### 12.10 Control Register Details

|         |          |                                              | logister not                          |
|---------|----------|----------------------------------------------|---------------------------------------|
| Address |          | Register name                                | Function                              |
| 0x4200  | T8F_CLK  | 8-bit Timer Input Clock Select Register      | Prescaler output clock selection      |
| 0x4202  | T8F_TR   | 8-bit Timer Reload Data Register             | Reload data setting                   |
| 0x4204  | T8F_TC   | 8-bit Timer Counter Data Register            | Counter data                          |
| 0x4206  | T8F_CTL  | 8-bit Timer Control Register                 | Timer mode setting and timer RUN/STOP |
| 0x4208  | T8F_INT  | 8-bit Timer Interrupt Control Register       | Interrupt control                     |
| 0x4280  | T8F_CLK1 | 8-bit Timer Ch.1 Input Clock Select Register | Prescaler output clock selection      |
| 0x4282  | T8F_TR1  | 8-bit Timer Ch.1 Reload Data Register        | Reload data setting                   |
| 0x4284  | T8F_TC1  | 8-bit Timer Ch.1 Counter Data Register       | Counter data                          |
| 0x4286  | T8F_CTL1 | 8-bit Timer Ch.1 Control Register            | Timer mode setting and timer RUN/STOP |
| 0x4288  | T8F_INT1 | 8-bit Timer Ch.1 Interrupt Control Register  | Interrupt control                     |

#### Table 12.10.1: 8-bit timer register list

The 8-bit timer registers are described in detail below. These are 16-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

| Register name    | Address   | Bit   | Name    | Function                       | S       | etting       | Init. | R/W | Remarks            |
|------------------|-----------|-------|---------|--------------------------------|---------|--------------|-------|-----|--------------------|
| 8-bit Timer Ch.x | 0x4200    | D15–4 | -       | reserved                       |         | -            | -     | -   | 0 when being read. |
| Input Clock      | 0x4280    | D3–0  | DF[3:0] | 8-bit timer input clock select | DF[3:0] | Clock        | 0x0   | R/W | -                  |
| Select Register  | (16 bits) |       |         | (Prescaler output clock)       | 0xf     | reserved     | 1     |     |                    |
| T8F_CLKx)        |           |       |         |                                | 0xe     | PCLK-1/16384 |       |     |                    |
| -                |           |       |         |                                | 0xd     | PCLK-1/8192  |       |     |                    |
|                  |           |       |         |                                | 0xc     | PCLK-1/4096  |       |     |                    |
|                  |           |       |         |                                | 0xb     | PCLK-1/2048  |       |     |                    |
|                  |           |       |         |                                | 0xa     | PCLK-1/1024  |       |     |                    |
|                  |           |       |         |                                | 0x9     | PCLK-1/512   |       |     |                    |
|                  |           |       |         |                                | 0x8     | PCLK-1/256   |       |     |                    |
|                  |           |       |         |                                | 0x7     | PCLK-1/128   |       |     |                    |
|                  |           |       |         |                                | 0x6     | PCLK-1/64    |       |     |                    |
|                  |           |       |         |                                | 0x5     | PCLK-1/32    |       |     |                    |
|                  |           |       |         |                                | 0x4     | PCLK-1/16    |       |     |                    |
|                  |           |       |         |                                | 0x3     | PCLK-1/8     |       |     |                    |
|                  |           |       |         |                                | 0x2     | PCLK-1/4     |       |     |                    |
|                  |           |       |         |                                | 0x1     | PCLK-1/2     |       |     |                    |
|                  |           |       |         |                                | 0x0     | PCLK-1/1     |       |     |                    |

#### 0x4200/0x4280: 8-bit Timer Ch.x Input Clock Select Register (T8F\_CLKx)

Note: The indication "x" in the register name indicates the channel number (0 or 1).

0x4200: 8-bit Timer Ch.0 Input Clock Select Register (T8F\_CLK0) 0x4280: 8-bit Timer Ch.1 Input Clock Select Register (T8F\_CLK1)

#### D[15:4] Reserved

#### D[3:0] DF[3:0]: 8-bit Timer Input Clock Select Bits

Select the 8-bit timer count clock from the 15 different prescaler output clocks.

| DF[3:0] | Prescaler output clock | DF[3:0] | Prescaler output clock |
|---------|------------------------|---------|------------------------|
| Oxf     | Reserved               | 0x7     | PCLK-1/128             |
| 0xe     | PCLK-1/16384           | 0x6     | PCLK-1/64              |
| 0xd     | PCLK-1/8192            | 0x5     | PCLK-1/32              |
| Охс     | PCLK-1/4096            | 0x4     | PCLK-1/16              |
| 0xb     | PCLK-1/2048            | 0x3     | PCLK-1/8               |
| 0xa     | PCLK-1/1024            | 0x2     | PCLK-1/4               |
| 0x9     | PCLK-1/512             | 0x1     | PCLK-1/2               |
| 0x8     | PCLK-1/256             | 0x0     | PCLK-1/1               |

#### Table 12.10.2: Count clock selection

(Default: 0x0)

Note: Make sure the 8-bit timer count is halted before changing count clock settings.

#### 0x4202/0x4282: 8-bit Timer Ch.x Reload Data Register (T8F\_TRx)

| Register name    | Address   | Bit   | Name    | Function                | Setting     | Init. | R/W | Remarks            |
|------------------|-----------|-------|---------|-------------------------|-------------|-------|-----|--------------------|
| 8-bit Timer Ch.x | 0x4202    | D15-8 | -       | reserved                | _           | -     | -   | 0 when being read. |
| Reload Data      | 0x4282    | D7–0  | TR[7:0] | 8-bit timer reload data | 0x0 to 0xff | 0x0   | R/W |                    |
| Register         | (16 bits) |       |         | TR7 = MSB               |             |       |     |                    |
| (T8F_TRx)        |           |       |         | TR0 = LSB               |             |       |     |                    |

#### Note: The indication "x" in the register name indicates the channel number (0 or 1).

0x4202: 8-bit Timer Ch.0 Reload Data Register (T8F\_TR0) 0x4282: 8-bit Timer Ch.1 Reload Data Register (T8F\_TR1)

#### D[15:8] Reserved

#### D[7:0] TR[7:0]: 8-bit Timer Reload Data

Sets the counter initial value. (Default: 0x0)

The reload data set in this register is preset to the counter if the timer is reset or the counter underflows. If the 8-bit timer is started after resetting, the timer counts down from the reload value (initial value). This means this reload value and the input clock frequency determine the time elapsed from the point at which the timer starts until the underflow occurs (or between underflows). The time determined is used to obtain the desired wait time, the intervals between periodic interrupts, and the programmable serial interface transfer clock.

#### 0x4204/0x4284: 8-bit Timer Ch.x Counter Data Register (T8F\_TCx)

| Register name    | Address   | Bit   | Name    | Function                 | Setting     | Init. | R/W | Remarks            |
|------------------|-----------|-------|---------|--------------------------|-------------|-------|-----|--------------------|
| 8-bit Timer Ch.x | 0x4204    | D15–8 | -       | reserved                 | _           | -     | -   | 0 when being read. |
| Counter Data     | 0x4284    | D7–0  | TC[7:0] | 8-bit timer counter data | 0x0 to 0xff | 0xff  | R   |                    |
| Register         | (16 bits) |       |         | TC7 = MSB                |             |       |     |                    |
| (T8F_TCx)        |           |       |         | TC0 = LSB                |             |       |     |                    |

#### Note: The indication "x" in the register name indicates the channel number (0 or 1).

0x4204: 8-bit Timer Ch.0 Counter Data Register (T8F\_TC0) 0x4284: 8-bit Timer Ch.1 Counter Data Register (T8F\_TC1)

#### D[15:8] Reserved

D[7:0] TC[7:0]: 8-bit Timer Counter Data Reads out the counter data. (Default: 0xff) This register is read-only and cannot be written to.

| Register name    | Address | Bit    | Name      | Function               |            | Set      | ting | g       | Init.                  | R/W                | Remarks              |
|------------------|---------|--------|-----------|------------------------|------------|----------|------|---------|------------------------|--------------------|----------------------|
| 8-bit Timer Ch.x | 0x4206  | D15-12 | -         | reserved               |            | -        |      | -       | -                      | 0 when being read. |                      |
| Control Register | 0x4286  | D11-8  | TFMD[3:0] | Fine mode setup        | 0x0 to 0xf |          | 0x0  | R/W     | Set a number of times  |                    |                      |
| (T8F_CTLx)       |         |        |           |                        |            |          |      |         | to insert delay into a |                    |                      |
|                  |         |        |           |                        |            |          |      |         |                        |                    | 16-underflow period. |
|                  |         | D7–5   | -         | reserved               |            | -        | _    |         | -                      | -                  | 0 when being read.   |
|                  |         | D4     | TRMD      | Count mode select      | 1          | One shot | 0    | Repeat  | 0                      | R/W                |                      |
|                  |         | D3–2   | -         | reserved               |            | -        | -    |         | -                      | -                  | 0 when being read.   |
|                  |         | D1     | PRESER    | Timer reset            | 1          | Reset    | 0    | Ignored | 0                      | W                  | 1                    |
|                  |         | D0     | PRUN      | Timer run/stop control | 1          | Run      | 0    | Stop    | 0                      | R/W                |                      |

#### 0x4206/0x4286: 8-bit Timer Ch.x Control Register (T8F\_CTLx)

Note: The indication "x" in the register name indicates the channel number (0 or 1).

0x4206: 8-bit Timer Ch.0 Control Register (T8F\_CTL0) 0x4286: 8-bit Timer Ch.1 Control Register (T8F\_CTL1)

#### D[15:12] Reserved

#### D[11:8] TFMD[3:0]: Fine Mode Setup Bits

Correct the transfer rate error. (Default: 0x0)

The TFMD[3:0] bit specifies the delay pattern to be inserted into the 16 underflow intervals. Inserting one delay extends the output clock cycle by one count clock cycle. This setting delays the interrupt timing in the same way.

|                 |                                    |        |        |             |      |       |       | derflov | -              |        | -       |             |        |      |       |        |
|-----------------|------------------------------------|--------|--------|-------------|------|-------|-------|---------|----------------|--------|---------|-------------|--------|------|-------|--------|
| TFMD[3:0]       | 1                                  | 2      | 3      | 4           | 5    | 6     | 7     | 8       | 9              | 10     | 11      | 12          | 13     | 14   | 15    | 16     |
| 0x0             | -                                  | -      | -      | -           | -    | -     | -     | -       | -              | -      | -       | -           | -      | -    | -     | -      |
| 0x1             | -                                  | -      | I      | -           | -    | -     | -     | -       | -              | -      | -       | -           | -      | -    | -     | D      |
| 0x2             | -                                  | -      | -      | -           | -    | -     | -     | D       | -              | -      | -       | -           | -      | -    | -     | D      |
| 0x3             | -                                  | _      | _      | -           | -    | -     | -     | D       | -              | -      | -       | D           | _      | -    | -     | D      |
| 0x4             | -                                  | _      | _      | D           | -    | -     | -     | D       | -              | -      | -       | D           | _      | -    | -     | D      |
| 0x5             | -                                  | -      | _      | D           | -    | -     | -     | D       | -              | -      | -       | D           | _      | D    | -     | D      |
| 0x6             | -                                  | -      | -      | D           | -    | D     | _     | D       | -              | -      | _       | D           | _      | D    | -     | D      |
| 0x7             | -                                  | _      | -      | D           | _    | D     | _     | D       | -              | D      | _       | D           | -      | D    | -     | D      |
| 0x8             | _                                  | D      | _      | D           | _    | D     | _     | D       | -              | D      | _       | D           | _      | D    | -     | D      |
| 0x9             | _                                  | D      | -      | D           | _    | D     | _     | D       | -              | D      | _       | D           | -      | D    | D     | D      |
| 0xa             | _                                  | D      | -      | D           | _    | D     | D     | D       | -              | D      | -       | D           | _      | D    | D     | D      |
| 0xb             | -                                  | D      | -      | D           | _    | D     | D     | D       | -              | D      | D       | D           | _      | D    | D     | D      |
| 0xc             | -                                  | D      | D      | D           | -    | D     | D     | D       | -              | D      | D       | D           | -      | D    | D     | D      |
| 0xd             | -                                  | D      | D      | D           | -    | D     | D     | D       | -              | D      | D       | D           | D      | D    | D     | D      |
| 0xe             | -                                  | D      | D      | D           | D    | D     | D     | D       | -              | D      | D       | D           | D      | D    | D     | D      |
| 0xf             | -                                  | D      | D      | D           | D    | D     | D     | D       | D              | D      | D       | D           | D      | D    | D     | D      |
|                 |                                    | Coun   | t cloc | k _∏_<br>15 | ЛЛ   | ЛЛ    | ЛЛ    | ЛЛ      | D:<br>ЛЛ<br>16 | Indica | ates th | ne ins<br>M | ertion | ofac | delay | cycle. |
| Underflow sig   | nal (no                            | o corr | ectior |             |      |       |       |         | _Ĩ             | 16     |         |             |        | Ĺ    | 1     |        |
| Underflow signa | Underflow signal (with correction) |        |        |             |      |       |       |         |                |        |         |             |        |      |       |        |
| Output clc      | ock (no                            | o corr | ectior | ı) _        |      |       |       |         |                |        |         |             |        |      |       |        |
| Output cloc     | •                                  |        |        | · _         |      |       |       |         |                | 1      |         |             |        |      |       |        |
|                 | I                                  | -igure | 12.1   | 0.1: D      | elay | cycle | inser | tion in | Fine           | mode   | Э       |             |        |      |       |        |

Table 12.10.3: Delay patterns specified by TFMD[3:0]



#### D4 TRMD: Count Mode Select Bit

Selects the 8-bit timer count mode. 1 (R/W): One-shot mode 0 (R/W): Repeat mode (default)

Setting TRMD to 0 sets the 8-bit timer to Repeat mode. In this mode, once the count starts, the 8-bit timer continues to run until stopped by the application. If the counter underflows, the timer presets the counter to the reload data register value and continues the count. Thus, the timer periodically outputs an underflow pulse. Set the 8-bit timer to this mode to generate periodic interrupts at desired intervals or to generate a serial transfer clock.

Setting TRMD to 1 sets the 8-bit timer to One-shot mode. In this mode, the 8-bit timer stops automatically as soon as the counter underflows. This means only one interrupt can be generated after the timer starts. Note that the timer presets the counter to the reload data register value, then stops when an underflow occurs. Set the 8-bit timer to this mode to set a specific wait time.

Note: Make sure the 8-bit timer count is halted before changing count mode settings.

#### D[3:2] Reserved

#### D1 PRESER: Timer Reset Bit

Resets the 8-bit timer.

1 (W): Reset

- 0 (W): Disabled
- 0 (R): Normally 0 when read out (default)

Writing 1 to this bit presets the counter to the reload data value.

#### D0 PRUN: Timer Run/Stop Control Bit

Controls the timer RUN/STOP. 1 (R/W): Run 0 (R/W): Stop (default)

The timer starts counting when PRUN is written as 1 and stops when written as 0. When the timer is stopped, the counter data is retained until reset or until the next RUN state.

|                  |           |       |      | •                            |         | -         | • |               |     |                    |                     |
|------------------|-----------|-------|------|------------------------------|---------|-----------|---|---------------|-----|--------------------|---------------------|
| Register name    | Address   | Bit   | Name | Function                     | Setting |           |   | Init.         | R/W | Remarks            |                     |
| 8-bit Timer Ch.x | 0x4208    | D15–9 | -    | reserved                     | -       |           |   | -             | -   | 0 when being read. |                     |
| Interrupt        | 0x4288    | D8    | T8IE | 8-bit timer interrupt enable | 1       | Enable    | 0 | Disable       | 0   | R/W                |                     |
| Control Register | (16 bits) | D7–1  | -    | reserved                     |         |           | _ |               | -   | -                  | 0 when being read.  |
| (T8F_INTx)       |           | D0    | T8IF | 8-bit timer interrupt flag   | 1       | Cause of  | 0 | Cause of      | 0   | R/W                | Reset by writing 1. |
|                  |           |       |      |                              |         | interrupt |   | interrupt not |     |                    |                     |
|                  |           |       |      |                              |         | occurred  |   | occurred      |     |                    |                     |

#### 0x4208/0x4288: 8-bit Timer Ch.x Interrupt Control Register (T8F\_INTx)

Note: The indication "x" in the register name indicates the channel number (0 or 1).

0x4208: 8-bit Timer Ch.0 Interrupt Control Register (T8F\_INT0) 0x4288: 8-bit Timer Ch.1 Interrupt Control Register (T8F\_INT1)

#### D[15:9] Reserved

#### D8 T8IE: 8-bit Timer Interrupt Enable Bit

Permits or prevents interrupts caused by counter underflows for each channel. 1 (R/W): Permit interrupt 0 (R/W): Prevent interrupt (default)

Setting T8IE to 1 permits 8-bit timer interrupt requests to the ITC; setting to 0 prevents interrupts.

#### D[7:1] Reserved

#### D0 T8IF: 8-bit Timer Interrupt Flag

Interrupt flag indicating the counter underflow interrupt cause occurrence status for each channel. 1 (R): Interrupt cause present

0 (R): No interrupt cause (default)

1 (W): Reset flag

0 (W): Disable

T8IF is the T8F module interrupt flag. Setting T8IE (D8) to 1 sets the counter to 1 if an underflow occurs during counting. An 8-bit timer interrupt request signal is output to the ITC at the same time. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core. Writing 1 to this bit resets T8IF.

- Note: To prevent interrupt recurrences, the T8 module interrupt flag T8IF must be reset within the interrupt handler routine following an 8-bit timer interrupt.
  - To prevent unwanted interrupts, reset T8IF before permitting 8-bit timer interrupts with T8IE.
  - The 8-bit timer uses one interrupt signal for Ch.0 and Ch.1 interrupt requests to the ITC. The same interrupt processing routine is performed regardless of which interrupt is generated. When using both channel interrupts, read out the interrupt flag in the T8F module as part of the interrupt processing routine and check which channel generates the interrupt.

### 12.11 Precautions

- The prescaler must run before the 8-bit timer.
- Set the count clock and count mode only while the 8-bit timer count is stopped.
- To prevent interrupt recurrences, the T8F module interrupt flag T8IF (D0/T8F\_INTx register) must be reset within the interrupt handler routine following an 8-bit timer interrupt.
  - \* **T8IF**: 8-bit Timer Ch.*x* Interrupt Flag in the 8-bit Timer Ch.*x* Interrupt Control (T8F\_INT*x*) Register (D0/0x4208/ x4288)
- To prevent unwanted interrupts, reset T8IF before permitting 8-bit timer interrupts with T8IE (D8/T8F\_INTx register).
  - \* **T8IE**: 8-bit Timer Ch.*x* Interrupt Enable Bit in the 8-bit Timer Ch.*x* Interrupt Control (T8F\_INT*x*) Register (D8/0x4208/x4288)
- The 8-bit timer uses one interrupt signal for Ch.0 and Ch.1 interrupt requests to the ITC. The same interrupt processing routine is performed regardless of which interrupt is generated. When using both channel interrupts, read out the interrupt flag in the T8F module as part of the interrupt processing routine and check which channel generates the interrupt.

# 13 PWM & Capture Timer (T16E)

### 13.1 PWM & Capture Timer Overview

The S1C17702 incorporates a double-channel PWM & capture timer. Figure 13.1.1 illustrates the PWM & capture timer configuration.



The PWM & capture timer includes a 16-bit up-counter (T16E\_TC register), two 16-bit compare data registers (T16E\_CA and T16E\_CB registers), and the corresponding buffers.

The 16-bit counter can be reset to 0 or set to a counter value by software and counts up for external signals from the prescaler output clock or P27 port pin. The count value can be read by software.

The compare data A and B registers hold data for comparison against the up-counter contents. Data can be read or written directly to or from the compare data registers. The compare data buffers enable loading to the compare data registers of comparison values set when the counter is reset by software or by a compare B match signal. Software can be used to set which of the compare data register and buffer the comparison values are written to.

If the counter value matches the contents of each compare data register, the comparator outputs a signal to control interrupts and output signals. These registers can be used to program the interrupt occurrence cycle and output clock frequency and duty ratio.

Note: The PWM & capture timer (T16E) modules for the two channels have the same functions, except for control register addresses. For this reason, the description in this section applies to all PWM & capture timer channels. The "x" in the register name indicates the channel number (0 or 1). Register addresses are indicated either as "Ch.0" or "Ch.1".

E.g.: T16E\_CTL*x* register (0x5306/0x5366) Ch.0: T16\_CTL0 register (0x5306)

Ch.1: T16\_CTL1 register (0x5366)

### 13.2 PWM & Capture Timer Operating Modes

The PWM & capture timer has the following two operating modes:

1. Internal clock mode (Timer counting internal clock)

2. External clock mode (Functions as event counter)

The operating mode is selected using CLKSEL (D3/T16E\_CTLx register).

\* CLKSEL: Input Clock Select Bit in the PWM Timer Ch.x Control (T16E\_CTLx) Register (D3/0x5306/0x5366)

Setting CLKSEL to 0 (default) selects internal clock mode, while setting to 1 selects external clock mode.

#### Internal clock mode

Internal clock mode uses the prescaler output clock as the count clock.

The count clock is selected by the T16EDF[3:0] (D[3:0]/T16E\_CLKx register) from the 15 types generated by the prescaler dividing the PCLK clock into 1/1 to 1/16 K divisions.

\* **T16EDF[3:0]**: Timer Input Clock Select Bits in the PWM Timer Ch.*x* Input Clock Select (T16E\_CLK*x*) Register (D[3:0]/0x5308/0x5368)

| Prescaler output clock | T16EDF[3:0]                                                                                                                                  | Prescaler output clock                                                                                                                                                                                                           |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved               | 0x7                                                                                                                                          | PCLK-1/128                                                                                                                                                                                                                       |
| PCLK-1/16384           | 0x6                                                                                                                                          | PCLK-1/64                                                                                                                                                                                                                        |
| PCLK-1/8192            | 0x5                                                                                                                                          | PCLK-1/32                                                                                                                                                                                                                        |
| PCLK-1/4096            | 0x4                                                                                                                                          | PCLK-1/16                                                                                                                                                                                                                        |
| PCLK-1/2048            | 0x3                                                                                                                                          | PCLK-1/8                                                                                                                                                                                                                         |
| PCLK-1/1024            | 0x2                                                                                                                                          | PCLK-1/4                                                                                                                                                                                                                         |
| PCLK-1/512             | 0x1                                                                                                                                          | PCLK-1/2                                                                                                                                                                                                                         |
| PCLK-1/256             | 0x0                                                                                                                                          | PCLK-1/1                                                                                                                                                                                                                         |
|                        | Reserved           PCLK-1/16384           PCLK-1/8192           PCLK-1/4096           PCLK-1/2048           PCLK-1/1024           PCLK-1/512 | Reserved         0x7           PCLK-1/16384         0x6           PCLK-1/8192         0x5           PCLK-1/4096         0x4           PCLK-1/2048         0x3           PCLK-1/1024         0x2           PCLK-1/512         0x1 |

#### Table 13.2.1: Prescaler clock selection

(Default: 0x0)

#### Note: • The prescaler must run before operating the PWM & capture timer in internal clock mode.

• Make sure the PWM & capture timer count is halted before changing count clock settings.

For detailed information on the prescaler control, see "9 Prescaler (PSC)."

#### External clock mode

In external clock mode, channel 0 uses the clock or pulse input via the P00 (EXCL3) port, while channel 1 uses the clock or pulse input via the P01 (EXCL4) port as the count clock. They can therefore also be used as an event counter. Timer operations other than input clock are the same as for internal clock mode.

The input/output port used for external clock/pulse input should be set to input mode (the default value). No pin function needs to be selected. While the input/output port functions as a general input, the input signal is also sent to the PWM & capture timer.

The PWM & capture timer increments counts based on the input signal rising edge.

The PWM & capture timer does not use the prescaler in this mode. If no other peripheral modules are using the prescaler clock, the prescaler can be stopped to reduce current consumption.

### 13.3 Setting and Resetting Counter Value

The PWM & capture timer counter can be reset to 0 by writing 1 to the T16ERST bit (D1/T16E\_CTLx register).

\* **T16ERST**: Timer Reset Bit in the PWM Timer Ch.x Control (T16E\_CTLx) Register (D1/0x5306/0x5366)

Normally, the counter should be reset by writing 1 to this bit before starting the count.

The counter is reset by hardware if the counter matches compare data B after the count starts.

The counter can also be set to any desired value by writing data to T16ETC[15:0] (D[15:0]/T16E\_TC register).

\* T16ETC[15:0]: Counter Data in the PWM Timer Ch.x Counter Data (T16E\_TCx) Register (D[15:0]/0x5304/0x5364)

### 13.4 Compare Data Settings

#### Compare data register/buffer selection

The PWM & capture timer incorporates a data comparator allowing comparison of counter data against any desired value. This comparison data is stored in the compare data A and B registers. Data can be read or written directly to or from the compare data registers.

The compare data buffers enable automatic loading to the compare data registers of the comparison values set in the buffers when the counter is reset by software (writing 1 to T16ERST) or by a compare B match signal. The CBUFEN (D5/T16E\_CTLx resister) is used to set which of the compare data register and buffer the comparison values are written to.

\* CBUFEN: Comparison Buffer Enable Bit in the PWM Timer Control (T16E\_CTLx) Register (D5/0x5306/0x5366)

Writing 1 to CBUFEN selects the compare data buffer. Writing 0 to it selects the compare data register. The compare data register is selected after initial resetting.

#### Compare data writing

Compare data A is written to T16ECA[15:0] (D[15:0]/T16E\_CAx register). Compare data B is written to T16ECB[15:0] (D[15:0]/T16E\_CBx register).

- \* **T16ECA[15:0]**: Compare Data A in the PWM Timer Ch.*x* Compare Data A (T16E\_CA*x*) Register (D[15:0]/0x5300/0x5360)
- \* **T16ECB[15:0]**: Compare Data B in the PWM Timer Ch.*x* Compare Data B (T16E\_CB*x*) Register (D[15:0]/0x5302/0x5362)

When CBUFEN is set to 0, the compare data register values can be read or written directly by these registers. When CBUFEN is set to 1, data is read from and written to these registers via the compare data buffers. The buffer contents are loaded into the compare data registers when the counter is reset.

The compare data registers and buffers are set to 0x0 after initial resetting.

The timer compares the count data against the compare data registers and generates a compare match signal if the values are equal. This compare match signal generates an interrupt and controls the clock (TOUTx/ TOUTNx signal) output externally.

Compare data B also determines the counter reset cycle. The counter reset cycle can be calculated as follows:

Counter reset interval= $\frac{CB + 1}{clk_in}$  [s]

Counter reset cycle =  $\frac{clk_in}{CB+1}$  [Hz]

CB: Compare data B (T16E\_CBx register value) clk\_in: Prescaler output clock frequency

### 13.5 PWM & Capture Timer RUN/STOP Control

Set the following before starting the PWM & capture timer.

- (1) Set the operating mode (input clock). See Section 13.2.
- (2) Set the clock output. See Section 13.6.
- (3) If using interrupts, set the interrupt level and permit interrupts for the PWM & capture timer. See Section 13.7.
- (4) Set the counter value or reset to 0. See Section 13.3.
- (5) Set the compare data. See Section 13.4.

The PWM & capture timer includes T16ERUN (D0/T16E\_CTLx register) to control Run/Stop.

\* T16ERUN: Timer Run/Stop Control Bit in the PWM Timer Ch.x Control (T16E\_CTLx) Register (D0/0x5306/0x5366)

The timer starts counting when T16ERUN is written as 1. Writing 0 to T16ERUN prevents clock input and stops the count.

This control does not affect the counter data. The counter data is retained even when the count is halted, allowing resumption of the count from that data.

If T16ERUN and T16ERST are written as 1 simultaneously, the timer starts counting after the reset.

If the counter matches the compare data A register setting during counting, a compare A match signal is output and a compare A interrupt factor generated.

Likewise, if the counter matches the compare data B register setting, a compare B match signal is output and a compare B interrupt factor generated. The counter is reset to 0 at the same time. If CBUFEN is set to 1, the value set in the compare data buffers is loaded into the compare data registers. If interrupts are permitted, an interrupt request is sent to the interrupt controller (ITC).

In either case, counting continues unaffected. For compare B, counting starts from the counter value 0.



Figure 13.5.1: Basic counter operation timing

### 13.6 Clock Output Control

The PWM & capture timer can generate a TOUT*x*/TOUTN*x* signal using the compare match signal. Figure 13.6.1 shows the PWM & capture timer clock output circuit.



Figure 13.6.1: PWM & capture timer clock output circuit

#### Initial output level settings

The default output level is 0 (Low level) while the TOUT*x* clock output is Off (TOUTN*x* output is High level). This can be changed to 1 (TOUT*x* = High level, TOUTN*x* = Low level) with INITOL (D8/T16E\_CTL*x* register).

\* INITOL: Initial Output Level Select Bit in the PWM Timer Ch.x Control (T16E\_CTLx) Register (D8/0x5306/0x5366)

The TOUT*x* initial output level is Low (TOUTN*x* output is High) when INITOL is 0 (the default value). Setting to 1 switches the initial output level to High (TOUTN*x* output is Low).

#### **Output signal polarity selection**

By default, an active High (normal Low) TOUTx output signal is generated (TOUTNx output signal is active Low). This logic can be inverted by INVOUT (D4/T16E\_CTLx register). Writing 1 to INVOUT causes the timer to generate an active Low (normal High) TOUTx signal (TOUTNx signal is active High).

\* **INVOUT**: Inverse Output Control Bit in the PWM Timer Ch.*x* Control (T16E\_CTL*x*) Register (D4/0x5306/0x5366)

Setting INVOUT to 1 also inverts the initial output level set for INITOL. See Figure 13.6.2 for more information on output waveforms.

#### **Output pin settings**

The TOUTx/TOUTNx signal generated here can be output from the following pins and can provide a programmable clock and PWM signal to external devices.

Ch.0: TOUT3 output  $\rightarrow$  TOUT3 (P26) pin, TOUTN3 output  $\rightarrow$  TOUTN3 (P27) pin

Ch.1: TOUT4 output  $\rightarrow$  TOUT4 (P04) pin, TOUTN4 output  $\rightarrow$  TOUTN4 (P05) pin

The pin used for output is set for input/output port use after initial resetting and switches to input mode. The pin then becomes high-impedance.

Switching the pin function to TOUT*x*/TOUTN*x* output outputs the level set by INITOL and INVOUT. After the timer output starts, the output is maintained at this level until changed by the counter value.

| INITOL | INVOUT | Initial output level |  |  |  |  |  |  |  |  |
|--------|--------|----------------------|--|--|--|--|--|--|--|--|
| 1      | 1      | Low                  |  |  |  |  |  |  |  |  |
| 1      | 0      | High                 |  |  |  |  |  |  |  |  |
| 0      | 1      | High                 |  |  |  |  |  |  |  |  |
| 0      | 0      | Low                  |  |  |  |  |  |  |  |  |

#### Table 13.6.1: Initial output level

#### Clock output start

To output the TOUT clock, program 1 to OUTEN (D2/T16E\_CTLx register). Writing 0 to OUTEN switches the output to the initial output level as set by INITOL and INVOUT.

\* **OUTEN**: Clock Output Enable Bit in the PWM Timer Ch.x Control (T16E\_CTLx) Register (D2/0x5306/0x5366)



#### When INVOUT = 0 (Active High)

The timer outputs Low level (initial output level at output start) until the counter matches the compare data A set in the T16E\_CAx register (0x5300/0x5360). When the counter reaches the next compare data A value, the output pin switches to High level, and a compare A interrupt factor is generated. If the counter subsequently counts up to compare data B set in the T16E\_CBx register (0x5302/0x5362), the counter is reset and the output pin is returned to the Low level. A compare B interrupt factor is also generated at the same time. The TOUTNx pins output the inverted signals described above.

#### When INVOUT = 1 (Active Low)

The timer outputs High level (inverted value of the initial output level at output start) until the counter matches the compare data A set in the T16E\_CAx register (0x5300/0x5360). When the counter reaches the next compare data A value, the output pin switches to Low level, and a compare A interrupt factor is generated. If the counter subsequently counts up to compare data B set in the T16E\_CBx register (0x5302/0x5362), the counter is reset and the output pin is returned to the High level. A compare B interrupt factor is also generated at the same time. The TOUTNx pins output the inverted signals described above.

#### **Clock output Fine mode settings**

With the default settings, the clock output changes at the input clock rising edge if the counter value matches the compare data A.

If the counter data register T16ETC[14:0] matches the compare data A register T16ECA0[15:1], the Fine mode clock output changes in accordance with the compare data A bit 0 (T16ECA0) value.

When T16ECA0 is 0: Changes at input clock rising edge.

When T16ECA0 is 1: Changes at half-cycle delayed input clock drop-off.



Figure 13.6.3: Fine mode clock output

The output duty can thus be adjusted in Fine mode in input clock half-cycle steps. Note that a pulse will be output with an input clock 1-cycle width when compare data A = 0 (same as for default). The maximum value for compare data B in Fine mode is  $2^{15} - 1 = 32,767$ , and the compare data A range will be 0 to (2 x compare data B - 1).

Fine mode is set by SELFM (D6/T16E\_CTLx register).

\* SELFM: Fine Mode Select Bit in the PWM Timer Ch.x Control (T16E\_CTLx) Register (D6/0x5306/0x5366)

Writing 1 to SELFM sets Fine mode. Fine mode is disabled after initial resetting.

#### Precautions

- (1) Compare data should be set with  $A \ge 0$  and  $B \ge 1$  when using the timer output. The minimum settings are A = 0 and B = 1, and the timer output cycle is half the input clock.
- (2) Setting compare data with A > B ( $A > B \times 2$  for Fine mode) generates a compare B match signal only. It does not generate a compare A match signal. In this case, the TOUT*x* output is fixed at Low (High when INVOUT = 1), and the TOUTN*x* output is fixed at High (Low when INVOUT = 1).

### 13.7 PWM & Capture Timer Interrupts

The T16E module includes functions for generating the following two kinds of interrupts:

- Compare A match interrupt
- Compare B match interrupt

The T16E module outputs a single interrupt signal shared by the above two interrupt factors to the interrupt controller (ITC). The interrupt flag within the T16E module should be read to identify the interrupt factor that occurred.

#### **Compare A match interrupt**

This interrupt request is generated when the counter matches the compare data A register setting during counting. It sets the interrupt flag CAIF (D0/T16E\_IFLGx register) within the T16E module to 1.

\* CAIF: Compare A Interrupt Flag in the PWM Timer Ch.x Interrupt Flag (T16E\_IFLGx) Register (D0/0x530c/0x536c)

To use this interrupt, set CAIE (D0/T16E\_IMSKx register) to 1. If CAIE is set to 0 (default), CAIF is not set to 1, and the interrupt request for this factor is not sent to the ITC.

\* CAIE: Compare A Interrupt Enable Bit in the PWM Timer Ch.x Interrupt Mask (T16E\_IMSKx) Register (D0/0x530a/0x536a)

If CAIF is set to 1, the T16E module outputs an interrupt request to the ITC. An interrupt is generated if the ITC and S1C17 core interrupt conditions are satisfied.

CAIF should be read and checked within the PWM & capture timer interrupt handler routine to determine whether the PWM & capture timer interrupt is attributable to compare A matching.

#### **Compare B match interrupt**

This interrupt request is generated when the counter matches the compare data B register setting during counting. It sets the interrupt flag CBIF (D1/T16E\_IFLGx register) within the T16E module to 1.

\* **CBIF**: Compare B Interrupt Flag in the PWM Timer Ch.*x* Interrupt Flag (T16E\_IFLG*x*) Register (D1/0x530c/0x536c)

To use this interrupt, set CBIE (D1/T16E\_IMSKx register) to 1. If CBIE is set to 0 (default), CBIF is not set to 1, and the interrupt request for this factor is not sent to the ITC.

\* CBIE: Compare B Interrupt Enable Bit in the PWM Timer Ch.x Interrupt Mask (T16E\_IMSKx) Register (D1/0x530a/0x536a)

If CAIF is set to 1, the T16E module outputs an interrupt request to the ITC. An interrupt is generated if the ITC and S1C17 core interrupt conditions are satisfied.

CAIF should be read and checked within the PWM & capture timer interrupt handler routine to determine whether the PWM & capture timer interrupt is attributable to compare A matching.

- Note: To prevent interrupt recurrences, the T16E module interrupt flags CAIF and CBIF must be reset within the interrupt handler routine following a PWM & capture timer interrupt.
  - To prevent generating unnecessary interrupts, reset the corresponding CAIF or CBIF before permitting compare A or compare B interrupts from CAIE or CBIE.

#### 13 PWM & CAPTURE TIMER (T16E)

#### Interrupt vectors

The PWM & capture timer interrupt vector numbers and vector addresses are listed below.

| Timer channel | Vector number | Vector address |  |  |  |  |  |  |  |  |
|---------------|---------------|----------------|--|--|--|--|--|--|--|--|
| T16E Ch.0     | 11 (0x0b)     | TTBR + 0x2c    |  |  |  |  |  |  |  |  |
| T16E Ch.1     | 21 (0x15)     | TTBR + 0x54    |  |  |  |  |  |  |  |  |

#### Table 13.7.1: PWM & capture timer interrupt vectors

#### Other interrupt settings

The ITC allows the priority of PWM & capture timer interrupts to be set between level 0 (the default value) and level 7 for each channel. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### **13.8 Control Register Details**

| Address |            | Register name                              | Function                                      |  |  |  |  |  |  |  |
|---------|------------|--------------------------------------------|-----------------------------------------------|--|--|--|--|--|--|--|
| 0x5300  | T16E_CA0   | PWM Timer Ch.0 Compare Data A Register     | Compare data A setting                        |  |  |  |  |  |  |  |
| 0x5302  | T16E_CB0   | PWM Timer Ch.0 Compare Data B Register     | Compare data B setting                        |  |  |  |  |  |  |  |
| 0x5304  | T16E_TC0   | PWM Timer Ch.0 Counter Data Register       | Counter data                                  |  |  |  |  |  |  |  |
| 0x5306  | T16E_CTL0  | PWM Timer Ch.0 Control Register            | Timer mode setting and timer RUN/STOP         |  |  |  |  |  |  |  |
| 0x5308  | T16E_CLK0  | PWM Timer Ch.0 Input Clock Select Register | Prescaler output clock selection              |  |  |  |  |  |  |  |
| 0x530a  | T16E_IMSK0 | PWM Timer Ch.0 Interrupt Mask Register     | Interrupt mask setting                        |  |  |  |  |  |  |  |
| 0x530c  | T16E_IFLG0 | PWM Timer Ch.0 Interrupt Flag Register     | Interrupt occurrence status display/resetting |  |  |  |  |  |  |  |
| 0x5360  | T16E_CA1   | PWM Timer Ch.1 Compare Data A Register     | Compare data A setting                        |  |  |  |  |  |  |  |
| 0x5362  | T16E_CB1   | PWM Timer Ch.1 Compare Data B Register     | Compare data B setting                        |  |  |  |  |  |  |  |
| 0x5364  | T16E_TC1   | PWM Timer Ch.1 Counter Data Register       | Counter data                                  |  |  |  |  |  |  |  |
| 0x5366  | T16E_CTL1  | PWM Timer Ch.1 Control Register            | Timer mode setting and timer RUN/STOP         |  |  |  |  |  |  |  |
| 0x5368  | T16E_CLK1  | PWM Timer Ch.1 Input Clock Select Register | Prescaler output clock selection              |  |  |  |  |  |  |  |
| 0x536a  | T16E_IMSK1 | PWM Timer Ch.1 Interrupt Mask Register     | Interrupt mask setting                        |  |  |  |  |  |  |  |
| 0x536c  | T16E_IFLG1 | PWM Timer Ch.1 Interrupt Flag Register     | Interrupt occurrence status display/resetting |  |  |  |  |  |  |  |

#### Table 13.8.1: PWM & capture timer register list

The PWM & capture timer registers are described in detail below. These are 16-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x5300/0x5360: PWM Timer Ch.x Compare Data A Register (T16E\_CAx)

| Register name | Address   | Bit   | Name         | Function       | Setting       | Init. | R/W | Remarks |
|---------------|-----------|-------|--------------|----------------|---------------|-------|-----|---------|
| PWM Timer     | 0x5300    | D15-0 | T16ECA[15:0] | Compare data A | 0x0 to 0xffff | 0x0   | R/W |         |
| Compare Data  | 0x5360    |       |              | T16ECA15 = MSB |               |       |     |         |
| A Register    | (16 bits) |       |              | T16ECA0 = LSB  |               |       |     |         |
| (T16E_CA)     |           |       |              |                |               |       |     |         |

Note: The "x" in register names indicates the channel number (0 or 1).

0x5300: PWM Timer Ch.0 Compare Data A Register (T16E\_CA0) 0x5360: PWM Timer Ch.1 Compare Data A Register (T16E\_CA1)

#### D[15:0] T16ECA[15:0]: Compare Data A

Sets the PWM & capture timer compare data A. (Default: 0x0)

When CBUFEN (D5/T16E\_CTLx register) is set to 0, this register can be used to directly read from or directly program to the compare data A register.

When CBUFEN is set to 1, data is read from and written to these registers via the compare data A buffer. The buffer contents are loaded into the compare data A register when the counter is reset.

The data set is compared against the counter data, and a compare A interrupt factor is generated if the contents match. The timer output waveform changes at the same time (rising when INVOUT (D4/ T16E\_CTLx register) = 0 and trailing when INVOUT = 1). These processes do not affect the counter data or the count process.

#### 0x5302/0x5362: PWM Timer Ch.x Compare Data B Register (T16E\_CBx)

| Register name | Address   | Bit   | Name         | Function       | Setting       | Init. | R/W | Remarks |
|---------------|-----------|-------|--------------|----------------|---------------|-------|-----|---------|
| PWM Timer     | 0x5302    | D15-0 | T16ECB[15:0] | Compare data B | 0x0 to 0xffff | 0x0   | R/W |         |
| Compare Data  | 0x5362    |       |              | T16ECB15 = MSB |               |       |     |         |
| B Register    | (16 bits) |       |              | T16ECB0 = LSB  |               |       |     |         |
| (T16E_CB)     |           |       |              |                |               |       |     |         |

Note: The "*x*" in register names indicates the channel number (0 or 1).

0x5302: PWM Timer Ch.0 Compare Data A Register (T16E\_CB0) 0x5362: PWM Timer Ch.1 Compare Data A Register (T16E\_CB1)

#### D[15:0] T16ECB[15:0]: Compare Data B

Sets the PWM & capture timer compare data B. (Default: 0x0)

When CBUFEN (D5/T16E\_CTLx register) is set to 0, this register can be used to directly read from or directly program to the compare data B register.

When CBUFEN is set to 1, data is read from and written to these registers via the compare data B buffer. The buffer contents are loaded into the compare data B register when the counter is reset.

The data set is compared against the counter data, and a compare B interrupt factor is generated if the contents match. The timer output waveform changes at the same time (rising when INVOUT (D4/ T16E\_CTLx register) = 0 and trailing when INVOUT = 1). The counter is reset to 0.

### 0x5304/0x5364: PWM Timer Ch.x Counter Data Register (T16E\_TCx)

| Register name | Address   | Bit   | Name         | Function       | Setting       | Init. | R/W | Remarks |
|---------------|-----------|-------|--------------|----------------|---------------|-------|-----|---------|
| PWM Timer     | 0x5304    | D15–0 | T16ETC[15:0] | Counter data   | 0x0 to 0xffff | 0x0   | R/W |         |
| Ch.x Counter  | 0x5364    |       |              | T16ETC15 = MSB |               |       |     |         |
| Data Register | (16 bits) |       |              | T16ETC0 = LSB  |               |       |     |         |
| (T16E_TCx)    |           |       |              |                |               |       |     |         |

Note: The "x" in register names indicates the channel number (0 or 1).

0x5304: PWM Timer Ch.0 Counter Data Register (T16E\_TC0) 0x5364: PWM Timer Ch.1 Counter Data Register (T16E\_TC1)

### D[15:0] T16ETC[15:0]: Counter Data

Counter data can be read out. (Default: 0x0) The counter value can also be set by writing data to this register.

| Register name | Address   | Bit   | Name    | Function                 | Setting |           | 3 | Init.       | R/W | Remarks            |                    |
|---------------|-----------|-------|---------|--------------------------|---------|-----------|---|-------------|-----|--------------------|--------------------|
| PWM Timer     | 0x5306    | D15–9 | -       | reserved                 |         | -         |   | -           | -   | 0 when being read. |                    |
| Ch.x Control  | 0x5366    | D8    | INITOL  | Initial output level     | 1       | High      | 0 | Low         | 0   | R/W                |                    |
| Register      | (16 bits) | D7    | -       | reserved                 |         | -         | - |             | -   | -                  | 0 when being read. |
| (T16E_CTLx)   |           | D6    | SELFM   | Fine mode select         | 1       | Fine mode | 0 | Normal mode | 0   | R/W                |                    |
|               |           | D5    | CBUFEN  | Comparison buffer enable | 1       | Enable    | 0 | Disable     | 0   | R/W                |                    |
|               |           | D4    | INVOUT  | Inverse output           | 1       | Invert    | 0 | Normal      | 0   | R/W                |                    |
|               |           | D3    | CLKSEL  | Input clock select       | 1       | External  | 0 | Internal    | 0   | R/W                |                    |
|               |           | D2    | OUTEN   | Clock output enable      | 1       | Enable    | 0 | Disable     | 0   | R/W                |                    |
|               |           | D1    | T16ERST | Timer reset              | 1       | Reset     | 0 | Ignored     | 0   | W                  | 0 when being read. |
|               |           | D0    | T16ERUN | Timer run/stop control   | 1       | Run       | 0 | Stop        | 0   | R/W                |                    |

### 0x5306/0x5366: PWM Timer Ch.x Control Register (T16E\_CTLx)

Note: The "x" in register names indicates the channel number (0 or 1).

### 0x5306: PWM Timer Ch.0 Control Register (T16E\_CTL0) 0x5366: PWM Timer Ch.1 Control Register (T16E\_CTL1)

### D[15:9] Reserved

### D8 INITOL: Initial Output Level Bit

Sets the timer output initial output level. 1 (R/W): TOUTx = High, TOUTNx = Low 0(R/W): TOUTx = Low, TOUTNx = High (default)

The timer output pin switches to the initial output level set here when the clock output is switched off by writing 0 to OUTEN (D2). Note that this level will be inverted when INVOUT (D4) is 1.

### D7 Reserved

### D6 SELFM: Fine Mode Select Bit

Sets the clock output to Fine mode. 1 (R/W): Fine mode 0 (R/W): Normal output (default) When SELEM is set to 1, the clock

When SELFM is set to 1, the clock output is set to Fine mode, and the output clock duty becomes adjustable in input clock half-cycle steps.

When SELFM is set to 0, normal clock output is used.

### D5 CBUFEN: Comparison Buffer Enable Bit

Permits and prevents writing to the compare data buffer.

1 (R/W): Permitted

0 (R/W): Prohibited (default)

When CBUFEN is set to 1, compare data is read and written via the compare data buffer. The buffer contents are loaded into the compare data register when the counter is reset by software or compare B signal.

When CBUFEN is set to 0, compare data is read and written directly to and from the compare data register.

### D4 INVOUT: Inverse Output Control Bit

Selects the timer output signal polarity.

1 (R/W): Inverted (TOUTx = active Low, TOUTNx = active High) 0 (R/W): Normal (TOUTx = active High, TOUTNx = active Low) (default)

Writing 1 to INVOUT generates a TOUTx output active Low signal (Off level = High). When INVOUT is 0, an active High signal (Off level = Low) is generated.

Writing 1 to this bit also inverts the initial output level set by INITOL (D8). The signal level above is inverted for TOUTNx output.

D3 CLKSEL: Input Clock Select Bit

Selects the timer input clock. 1 (R/W): External clock 0 (R/W): Internal clock (default)

Writing 0 to CLKSEL selects the internal clock (prescaler output) as the timer input clock. Writing 1 selects an external clock (a clock entered from EXCL3 (P00) pin for Ch.0 and a clock from EXCL4 (P01) pin for Ch.1), and functions as an event counter.

The input/output port used for external clock/pulse input should be set to input mode (the default value). No pin function needs to be selected. While the input/output port functions as a general input, the input signal is also sent to the PWM & capture timer.

### D2 OUTEN: Clock Output Enable Bit

Controls the TOUT*x*/TOUTN*x* signal (timer output clock) output. 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Writing 1 to OUTEN outputs the TOUTx/TOUTNx signal from the corresponding output pin. Ch.0: TOUT3 output  $\rightarrow$  TOUT3 (P26) pin, TOUTN3 output  $\rightarrow$  TOUTN3 (P27) pin Ch.1: TOUT4 output  $\rightarrow$  TOUT4 (P04) pin, TOUTN4 output  $\rightarrow$  TOUTN4 (P05) pin

Writing 0 to OUTEN stops the output, and switches to the Off level corresponding to the settings for INVOUT (D4) and INITOL (D8). The above pins must be set to TOUTx/TOUTNx output using the port function selection register before outputting the TOUTx/TOUTNx signals.

### D1 T16ERST: Timer Reset Bit

Resets the counter.

- 1 (W): Reset
- 0 (W): Disabled
- 0 (R): Normally 0 when read out (default)

Writing 1 to T16ERST resets the PWM & capture timer counter.

### D0 T16ERUN: Timer Run/Stop Control Bit

Controls the timer Run/Stop.

1 (R/W): Run

0 (R/W): Stop (default)

The PWM & capture timer starts the count when T16ERUN is written as 1 and stops when written as 0. The counter data is retained when stopped until the subsequent reset or run. Counting can be resumed when switched from Stop to Run from the data retained.

| Register name | Address   | Bit   | Name        | Function                 | Se          | etting       | Init. | R/W | Remarks            |
|---------------|-----------|-------|-------------|--------------------------|-------------|--------------|-------|-----|--------------------|
| PWM Timer     | 0x5308    | D15–4 | -           | reserved                 |             | -            | -     | -   | 0 when being read. |
| CH.x Input    | 0x5368    | D3-0  | T16EDF[3:0] | Timer input clock select | T16EDF[3:0] | Clock        | 0x0   | R/W |                    |
| Clock Select  | (16 bits) |       |             | (Prescaler output clock) | 0xf         | reserved     |       |     |                    |
| Register      |           |       |             |                          | 0xe         | PCLK-1/16384 |       |     |                    |
| (T16E CLKx)   |           |       |             |                          | 0xd         | PCLK-1/8192  |       |     |                    |
| · _ /         |           |       |             |                          | 0xc         | PCLK-1/4096  |       |     |                    |
|               |           |       |             |                          | 0xb         | PCLK-1/2048  |       |     |                    |
|               |           |       |             |                          | 0xa         | PCLK-1/1024  |       |     |                    |
|               |           |       |             |                          | 0x9         | PCLK-1/512   |       |     |                    |
|               |           |       |             |                          | 0x8         | PCLK-1/256   |       |     |                    |
|               |           |       |             |                          | 0x7         | PCLK-1/128   |       |     |                    |
|               |           |       |             |                          | 0x6         | PCLK-1/64    |       |     |                    |
|               |           |       |             |                          | 0x5         | PCLK-1/32    |       |     |                    |
|               |           |       |             |                          | 0x4         | PCLK-1/16    |       |     |                    |
|               |           |       |             |                          | 0x3         | PCLK-1/8     |       |     |                    |
|               |           |       |             |                          | 0x2         | PCLK-1/4     |       |     |                    |
|               |           |       |             |                          | 0x1         | PCLK-1/2     |       |     |                    |
|               |           |       |             |                          | 0x0         | PCLK-1/1     |       |     |                    |

### 0x5308/0x5368: PWM Timer Ch.x Input Clock Select Register (T16E\_CLKx)

Note: The "x" in register names indicates the channel number (0 or 1).

0x5308: PWM Timer Ch.0 Input Clock Select Register (T16E\_CLK0) 0x5368: PWM Timer Ch.1 Input Clock Select Register (T16E\_CLK1)

### D[15:4] Reserved

### D[3:0] T16EDF[3:0]: Timer Input Clock Select Bits

Select the PWM & capture timer count clock from the 15 different prescaler output clocks.

| T16EDF[3:0] | Prescaler output clock | T16EDF[3:0] | Prescaler output clock |
|-------------|------------------------|-------------|------------------------|
| 0xf         | Reserved               | 0x7         | PCLK-1/128             |
| 0xe         | PCLK-1/16384           | 0x6         | PCLK-1/64              |
| 0xd         | PCLK-1/8192            | 0x5         | PCLK-1/32              |
| 0xc         | PCLK-1/4096            | 0x4         | PCLK-1/16              |
| 0xb         | PCLK-1/2048            | 0x3         | PCLK-1/8               |
| 0xa         | PCLK-1/1024            | 0x2         | PCLK-1/4               |
| 0x9         | PCLK-1/512             | 0x1         | PCLK-1/2               |
| 0x8         | PCLK-1/256             | 0x0         | PCLK-1/1               |

#### Table 13.8.2: Count clock selection

(Default: 0x0)

Note: Make sure the PWM & capture timer count is halted before changing count clock settings.

### 0x530a/0x536a: PWM Timer Ch.x Interrupt Mask Registers (T16E\_IMSKx)

| Register name  | Address   | Bit   | Name | Function                   | Setting |        | Init. | R/W     | Remarks |     |                    |
|----------------|-----------|-------|------|----------------------------|---------|--------|-------|---------|---------|-----|--------------------|
| PWM Timer Ch.x | 0x530a    | D15–2 | -    | reserved                   |         | _      | -     |         | -       | -   | 0 when being read. |
| Interrupt      | 0x536a    |       |      |                            |         |        |       |         |         | -   |                    |
| Mask Register  | (16 bits) | D1    | CBIE | Compare B interrupt enable | 1       | Enable | 0     | Disable | 0       | R/W |                    |
| (T16E_IMSKx)   |           | D0    | CAIE | Compare A interrupt enable | 1       | Enable | 0     | Disable | 0       | R/W |                    |

Note: The "x" in register names indicates the channel number (0 or 1).

0x530a: PWM Timer Ch.0 Interrupt Mask Register (T16E\_IMSK0) 0x536a: PWM Timer Ch.1 Interrupt Mask Register (T16E\_IMSK1)

### D[15:2] Reserved

D1 CBIE: Compare B Interrupt Enable Bit

Permits or prohibits compare B match interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)

Setting CBIE to 1 permits compare B interrupt requests to the ITC. Setting it to 0 prohibits interrupts.

### D0 CAIE: Compare A Interrupt Enable Bit

Permits or prohibits compare A match interrupts. 1 (R/W): Interrupt permitted

0 (R/W): Interrupt prohibited (default)

Setting CAIE to 1 permits compare A interrupt requests to the ITC. Setting it to 0 prohibits interrupts.

### 0x530c/0x536c: PWM Timer Ch.x Interrupt Flag Registers (T16E\_IFLGx)

| Register name                          | Address   | Bit   | Name | Function                 | Setting |                       |                           | Init. | R/W | Remarks             |
|----------------------------------------|-----------|-------|------|--------------------------|---------|-----------------------|---------------------------|-------|-----|---------------------|
| PWM Timer Ch.x                         | 0x530c    | D15–2 | -    | reserved                 |         | -                     |                           | -     | -   | 0 when being read.  |
| Interrupt                              | 0x536c    | D1    | CBIF | Compare B interrupt flag | 1       |                       | 0 Cause of                |       | R/W | Reset by writing 1. |
| Flag Register<br>(T16E_IFLG <i>x</i> ) | (16 bits) | D0    | CAIF | Compare A interrupt flag | 1       | interrupt<br>occurred | interrupt not<br>occurred | 0     | R/W |                     |

Note: The "x" in register names indicates the channel number (0 or 1).

0x530c: PWM Timer Ch.0 Interrupt Flag Register (T16E\_IFLG0) 0x536c: PWM Timer Ch.1 Interrupt Flag Register (T16E\_IFLG1)

### D[15:2] Reserved

### D1 CBIF: Compare B Interrupt Flag

Interrupt flag indicating the compare B interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

CBIF is the interrupt flag corresponding to compare B interrupts. Setting CBIE (D1/T16E\_IMSK*x*) to 1 sets this to 1 when the counter matches the compare data B register setting during counting. A PWM & capture timer interrupt request signal is output to the ITC at the same time. This interrupt request signal generates an interrupt if the ITC and S1C17 core interrupt conditions are satisfied. CBIF is reset by writing 1.

### D0 CAIF: Compare A Interrupt Flag

Interrupt flag indicating the compare A interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

CAIF is the interrupt flag corresponding to compare A interrupts. Setting CAIE (D0/T16E\_IMSKx) to 1 sets this to 1 when the counter matches the compare data A register setting during counting. A PWM & capture timer interrupt request signal is output to the ITC at the same time. This interrupt request signal generates an interrupt if the ITC and S1C17 core interrupt conditions are satisfied. CAIF is reset by writing 1.

## Note: • To prevent interrupt recurrences, T16E module interrupt flags CAIF and CBIF must be reset within the interrupt handler routine following a PWM & capture timer interrupt.

 To prevent generating unnecessary interrupts, reset the corresponding CAIF or CBIF before permitting compare A or compare B interrupts from CAIE (D0/T16E\_IMSK*x*) or CBIE (D1/ T16E\_IMSK*x*).

## **13.9 Precautions**

- The prescaler must run before operating the PWM & capture timer.
- Make sure the PWM & capture timer count is halted before changing count clock settings.
- Compare data should be set with  $A \ge 0$  and  $B \ge 1$  when using the timer output. The minimum settings are A = 0 and B = 1, and the timer output cycle is half the input clock.
- Setting compare data with A > B (A > B x 2 for Fine mode) generates a compare B match signal only. It does not generate a compare A match signal. In this case, the timer output is fixed at Low (High when INVOUT = 1).
- To prevent interrupt recurrences, the T16E module interrupt flags CAIF (D0/T16E\_INTx register) and CBIF (D1/T16E\_INTx register) must be reset within the interrupt handler routine following a PWM & capture timer interrupt.
- To prevent generating unnecessary interrupts, reset the corresponding CAIF (D0/T16E\_IFLGx register) or CBIF (D1/T16E\_IFLGx register) before permitting compare A or compare B interrupts from CAIE (D0/T16E\_IMSKx register) or CBIE (D1/T16E\_IMSKx register).

# 14 8-bit OSC1 Timer (T8OSC1)

## 14.1 8-bit OSC1 Timer Overview

The S1C17702 incorporates a single-channel 8-bit OSC1 timer that uses the OSC1 clock as its oscillation source. Figure 14.1.1 illustrates the 8-bit OSC1 timer configuration.



The 8-bit OSC1 timer includes an 8-bit up-counter (T8OOSC1\_CNT register), an 8-bit compare data register (T8OSC1\_CMP register), and an 8-bit PWM duty data register (T8OSC1\_DUTY register).

The 8-bit counter can be reset to 0 by software and counts up using the OSC1 division clock (OSC1-1/1 to OSC1-1/32). The count value can be read by software.

The compare data and PWM duty registers store the data used for comparisons against up-counter contents. If the counter values match the contents of each data register, the comparator outputs a signal to control the interrupts and the PWM output signal. The compare data register can be used to set the interrupt generating and PWM output clock frequencies. The PWM duty data register can be used to set the PWM output clock duty ratio.

## 14.2 8-bit OSC1 Timer Count Mode

The 8-bit OSC1 timer features two count modes: Repeat mode and One-shot mode. These modes are selected using the T8ORMD bit (D1/T8OSC1\_CT register).

\* T8ORMD: Count Mode Select Bit in the 8-bit OSC1 Timer Control (T8OSC1\_CTL) Register (D1/0x50c0)

### Repeat mode (T8ORMD = 0, default)

Setting T8ORMD to 0 sets the 8-bit OSC1 timer to Repeat mode.

In this mode, once the count starts, the 8-bit OSC1 timer continues running until stopped by the application program. If the counter matches the compare data, the timer resets the counter and continues counting. The interrupt signal is output at the same time. The 8-bit OSC1 timer should be set to this mode to generate periodic interrupts at desired intervals or to perform PWM output.

### One-shot mode (T8ORMD = 1)

Setting T8ORMD to 1 sets the 8-bit OSC1 timer to One-shot mode.

In this mode, the 8-bit OSC1 timer stops automatically as soon as the counter matches the compare data. This means only one interrupt can be generated after the timer starts. Note that the timer resets the counter, then stops after a complete match has occurred. The 8-bit OSC1 timer should be set to this mode to set a specific wait time.

Note: • Make sure the 8-bit OSC1 timer count is halted before changing count mode settings.

• The counter will not be stopped and one-shot mode will not operate if a compare match arises while the CPU is halted, even when counting is in progress with one-shot mode set.

## 14.3 Count Clock

The 8-bit OSC1 timer uses the OSC1 division clock output by the OSC module as the count clock. The OSC module generates 6 different clocks by dividing the OSC1 clock into 1/1 to 1/32 divisions. One of these is selected by T8O1CK[2:0] (D[3:1]/OSC\_T8OSC1 register).

\* T8O1CK[2:0]: T8OSC1 Clock Division Ratio Select Bits in the T8OSC1 Clock Control (OSC\_T8OSC1) Register (D[3:1]/0x5065)

| 14010 14.0.1. | Obdite Clock Sciection |
|---------------|------------------------|
| T8O1CK[2:0]   | Division ratio         |
| 0x7 to 0x6    | Reserved               |
| 0x5           | OSC1-1/32              |
| 0x4           | OSC1-1/16              |
| 0x3           | OSC1-1/8               |
| 0x2           | OSC1-1/4               |
| 0x1           | OSC1-1/2               |
| 0x0           | OSC1-1/1               |
|               | (Default: 0x0)         |

The clock feed to the 8-bit OSC1 timer is controlled using T8O1CE (D0/OSC\_T8OSC1 register). The T8O1CE default setting is 0, which stops the clock feed. Setting T8O1CE to 1 sends the clock generated as above to the 8-bit OSC1 timer. If 8-bit OSC1 timer operation is not required, the clock feed should be stopped to reduce power consumption.

\* T801CE: T80SC1 Clock Enable Bit in the T80SC1 Clock Control (OSC\_T80SC1) Register (D0/0x5065)

### Note: Make sure the 8-bit OSC1 timer count is halted before changing count clock settings.

For detailed information on clock control, refer to "7 Oscillator Circuit (OSC)."

## 14.4 Resetting 8-bit OSC1 Timer

The 8-bit OSC1 Timer can be reset to 0 by writing 1 to the T8ORS bit (D4/T8OSC1\_CTL register).

\* T80RST: Timer Reset Bit in the 8-bit OSC1 Timer Control (T8OSC1\_CTL) Register (D4/0x50c0)

Normally, the counter should be reset by writing 1 to this bit before starting the count. The counter is reset by hardware if the counter matches compare data after the count starts.

## 14.5 Compare Data Settings

Compare data is written to T8OCMP[7:0] (D[7:0]/T8OSC1\_CMP register).

\* T80CMP[7:0]: Compare Data Bits in the 8-bit OSC1 Timer Compare Data (T80SC1\_CMP) Register (D[7:0]/0x50c2)

After initial resetting, the compare data register is set to 0x0.

The timer compares the count data against the compare data register and generates a compare match signal as well as resets the counter if the values are equal. This compare match signal can generate an interrupt. The compare match cycle can be calculated as follows:

Compare match interval =  $\frac{\text{CMP} + 1}{\text{clk}_{in}}$  [s]

Compare match cycle =  $\frac{\text{clk}_{\text{in}}}{\text{CMP} + 1}$  [Hz]

CMP: Compare data (T8OSC1\_CMP register value) clk\_in: 8-bit OSC1 timer count clock frequency

When the 8-bit OSC1 timer is used to generate a PWM signal, the compare data determines the frequency of the output signal. (For a discussion of PWM output, refer to Section 14.8.)

## 14.6 8-bit OSC1 Timer RUN/STOP Control

Set the following items before starting the 8-bit OSC1 timer.

- (1) Set the count mode (One-shot or Repeat). See Section 14.2.
- (2) Select the operation clock. See Section 14.3.

(3) If using interrupts, set the interrupt level and permit interrupts for the 8-bit OSC1 timer. See Section 14.7.

- (4) Reset the timer. See Section 14.4.
- (5) Set the compare data. See Section 14.5.

(6) To output PWM signals, set the PWM duty data. See Section 14.8.

The 8-bit OSC1 timer includes T8ORUN (D0/T8OSC1\_CTL register) to control Run/Stop.

\* T8ORUN: Timer Run/Stop Control Bit in the 8-bit OSC1 Timer Control (T8OSC1\_CTL) Register (D0/0x50c0)

The timer starts counting when T8ORUN is written as 1. Writing 0 to T8ORUN prevents clock input and stops the count.

This control does not affect the counter data. The counter data is retained even when the count is halted, allowing resumption of the count from that data.

If T8ORUN and T8ORST are written as 1 simultaneously, the timer starts counting after the reset.

If the counter matches the compare data register setting during counting, a compare match signal is output and a compare interrupt factor generated.

Likewise, if the counter matches the compare data B register setting, a compare B match signal is output and a compare B interrupt factor generated. The counter is reset to 0 at the same time.

If interrupts are permitted, an interrupt request is sent to the interrupt controller (ITC).

If One-shot mode is set, the timer stops the count.

If Repeat mode is set, the timer continues to count from 0.



## 14.7 8-bit OSC1 Timer Interrupts

The T8OSC1 module outputs an interrupt request to the interrupt controller (ITC) by compare match.

### **Compare match interrupt**

This interrupt request is generated when the counter matches the compare data register setting during counting. It sets the interrupt flag T80IF (D0/T80SC1\_IFLG register) within the T80SC1 module to 1.

\* **T80IF**: 8-bit OSC1 Timer Interrupt Flag in the 8-bit OSC1 Timer Interrupt Flag (T8OSC1\_IFLG) Register (D0/0x50c4)

To use this interrupt, set T8OIE (D0/T8OSC1\_IMSK register) to 1. If T8OIE is set to 0 (default), T8OIE is not set to 1, and the interrupt request for this factor is not sent to the ITC.

\* **T8OIE**: 8-bit OSC1 Timer Interrupt Enable Bit in the 8-bit OSC1 Timer Interrupt Mask (T8OSC1\_IMSK) Register (D0/0x50c3)

If T8OIF is set to 1, the T8OSC1 module outputs an interrupt request to the ITC. This interrupt request signal generates an interrupt if the ITC and S1C17 core interrupt conditions are satisfied.

- Note: To prevent interrupt recurrences, the T8OSC1 module interrupt flag T8OIF must be reset within the interrupt handler routine following an 8-bit OSC1 timer interrupt.
  - To prevent generating unnecessary interrupts, reset the corresponding T8OIF before permitting compare 8-bit OSC1 interrupts from T8OIE.

### Interrupt vectors

The 8-bit OSC timer interrupt vector numbers and vector addresses are listed below.

Vector number: 8 (0x08) Vector address: TTBR + 0x20

### Other interrupt settings

The ITC allows the priority of 8-bit OSC1 timer interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

## 14.8 PWM output

The 8-bit OSC1 timer can generate a PWM signal in accordance with the compare data and PWM duty data settings and output it from the TOUT5 (P16) pin.

### **Output pin setting**

The PWM output pin (TOUT5) also acts as a pin (P16) for a general-purpose input/output port. In the default state, this pin is set as a general-purpose input/output port pin. To use it as a PWM output pin, change the function by setting the value 1 in the P16MUX (D6/P1\_PMUX register).

\* P16MUX: P16 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D6/0x52a1)

### **PWM** waveform control

The PWM waveform frequency can be set by the compare data register (0x50c2) (see Section 14.5). The duty ratio can be adjusted by the PWM duty data register (0x50c5).

The timer outputs a Low level signal until the counter value matches the value of the PWM duty data register. When the counter value exceeds the value of the PWM duty data, the output pin changes to High. Once the counter counts up to the compare data register value, the counter is reset and the output pin returns to Low. Figure 14.8.1 shows the output waveform.



Figure 14.8.1 PWM output waveform

### Precautions

- (1) When using the timer output, set the following: PWM duty data  $\ge 0$ , compare data  $\ge 1$ . The minimum setting value is 0 for PWM duty data and 1 for compare data. The timer output cycle is 1/2 of the input clock.
- (2) When the PWM duty data is set greater than the compare data, only the compare match signal will be generated. No duty match signal will be generated. In that case, the TOUT5 output is fixed to Low.

## **14.9 Control Register Details**

|         |             |                                          | i regioter not                                |
|---------|-------------|------------------------------------------|-----------------------------------------------|
| Address |             | Register name                            | Function                                      |
| 0x50c0  | T8OSC1_CTL  | 8-bit OSC1 Timer Control Register        | Timer mode setting and timer RUN/STOP         |
| 0x50c1  | T8OSC1_CNT  | 8-bit OSC1 Timer Counter Data Register   | Counter data                                  |
| 0x50c2  | T8OSC1_CMP  | 8-bit OSC1 Timer Compare Data Register   | Compare data setting                          |
| 0x50c3  | T8OSC1_IMSK | 8-bit OSC1 Timer Interrupt Mask Register | Interrupt mask setting                        |
| 0x50c4  | T8OSC1_IFLG | 8-bit OSC1 Timer Interrupt Flag Register | Interrupt occurrence status display/resetting |
| 0x50c5  | T8OSC1_DUTY | 8-bit OSC1 Timer PWM Duty Data Register  | PWM output data setting                       |

Table 14.9.1: 8-bit OSC1 timer register list

The 8-bit OSC1 timer registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

| Register name | Address  | Bit  | Name   | Function               | Setting |          |   | Init.   | R/W | Remarks |                    |
|---------------|----------|------|--------|------------------------|---------|----------|---|---------|-----|---------|--------------------|
| 8-bit OSC1    | 0x50c0   | D7–5 | -      | reserved               |         | -        | - |         | -   | -       | 0 when being read. |
| Timer Control | (8 bits) | D4   | T8ORST | Timer reset            | 1       | Reset    | 0 | Ignored | 0   | W       |                    |
| Register      |          | D3–2 | -      | reserved               |         | -        | - |         | -   | -       |                    |
| (T8OSC1_CTL)  |          | D1   | T8ORMD | Count mode select      | 1       | One shot | 0 | Repeat  | 0   | R/W     |                    |
|               |          | D0   | T8ORUN | Timer run/stop control | 1       | Run      | 0 | Stop    | 0   | R/W     |                    |

### 0x50c0: 8-bit OSC1 Timer Control Register (T8OSC1\_CTL)

### D[7:5] Reserved

### D4 T8ORST: Timer Reset Bit

Resets the 8-bit OSC1 timer.

1 (W): Reset

0 (W): Disabled

0 (R): Normally 0 when read out (default)

Writing 1 to this bit resets the counter to 0.

### D[3:2] Reserved

### D1 T8ORMD: Count Mode Select Bit

Selects the 8-bit OSC1 timer count mode.

1 (R/W): One-shot mode

0 (R/W): Repeat mode (default)

Setting T8ORMD to 0 sets the 8-bit OSC1 timer to Repeat mode. In this mode, once the count starts, the 8-bit timer continues to run until stopped by the application. If the counter matches the compare data register value, the timer resets the counter and continues counting. This means the timer periodically outputs a compare match signal. Set the 8-bit OSC1 timer to this mode to generate periodic interrupts at the desired interval or to perform PWM output.

Setting T8ORMD to 1 sets the 8-bit OSC1 timer to One-shot mode. In this mode, the 8-bit OSC1 timer stops automatically when the counter matches the compare data register value. This means an interrupt can be generated only once after the timer has been started. Note that the timer resets the counter and then stops after a compare match has occurred. Set the 8-bit OSC1 timer to this mode to create a specific wait time.

### Note: Set the count mode only while the 8-bit OSC1 timer count is stopped.

### D0 T8ORUN: Timer Run/Stop Control Bit

Controls the timer RUN/STOP. 1 (R/W): Run 0 (R/W): Stop (default)

The timer starts counting when T8ORUN is written as 1 and stops when written as 0. When the timer is stopped, the counter data is retained until reset or until the next RUN state.

### 0x50c1: 8-bit OSC1 Timer Counter Data Register (T8OSC1\_CNT)

| Register name               | Address            | Bit  | Name | Function                            | Setting     | Init. | R/W | Remarks |
|-----------------------------|--------------------|------|------|-------------------------------------|-------------|-------|-----|---------|
| 8-bit OSC1<br>Timer Counter | 0x50c1<br>(8 bits) | D7–0 |      | Timer counter data<br>T8OCNT7 = MSB | 0x0 to 0xff | 0x0   | R   |         |
| Data Register               | (0 01(3)           |      |      | T8OCNT0 = LSB                       |             |       |     |         |
| (T8OSC1_CNT)                |                    |      |      |                                     |             |       |     |         |

### D[7:0] T8OCNT[7:0]: Counter Data

Reads out the counter data. (Default: 0x0)

This register is read-only and cannot be written to.

## Note: The correct counter value may not be read out (reading is unstable) if the register is read while counting is underway.

Obtain the counter value by one of the following methods:

- Read the counter value while the counter is halted.
- Read the counter twice in succession. Treat the value as valid if the values read are identical.

### 0x50c2: 8-bit OSC1 Timer Compare Data Register (T8OSC1\_CMP)

| Register name | Address  | Bit  | Name        | Function      | Setting     | Init. | R/W | Remarks |
|---------------|----------|------|-------------|---------------|-------------|-------|-----|---------|
| 8-bit OSC1    | 0x50c2   | D7–0 | T8OCMP[7:0] | Compare data  | 0x0 to 0xff | 0x0   | R/W |         |
| Timer Compare | (8 bits) |      |             | T8OCMP7 = MSB |             |       |     |         |
| Data Register |          |      |             | T8OCMP0 = LSB |             |       |     |         |
| (T8OSC1_CMP)  |          |      |             |               |             |       |     |         |

### D[7:0] T8OCMP[7:0]: Compare Data

Sets the 8-bit OSC1 timer compare data. (Default: 0x0)

The data set is compared against the counter data, and a compare match interrupt factor is generated if the contents match. And the counter is reset to 0.

### 0x50c3: 8-bit OSC1 Timer Interrupt Mask Register (T8OSC1\_IMSK)

| Register name   | Address  | Bit  | Name  | Function                          | Setting            | lnit. | R/W | Remarks            |
|-----------------|----------|------|-------|-----------------------------------|--------------------|-------|-----|--------------------|
| 8-bit OSC1      | 0x50c3   | D7–1 | -     | reserved                          | -                  | -     | -   | 0 when being read. |
| Timer Interrupt | (8 bits) | D0   | T8OIE | 8-bit OSC1 timer interrupt enable | 1 Enable 0 Disable | 0     | R/W |                    |
| Mask Register   |          |      |       | -                                 |                    |       |     |                    |
| (T8OSC1_IMSK)   |          |      |       |                                   |                    |       |     |                    |

### D[7:1] Reserved

### D0 T80IE: 8-bit OSC1 Timer Interrupt Enable Bit

Permits or prohibits compare match interrupts.

1 (R/W): Interrupt permitted

0 (R/W): Interrupt prohibited (default)

Setting T8OIE to 1 permits 8-bit OSC1 timer interrupt requests to the ITC. Setting it to 0 prohibits interrupts.

### 0x50c4: 8-bit OSC1 Timer Interrupt Flag Register (T8OSC1\_IFLG)

| Register name   | Address  | Bit  | Name  | Function                        | Setting |           |   | Init.         | R/W | Remarks            |                     |
|-----------------|----------|------|-------|---------------------------------|---------|-----------|---|---------------|-----|--------------------|---------------------|
| 8-bit OSC1      | 0x50c4   | D7–1 | -     | reserved                        | -       |           |   | -             | -   | 0 when being read. |                     |
| Timer Interrupt | (8 bits) | D0   | T8OIF | 8-bit OSC1 timer interrupt flag | 1       | Cause of  | 0 | Cause of      | 0   | R/W                | Reset by writing 1. |
| Flag Register   |          |      |       |                                 |         | interrupt |   | interrupt not |     |                    |                     |
| (T8OSC1_IFLG)   |          |      |       |                                 |         | occurred  |   | occurred      |     |                    |                     |

### D[7:1] Reserved

### D0 T8OIF: 8-bit OSC1 Timer Interrupt Flag

Interrupt flag indicating the compare match interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

T8OIF is the T8OSC1 module interrupt flag. Setting T8OIE (D0/T8OSC1\_IMSK register) to 1 sets this to 1 when the counter matches the compare data register setting during counting. An 8-bit OSC1 timer interrupt request signal output simultaneously to the ITC generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

T8OIF is reset by writing as 1.

- Note: To prevent interrupt recurrences, the T8OSC1 module interrupt flag T8OIF must be reset within the interrupt handler routine following an 8-bit OSC1 timer interrupt.
  - To prevent generating unnecessary interrupts, reset T8OIF before permitting compare match interrupts using T8OIE (D0/T8OSC1\_IMSK register).

### 0x50c5: 8-bit OSC1 Timer PWM Duty Data Register (T8OSC1\_DUTY)

| Register name             | Address            | Bit  | Name | Function                              | Setting     | Init. | R/W | Remarks |
|---------------------------|--------------------|------|------|---------------------------------------|-------------|-------|-----|---------|
| 8-bit OSC1<br>Timer PWM   | 0x50c5<br>(8 bits) | D7–0 |      | PWM output duty data<br>T8ODTY7 = MSB | 0x0 to 0xff | 0x0   | R/W |         |
| Duty Data                 | (*****)            |      |      | T8ODTY0 = LSB                         |             |       |     |         |
| Register<br>(T8OSC1_DUTY) |                    |      |      |                                       |             |       |     |         |

### D[7:0] T8ODTY[7:0]: PWM Output Duty Data

Sets the data that determines the duty ratio of PWM waveform. (default: 0x0)

The set data is compared against the counter data. If the contents match, the timer output waveform rises. If the counter data matches the compare data, the timer output waveform falls. These processes do not affect the counter data or count process.

## 14.10 Precautions

- The 8-bit OSC1 timer clock must be output from the OSC module before the 8-bit OSC1 timer begins running.
- Set the count clock and count mode only while the 8-bit OSC1 timer count is stopped.
- To prevent interrupt recurrences, the T8OSC1 module interrupt flag T8OIF (D0/T8OSC1\_IFLG register) must be reset within the interrupt handler routine following an 8-bit OSC1 timer interrupt.
- To prevent generating unnecessary interrupts, reset T80IF (D0/T80SC1\_IFLG register) before permitting compare match interrupts using T80IE (D0/T80SC1\_IMSK register).
- The correct counter value may not be read out (reading is unstable) if the counter data register is read while counting is underway.

To obtain the counter value, read the counter data register while the counter is halted or read the counter data register twice in succession. Treat the value as valid if the values read are identical.

- When using the PWM output, set the following: PWM duty data  $\ge 0$ , compare data  $\ge 1$ . The minimum setting value is 0 for PWM duty data and 1 for compare data. The timer output cycle is 1/2 of the input clock.
- When the PWM duty data is set greater than the compare data, only the compare match signal is generated. No duty match signal is generated. In that case, the TOUT5 output is fixed to Low.
- The counter will not be stopped and one-shot mode will not operate if a compare match arises while the CPU is halted, even when counting is in progress with one-shot mode set.

# **15 Clock Timer (CT)**

## **15.1 Clock Timer Overview**

The S1C17702 incorporates a single-channel clock timer that uses the OSC1 clock as its oscillation source.

The clock timer consists of an 8-bit binary counter that uses the 256 Hz signal divided from the OSC1 clock as the input clock and allows data for each bit (128 Hz to 1 Hz) to be read out by software.

The clock timer can also generate interrupts using the 32 Hz, 8 Hz, 2 Hz, and 1 Hz signals.

This clock timer is normally used for various timing functions, such as clocks.

Figure 15.1.1 illustrates the clock timer configuration.



## **15.2 Operation Clock**

The clock timer uses the 256 Hz clock output by the OSC module as the operation clock.

The OSC module generates this operation clock by dividing the OSC1 clock into 1/128, resulting in a frequency of 256 Hz when the OSC1 clock frequency is 32.768 kHz. The frequency described in this section will vary accordingly for other OSC1 clock frequencies.

The OSC module does not include a 256 Hz clock output control bit. The 256 Hz clock is normally fed to the clock timer when the OSC1 oscillation is on.

For detailed information on OSC1 oscillator circuit control, refer to "7 Oscillator Circuit (OSC)."

## **15.3 Clock Timer Resetting**

Reset the clock timer by writing 1 to the CTRST bit (D4/CT\_CTL register). This clears the counter to 0.

\* CTRST: Clock Timer Reset Bit in the Clock Timer Control (CT\_CTL) Register (D4/0x5000)

Apart from this operation, the counter is also cleared by initial resetting.

## 15.4 Clock Timer RUN/STOP Control

Set the following items before starting the clock timer.

(1) If using interrupts, set the interrupt level and permit interrupts for the clock timer. See Section 15.5.

(2) Reset the timer. See Section 15.3.

The clock timer includes CTRUN (D0/CT\_CTL register) to control Run/Stop.

\* CTRUN: Clock Timer Run/Stop Control Bit in the Clock Timer Control (CT\_CTL) Register (D0/0x5000)

The clock timer starts operating when CTRUN is written as 1. Writing 0 to CTRUN prevents clock input and stops the operation.

This control does not affect the counter (CT\_CNT register) data. The counter data is retained even when the count is halted, allowing resumption of the count from that data.

If CTRUN and CTRST are written as 1 simultaneously, the clock timer starts counting after the reset.

Interrupt factors are generated during counting at the corresponding 32 Hz, 8 Hz, 2 Hz, and 1 Hz signal falling edges. If interrupts are permitted, interrupt requests are sent to the interrupt controller (ITC).



Figure 15.4.1: Clock timer timing chart

Note: The clock timer switches to Run/Stop mode when data is written to CTRUN synchronized with the 256 Hz signal falling edge. When 0 is written to CTRUN, the timer switches to Stop state after counting an additional "+1." 1 is retained for CTRUN reading until the timer actually stops.

Figure 15.4.2 shows the Run/Stop control timing chart.



## **15.5 Clock Timer Interrupts**

The CT module includes functions for generating the following four kinds of interrupts:

32 Hz, 8 Hz, 2 Hz, 1 Hz interrupts

The CT module outputs a single interrupt signal shared by the above four interrupt factors to the interrupt controller (ITC). The interrupt flag within the CT module should be read to identify the interrupt factor that occurred.

### 32 Hz, 8 Hz, 2 Hz, 1 Hz interrupts

Generated at the 32 Hz, 8 Hz, 2 Hz, and 1 Hz signal falling edges, these interrupt requests set the following interrupt flags in the CT module to 1.

- \* CTIF32: 32 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D3/0x5003)
- \* CTIF8: 8 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D2/0x5003)
- \* CTIF2: 2 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D1/0x5003)
- \* CTIF1: 1 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D0/0x5003)

To use these interrupts, set the following interrupt enable bits to 1 for the corresponding interrupt flags. If the interrupt enable bits are set to 0 (default), the interrupt flag will not be set to 1, and the interrupt requests for this factor will not be sent to the ITC.

- \* CTIE32: 32 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D3/0x5002)
- \* CTIE8: 8 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D2/0x5002)
- \* CTIE2: 2 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D1/0x5002)
- \* CTIE1: 1 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D0/0x5002)

The CT module outputs an interrupt request to the ITC if the CTIF\* is set to 1. This interrupt request signal sets the clock timer interrupt flag inside the ITC to 1 and generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

Check the frequency of a clock timer interrupt by reading CTIF\* as part of the clock timer interrupt handler routine.

- Note: To prevent interrupt recurrences, the CT module interrupt flag CTIF\*must be reset within the interrupt handler routine following a clock timer interrupt.
  - To prevent generating unnecessary interrupts, reset the corresponding CTIF\* before permitting clock timer interrupts from CTIE\*.

### Interrupt vectors

The clock timer interrupt vector numbers and vector addresses are listed below.

Vector number: 7 (0x07) Vector address: TTBR + 0x1c

### Other interrupt settings

The ITC allows the priority of clock timer interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

## **15.6 Control Register Details**

| Address |                                             | Register name                       | Function                                      |  |  |  |  |  |  |  |
|---------|---------------------------------------------|-------------------------------------|-----------------------------------------------|--|--|--|--|--|--|--|
| 0x5000  | CT_CTL                                      | Clock Timer Control Register        | Timer resetting and Run/Stop control          |  |  |  |  |  |  |  |
| 0x5001  | CT_CNT                                      | Clock Timer Counter Register        | Counter data                                  |  |  |  |  |  |  |  |
| 0x5002  | CT_IMSK                                     | Clock Timer Interrupt Mask Register | Interrupt mask setting                        |  |  |  |  |  |  |  |
| 0x5003  | CT_IFLG Clock Timer Interrupt Flag Register |                                     | Interrupt occurrence status display/resetting |  |  |  |  |  |  |  |

Table 15.6.1: Clock timer registers list

The clock timer registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

### 0x5000: Clock Timer Control Register (CT\_CTL)

| Register name    | Address  | Bit  | Name  | Function                     | Setting |           |   | R/W | Remarks            |
|------------------|----------|------|-------|------------------------------|---------|-----------|---|-----|--------------------|
| Clock Timer      | 0x5000   | D7–5 | -     | reserved                     | -       |           |   | -   | 0 when being read. |
| Control Register | (8 bits) | D4   | CTRST | Clock timer reset            | 1 Reset | 0 Ignored | 0 | W   |                    |
| (CT_CTL)         |          | D3–1 | -     | reserved                     | -       | _         | - | -   |                    |
|                  |          | D0   | CTRUN | Clock timer run/stop control | 1 Run   | 0 Stop    | 0 | R/W |                    |

### D[7:5] Reserved

### D4 CTRST: Clock Timer Reset Bit

Resets the clock timer.

1 (W): Reset

0 (W): Disabled

0 (R): Normally 0 when read out (default)

Writing 1 to this bit resets the counter to 0x0. When reset in Run state, the clock timer restarts immediately after resetting. The reset data 0x0 is retained when in Stop state.

### D[3:1] Reserved

### D0 CTRUN: Clock Timer Run/Stop Control Bit

Controls the clock timer Run/Stop. 1 (R/W): Run 0 (R/W): Stop (default)

The clock timer starts counting when CTRUN is written as 1 and stops when written as 0. The counter data is retained at Stop state until a reset or the next Run state.

### 0x5001: Clock Timer Counter Register (CT\_CNT)

| Register name  | Address  | Bit  | Name       | Function                  | Setting     |   | R/W | Remarks |
|----------------|----------|------|------------|---------------------------|-------------|---|-----|---------|
| Clock Timer    | 0x5001   | D7-0 | CTCNT[7:0] | Clock timer counter value | 0x0 to 0xff | 0 | R   |         |
| Counter Regis- | (8 bits) |      |            |                           |             |   |     |         |
| ter            |          |      |            |                           |             |   |     |         |
| (CT_CNT)       |          |      |            |                           |             |   |     |         |

### D[7:0] CTCNT[7:0]: Clock Timer Counter Value

Reads out the counter data. (Default: 0xff)

This register is read-only and cannot be written to.

The bits correspond to various frequencies, as follows:

- D7: 1Hz
- D6: 2Hz
- D5: 4Hz
- D4: 8Hz
- D3: 16Hz D2: 32Hz
- D2: 32HZ
- D1: 04HZ
- D0: 128Hz
- Note: The correct counter value may not be read out (reading is unstable) if the register is read while counting is underway.

Obtain the counter value by one of the following methods:

- Read the counter value while the counter is halted.
- Read the counter twice in succession. Treat the value as valid if the values read are identical.

#### Register name Address Setting Init. R/W Bit Name Function Remarks Clock Timer D7-4 0x5002 reserved \_ 0 when being read. Interrupt Mask (8 bits) D3 CTIE32 32 Hz interrupt enable 1 Enable 0 Disable 0 R/W Register 0 Disable D2 CTIE8 8 Hz interrupt enable 1 Enable 0 R/W (CT\_IMSK) D1 CTIE2 1 Enable 0 Disable 0 R/W 2 Hz interrupt enable CTIE1 D0 1 Hz interrupt enable 1 Enable 0 Disable 0 R/W

### 0x5002: Clock Timer Interrupt Mask Register (CT\_IMSK)

This register permits or prohibits interrupt requests individually for the clock timer 32 Hz, 8 Hz, 2 Hz, and 1 Hz signals. Setting the CTIE\*bit to 1 permits clock timer interrupts for the corresponding frequency signal falling edge, while setting to 0 prohibits interrupts.

To enable interrupt generation, the ITC clock timer interrupt enable bits must also be set to permit interrupts.

### D[7:4] Reserved

| D3 | CTIE32: 32 Hz Interrupt Enable Bit<br>Permits or prohibits 32 Hz signal interrupts.<br>1 (R/W): Interrupt permitted<br>0 (R/W): Interrupt prohibited (default)     |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D2 | <b>CTIE8: 8 Hz Interrupt Enable Bit</b><br>Permits or prohibits 8 Hz signal interrupts.<br>1 (R/W): Interrupt permitted<br>0 (R/W): Interrupt prohibited (default) |
| D1 | <b>CTIE2: 2 Hz Interrupt Enable Bit</b><br>Permits or prohibits 2 Hz signal interrupts.<br>1 ( <b>R</b> / <b>W</b> ): Interrupt permitted                          |

1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)

### D0 CTIE1: 1 Hz Interrupt Enable Bit Permits or prohibits 1 Hz signal interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)

| Register name  | Address  | Bit  | Name   | Function             | Setting |           |   |               | Init. | R/W | Remarks             |
|----------------|----------|------|--------|----------------------|---------|-----------|---|---------------|-------|-----|---------------------|
| Clock Timer    | 0x5003   | D7–4 | -      | reserved             | -       |           |   |               | -     | -   | 0 when being read.  |
| Interrupt Flag | (8 bits) | D3   | CTIF32 | 32 Hz interrupt flag | 1       | Cause of  | 0 | Cause of      | 0     | R/W | Reset by writing 1. |
| Register       |          | D2   | CTIF8  | 8 Hz interrupt flag  | 1       | interrupt |   | interrupt not | 0     | R/W |                     |
| (CT_IFLG)      |          | D1   | CTIF2  | 2 Hz interrupt flag  | 1       | occurred  |   | occurred      | 0     | R/W |                     |
|                |          | D0   | CTIF1  | 1 Hz interrupt flag  | 1       |           |   |               | 0     | R/W |                     |

### 0x5003: Clock Timer Interrupt Flag Register (CT\_IFLG)

This register indicates the occurrence state of interrupt factors due to clock timer 32 Hz, 8 Hz, 2 Hz, and 1 Hz signals. If a clock timer interrupt occurs, identify the interrupt factor (frequency) by reading the interrupt flag in this register. CTIF\* are CT module interrupt flags corresponding to the individual 32 Hz, 8 Hz, 2 Hz, and 1 Hz interrupts. It is set to 1 at the falling edge of each signal if CTIE\* (CT\_IMSK register) is set to 1. The clock timer interrupt request signal is output to the ITC at the same time. This interrupt request signal generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

CTIF\* is reset by writing as 1.

- Note: To prevent interrupt recurrences, the CT module interrupt flag CTIF\*must be reset within the interrupt handler routine following a clock timer interrupt.
  - To prevent generating unnecessary interrupts, CTIF\* must be reset before permitting clock timer interrupts using CTIE.\*

### D[7:4] Reserved

### D3 CTIF32: 32 Hz Interrupt Flag

Interrupt flag indicating the 32 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting CTIE32 (D3/CT\_IMSK register) to 1 sets CTIF32 to 1 at the 32 Hz signal falling edge.

### D2 CTIF8: 8 Hz Interrupt Flag

Interrupt flag indicating the 8 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting CTIE8 (D2/CT\_IMSK register) to 1 sets CTIF8 to 1 at the 8 Hz signal falling edge.

### D1 CTIF2: 2 Hz Interrupt Flag

Interrupt flag indicating the 2 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting CTIE2 (D1/CT\_IMSK register) to 1 sets CTIF2 to 1 at the 2 Hz signal falling edge.

### D0 CTIF1: 1 Hz Interrupt Flag

Interrupt flag indicating the 1 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting CTIE1 (D0/CT\_IMSK register) to 1 sets CTIF1 to 1 at the 1 Hz signal falling edge.

### **15.7 Precautions**

- The OSC1 oscillator circuit must be set to On before operating the clock timer.
- To prevent generating unnecessary interrupts, reset the CT\_IFLG register interrupt flag before permitting clock timer interrupts by the CT\_IMSK register.
- The clock timer switches to Run/Stop mode when data is written to CTRUN synchronized with the 256 Hz signal falling edge. When 0 is written to CTRUN (D0/CT\_CTL register), the timer switches to Stop state after counting an additional "+1." 1 is retained for CTRUN reading until the timer actually stops. Figure 15.7.1 shows the Run/Stop control timing chart.



- Executing the slp instruction will destabilize a running clock timer (CTRUN = 1) during recovery from SLEEP state. When switching to SLEEP state, set the clock timer to STOP (CTRUN = 0) before executing the slp instruction.
- The correct counter value may not be read out (reading is unstable) if the counter register is read while counting is underway.

Read the counter register while the counter is halted or read the counter register twice in succession. Treat the value as valid if the values read are identical.

# **16 Stopwatch Timer (SWT)**

## **16.1 Stopwatch Timer Overview**

The S1C17702 incorporates a 1/100-second and 1/10-second stopwatch timer. The stopwatch timer consists of a 4-bit 2-stage BCD counter (1/100 and 1/10 second) that uses the 256 Hz signal divided from the OSC1 clock as the input clock and allows count data to be read out by software.

The stopwatch timer can also generate interrupts using the 100 Hz (approximately 100 Hz), 10 Hz (approximately 10 Hz), and 1 Hz signals.

Figure 16.1.1 illustrates the stopwatch timer configuration.



S1C17702 TECHNICAL MANUAL

## 16.2 BCD Counters

The stopwatch counter consists of 1/100-second and 1/10-second 4-bit BCD counters. The count value can be read from the SWT\_BCNT register.

### 1/100-second counter

\* BCD100[3:0]: 1/100 Sec. BCD Counter Value in the Stopwatch Timer BCD Counter (SWT\_BCNT) Register (D[3:0]/0x5021)

1/10-second counter

\* BCD10[3:0]: 1/10 Sec. BCD Counter Value in the Stopwatch Timer BCD Counter (SWT\_BCNT) Register (D[7:4]/0x5021)

### **Count-up Pattern**

A feedback division circuit is used to generate 100 Hz, 10 Hz, and 1 Hz signals from the 256 Hz clock. The counter count-up pattern varies as shown in Figure 16.2.1.



Figure 16.2.1: Stopwatch timer count-up patterns

The feedback division circuit generates an approximate 100 Hz signal at 2/256-second and 3/256-second intervals from the 256 Hz signal fed from the OSC module.

The 1/100-second counter counts the approximate 100 Hz signal output by the feedback division circuit and generates an approximate 10 Hz signal at 25/256-second and 26/256-second intervals.

Count-up will be pseudo 1/100-second counting at 2/256-second and 3/256-second intervals.

The 1/10-second counter counts the approximate 10 Hz signal generated by the 1/100-second counter at a ratio of 4:6, and generates a 1 Hz signal.

Count-up will be pseudo 1/10-second counting at 25/256-second and 26/256-second intervals.

### 16.3 Operation Clock

The stopwatch timer uses the 256 Hz clock output by the OSC module as the operation clock.

The OSC module generates this operation clock by dividing the OSC1 clock into 1/128, resulting in a frequency of 256 Hz when the OSC1 clock frequency is 32.768 kHz. The frequency described in this section will vary accordingly for other OSC1 clock frequencies.

The OSC module does not include a 256 Hz clock output control bit. The 256 Hz clock is normally fed to the stopwatch timer when the OSC1 oscillation is on.

For detailed information on OSC1 oscillator circuit control, refer to "7 Oscillator Circuit (OSC)."

### 16.4 Stopwatch Timer Resetting

Reset the stopwatch timer by writing 1 to the SWTRST bit (D4/SWT\_CTL register). This clears the counter to 0.

\* **SWTRST**: Stopwatch Timer Reset Bit in the Stopwatch Timer Control (SWT\_CTL) Register (D4/0x5020)

Apart from this operation, the counter is also cleared by initial resetting.

### 16.5 Stopwatch Timer RUN/STOP Control

Set the following items before starting the stopwatch timer.

- (1) If using interrupts, set the interrupt level and permit interrupts for the stopwatch timer. See Section 16.6.
- (2) Reset the timer. See Section 16.4.

The stopwatch timer includes SWTRUN (D0/SWT\_CTL register) to control Run/Stop.

\* SWTRUN: Stopwatch Timer Run/Stop Control Bit in the Stopwatch Timer Control (SWT\_CTL) Register (D0/0x5020)

The stopwatch timer starts counting when SWTRUN is written as 1. Writing 0 to SWTRUN prevents clock input and stops the count.

This control does not affect the counter (SWT\_BCNT register) data. The counter data is retained even when the count is halted, allowing resumption of the count from that data.

If SWTRUN and SWTRST are written as 1 simultaneously, the stopwatch timer starts counting after the reset.

Interrupt factors are generated during counting at the corresponding 100 Hz (approximate 100 Hz), 10 Hz (approximate 10 Hz), and 1 Hz signal falling edges. If interrupts are permitted, interrupt requests are sent to the interrupt controller (ITC).



Note: The stopwatch timer switches to Run/Stop mode when data is written to SWTRUN synchronized with the 256 Hz signal falling edge. When 0 is written to SWTRUN, the timer switches to Stop state after counting an additional "+1." 1 is retained for SWTRUN reading until the timer actually stops.

Figure 16.5.2 shows the Run/Stop control timing chart.



### 16.6 Stopwatch Timer Interrupts

The SWT module includes functions for generating the following three kinds of interrupts:

- 100 Hz interrupt
- 10 Hz interrupt
- 1 Hz interrupt

The SWT module outputs a single interrupt signal shared by the above three interrupt factors to the interrupt controller (ITC). The interrupt flag within the SWT module should be read to identify the interrupt factor that occurred.

#### 100 Hz, 10 Hz, 1 Hz interrupts

Generated at the 100 Hz (approximate 100 Hz), 10 Hz (approximate 10 Hz), and 1 Hz signal falling edges, these interrupt requests set the following interrupt flags in the SWT module to 1.

- \* SIF1: 1 Hz Interrupt Flag in the Stopwatch Timer Interrupt Flag (SWT\_IFLG) Register (D2/0x5023)
- \* SIF10: 10 Hz Interrupt Flag in the Stopwatch Timer Interrupt Flag (SWT\_IFLG) Register (D1/0x5023)
- \* SIF100: 100 Hz Interrupt Flag in the Stopwatch Timer Interrupt Flag (SWT\_IFLG) Register (D0/0x5023)

To use these interrupts, set the following interrupt enable bits to 1 for the corresponding interrupt flags. If the interrupt enable bits are set to 0 (default), the interrupt flag will not be set to 1, and the interrupt requests for this factor will not be sent to the ITC.

- \* SIE1: 1 Hz Interrupt Enable Bit in the Stopwatch Timer Interrupt Mask (SWT\_IMSK) Register (D2/0x5022)
- \* SIE10: 10 Hz Interrupt Enable Bit in the Stopwatch Timer Interrupt Mask (SWT\_IMSK) Register (D1/0x5022)
- \* SIE100: 100 Hz Interrupt Enable Bit in the Stopwatch Timer Interrupt Mask (SWT\_IMSK) Register (D0/0x5022)

The SWT module outputs an interrupt request to the ITC if the SIF\* is set to 1. This interrupt request signal generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

Check the frequency of a stopwatch timer interrupt by reading SIF\* as part of the stopwatch timer interrupt handler routine.

- Note: To prevent interrupt recurrences, the SWT module interrupt flag SIF\*must be reset within the interrupt handler routine following a stopwatch timer interrupt.
  - To prevent generating unnecessary interrupts, reset the corresponding SIF\* before permitting stopwatch timer interrupt from SIE\*.

#### Interrupt vectors

The stopwatch timer interrupt vector numbers and vector addresses are listed below.

Vector number: 6 (0x06) Vector address: TTBR + 0x18

#### Other interrupt settings

The ITC allows the priority of stopwatch timer interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### 16.7 Control Register Details

| Address | Register name                                    |                                                                     | Function                                      |  |  |  |  |  |  |
|---------|--------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------|--|--|--|--|--|--|
| 0x5020  | SWT_CTL                                          | ppwatch Timer Control Register Timer resetting and Run/Stop control |                                               |  |  |  |  |  |  |
| 0x5021  | SWT_BCNT                                         | Stopwatch Timer BCD Counter Register                                | BCD counter data                              |  |  |  |  |  |  |
| 0x5022  | SWT_IMSK                                         | Stopwatch Timer Interrupt Mask Register                             | Interrupt mask setting                        |  |  |  |  |  |  |
| 0x5023  | SWT_IFLG Stopwatch Timer Interrupt Flag Register |                                                                     | Interrupt occurrence status display/resetting |  |  |  |  |  |  |

Table 16.7.1 Stopwatch timer register list

The stopwatch timer registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x5020: Stopwatch Timer Control Register (SWT\_CTL)

| Register name | Address  | Bit  | Name   | Function                         | Setting |           | Init. | R/W | Remarks            |
|---------------|----------|------|--------|----------------------------------|---------|-----------|-------|-----|--------------------|
| Stopwatch     | 0x5020   | D7–5 | -      | reserved                         | -       |           | -     | -   | 0 when being read. |
| Timer Control | (8 bits) | D4   | SWTRST | Stopwatch timer reset            | 1 Reset | 0 Ignored | 0     | W   | -                  |
| Register      |          | D3–1 | -      | reserved                         |         | -         | -     | -   |                    |
| (SWT_CTL)     |          | D0   | SWTRUN | Stopwatch timer run/stop control | 1 Run   | 0 Stop    | 0     | R/W |                    |

#### D[7:5] Reserved

#### D4 SWTRST: Stopwatch Timer Reset Bit

Resets the stopwatch timer.

- 1 (W): Reset
- 0 (W): Disabled

0 (R): Normally 0 when read out (default)

Writing 1 to this bit resets the counter to 0x0. When reset in Run state, the stopwatch timer restarts immediately after resetting. The reset data 0x0 is retained when in Stop state.

#### D[3:1] Reserved

#### D0 SWTRUN: Stopwatch Timer Run/Stop Control Bit

Controls the stopwatch timer Run/Stop. 1 (R/W): Run 0 (R/W): Stop (default)

The stopwatch timer starts counting when SWTRUN is written as 1 and stops when written as 0. The counter data is retained at Stop state until a reset or the next Run state.

#### 0x5021: Stopwatch Timer BCD Counter Register (SWT\_BCNT)

| Register name | Address  | Bit  | Name        | Function                     | Setting | Init. | R/W | Remarks |
|---------------|----------|------|-------------|------------------------------|---------|-------|-----|---------|
| Stopwatch     | 0x5021   | D7–4 | BCD10[3:0]  | 1/10 sec. BCD counter value  | 0 to 9  | 0     | R   |         |
| Timer BCD     | (8 bits) |      |             |                              |         |       |     |         |
| Counter       |          | D3-0 | BCD100[3:0] | 1/100 sec. BCD counter value | 0 to 9  | 0     | R   |         |
| Register      |          |      |             |                              |         |       |     |         |
| (SWT_BCNT)    |          |      |             |                              |         |       |     |         |

D[7:4] BCD10[3:0]: 1/10 Sec. BCD Counter Value Read the 1/10-second counter BCD data. (Default: 0) This register is read-only and cannot be written to.

- D[3:0] BCD100[3:0]: 1/100 Sec. BCD Counter Value Read the 1/100-second counter BCD data. (Default: 0) This register is read-only and cannot be written to.
- Note: The correct counter value may not be read out (reading is unstable) if the register is read while counting is underway.

Obtain the counter value by one of the following methods:

- Read the counter value while the counter is halted.
- Read the counter twice in succession. Treat the value as valid if the values read are identical.

| Register name   | Address  | Bit  | Name   | Function                |   | Setting |   | Init.   | R/W | Remarks |                    |
|-----------------|----------|------|--------|-------------------------|---|---------|---|---------|-----|---------|--------------------|
| Stopwatch       | 0x5022   | D7–3 | -      | reserved                |   | -       | _ |         | -   | -       | 0 when being read. |
| Timer Interrupt | (8 bits) | D2   | SIE1   | 1 Hz interrupt enable   | 1 | Enable  | 0 | Disable | 0   | R/W     |                    |
| Mask Register   |          | D1   | SIE10  | 10 Hz interrupt enable  | 1 | Enable  | 0 | Disable | 0   | R/W     |                    |
| (SWT_IMSK)      |          | D0   | SIE100 | 100 Hz interrupt enable | 1 | Enable  | 0 | Disable | 0   | R/W     |                    |

#### 0x5022: Stopwatch Timer Interrupt Mask Register (SWT\_IMSK)

This register permits or prohibits interrupt requests individually for the stopwatch timer 100 Hz, 10 Hz, and 1 Hz signals. Setting the SIE\*bit to 1 permits stopwatch timer interrupts for the corresponding frequency signal falling edge, while setting to 0 prohibits interrupts.

To enable interrupt generation, the ITC stopwatch timer interrupt enable bits must also be set to permit interrupts.

#### D[7:3] Reserved

- D2 SIE1: 1 Hz Interrupt Enable Bit Permits or prohibits 1 Hz signal interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)
- D1 SIE10: 10 Hz Interrupt Enable Bit Permits or prohibits 10 Hz signal interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)
- D0 SIE100: 100 Hz Interrupt Enable Bit Permits or prohibits 100 Hz signal interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)

| Register name   | Address  | Bit  | Name   | Function              | Setting |         | Init.         | R/W | Remarks            |                     |
|-----------------|----------|------|--------|-----------------------|---------|---------|---------------|-----|--------------------|---------------------|
| Stopwatch       | 0x5023   | D7–3 | -      | reserved              | -       |         | -             | -   | 0 when being read. |                     |
| Timer Interrupt | (8 bits) | D2   | SIF1   | 1 Hz interrupt flag   | 1 Caus  | se of C | Cause of      | 0   | R/W                | Reset by writing 1. |
| Flag Register   |          | D1   | SIF10  | 10 Hz interrupt flag  | inter   | rupt    | interrupt not | 0   | R/W                |                     |
| (SWT_IFLG)      |          | D0   | SIF100 | 100 Hz interrupt flag | occu    | irred   | occurred      | 0   | R/W                |                     |

#### 0x5023: Stopwatch Timer Interrupt Flag Register (SWT\_IFLG)

This register indicates the occurrence state of interrupt factors due to stopwatch timer 100 Hz, 10 Hz, and 1 Hz signals. If a stopwatch timer interrupt occurs, identify the interrupt factor (frequency) by reading the interrupt flag in this register.

SIF\* are SWT module interrupt flags corresponding to the individual 100 Hz, 10 Hz, and 1 Hz interrupts. It is set to 1 at the falling edge of each signal if SIE\* (SWT\_IMSK register) is set to 1. The stopwatch timer interrupt request signal is output to the ITC at the same time. This interrupt request signal generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

SIF\* is reset by writing as 1.

- Note: To prevent interrupt recurrences, the SWT module interrupt flag SIF\*must be reset within the interrupt handler routine following a stopwatch timer interrupt.
  - To prevent generating unnecessary interrupts, SIF\* must be reset before permitting clock timer interrupts using SIE.\*

#### D[7:3] Reserved

#### D2 SIF1: 1 Hz Interrupt Flag

Interrupt flag indicating the 1 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting SIE1 (D2/SWT\_IMSK register) to 1 sets SIF1 to 1 at the 1 Hz signal falling edge.

#### D1 SIF10: 10 Hz Interrupt Flag

Interrupt flag indicating the 10 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting SIE10 (D1/SWT\_IMSK register) to 1 sets SIF10 to 1 at the 10 Hz signal falling edge.

#### D0 SIF100: 100 Hz Interrupt Flag

Interrupt flag indicating the 100 Hz interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting SIE100 (D0/SWT\_IMSK register) to 1 sets SIF100 to 1 at the 100 Hz signal falling edge.

### **16.8 Precautions**

- The OSC1 oscillator circuit must be set to On before operating the stopwatch timer.
- To prevent interrupt recurrences, the SWT\_IFLG register interrupt flag must be reset within the interrupt handler routine following a stopwatch timer interrupt.
- To prevent generating unnecessary interrupts, reset the SWT\_IFLG register interrupt flag before permitting stopwatch timer interrupts by the SWT\_IMSK register.
- The stopwatch timer switches to Run/Stop mode when data is written to SWTRUN (D0/SWT\_CTL resister) synchronized with the 256 Hz signal falling edge. When 0 is written to SWTRUN, the timer switches to Stop state after counting an additional "+1." 1 is retained for SWTRUN reading until the timer actually stops. Figure 16.8.1 shows the Run/Stop control timing chart.



- Executing the slp instruction will destabilize a running stopwatch timer (SWTRUN = 1) during recovery from SLEEP state. When switching to SLEEP state, set the stopwatch timer to STOP (SWTRUN = 0) before executing the slp instruction.
- The correct counter value may not be read out (reading is unstable) if the counter register is read while counting is underway.

To obtain the counter value, read the counter register while the counter is halted or read the counter register twice in succession. Treat the value as valid if the values read are identical.

# 17 Watchdog Timer (WDT)

### 17.1 Watchdog Timer Overview

The S1C17702 incorporates a watchdog timer that uses the OSC1 oscillator circuit as its oscillation source. The watchdog timer generates an NMI or reset (selectable via software) to the CPU if not reset within 131,072/fosci seconds (4 seconds when  $fosc_1 = 32.768 \text{ kHz}$ ).

Reset the watchdog timer via software within this cycle to prevent NMI/resets, which in turn enables runaway detection for programs that do not pass through the handler routine.

Figure 17.1.1 illustrates the watchdog timer block diagram.



Figure 17.1.1: Watchdog timer block diagram

### 17.2 Operation Clock

The watchdog timer uses the 256 Hz clock output by the OSC module as the operation clock.

The OSC module generates this operation clock by dividing the OSC1 clock into 1/128, resulting in a frequency of 256 Hz when the OSC1 clock frequency is 32.768 kHz. The frequency described in this section will vary accordingly for other OSC1 clock frequencies.

The OSC module does not include a 256 Hz clock output control bit. The 256 Hz clock is normally fed to the watchdog timer when the OSC1 oscillation is on.

For detailed information on OSC1 oscillator circuit control, refer to "7 Oscillator Circuit (OSC)."

### 17.3 Watchdog Timer Control

#### 17.3.1 NMI/Reset Mode Selection

WDTMD (D1/WDT\_ST register) is used to select whether an NMI signal or a reset signal is output when the watchdog timer has not been reset within the NMI/Reset occurrence cycle.

\* WDTMD: NMI/Reset Mode Select Bit in the Watchdog Timer Status (WDT\_ST) Register (D1/0x5041)

To generate an NMI, set WDTMD to 0 (default). Set to 1 to generate a reset.

### 17.3.2 Watchdog Timer Run/Stop Control

The watchdog timer starts counting when a value other than 0b1010 is written to WDTRUN[3:0] (D[3:0]/WDT\_CTL register) and stops when 0b1010 is written.

\* WDTRUN[3:0]: Watchdog Timer Run/Stop Control Bits in the Watchdog Timer Control (WDT\_CTL) Register (D[3:0]/0x5040)

Initial resetting sets WDTRUN[3:0] to 0b1010 and stops the watchdog timer.

Since an NMI or Reset may be generated immediately after running depending on the counter value, the watchdog timer should also be reset concurrently (before running the watchdog timer), as explained in the following section.

### 17.3.3 Watchdog Timer Resetting

To reset the watchdog timer, program 1 to WDTRST (D4/WDT\_CTL register).

\* WDTRST: Watchdog Timer Reset Bit in the Watchdog Timer Control (WDT\_CTL) Register (D4/0x5040)

A location should be provided for periodically processing the routine for resetting the watchdog timer before an NMI or Reset is generated when using the watchdog timer. Process this routine within 131,072/fosc1 second (4 seconds when fosc1 = 32.768 kHz) cycle.

After resetting, the watchdog timer starts counting with a new NMI/Reset generation cycle.

If the watchdog timer is not reset within the NMI/Reset generation cycle for any reason, the CPU is switched to interrupt processing by NMI or resetting, an interrupt vector is read out, and an interrupt handler routine is executed.

The reset and NMI vector addresses are TTBR + 0x0 and TTBR + 0x08.

If the counter overflows and generates an NMI without the watchdog timer being reset, WDTST (D0/WDT\_ST register) is set to 1.

\* WDTST: NMI Status Bit in the Watchdog Timer Status (WDT\_ST) Register (D0/0x5041)

This bit is provided to confirm that the watchdog timer was the source of the NMI. The WDTST set to 1 is cleared to 0 by resetting the watchdog timer.

### 17.3.4 Operation in Standby Mode

#### HALT mode

The watchdog timer operates in HALT mode, as the clock is fed. HALT mode is therefore cleared by an NMI or Reset if it continues for more than the NMI/Reset cycle. To disable the watchdog timer while in HALT mode, stop the watchdog timer by writing 0b1010 to WDTRUN[3:0] before executing the halt instruction. Reset the watchdog timer before resuming operations after HALT mode is cleared.

#### SLEEP mode

The clock fed from the OSC module is stopped in SLEEP mode, which also stops the watchdog timer. To prevent generation of an unnecessary NMI or Reset after clearing SLEEP mode, reset the watchdog timer before executing the slp instruction. The watchdog should also be stopped as required using WDTRUN[3:0].

### **17.4 Control Register Details**

| Table 17.4.1 Watchdog timer register list |                                |                                                                         |  |  |  |  |  |  |  |
|-------------------------------------------|--------------------------------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                                           | Register name                  | Function                                                                |  |  |  |  |  |  |  |
| WDT_CTL Watchdog Timer Control Register   |                                | Timer reset and Run/Stop control                                        |  |  |  |  |  |  |  |
| WDT_ST                                    | Watchdog Timer Status Register | Timer mode setting and NMI status display                               |  |  |  |  |  |  |  |
|                                           |                                | Register name           WDT_CTL         Watchdog Timer Control Register |  |  |  |  |  |  |  |

Table 17.4.1 Watchdog timer register list

The watchdog timer registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x5040: Watchdog Timer Control Register (WDT\_CTL)

| Register name | Address  | Bit  | Name        | Function                        | Set             | Init.     | R/W  | Remarks |                    |
|---------------|----------|------|-------------|---------------------------------|-----------------|-----------|------|---------|--------------------|
| Watchdog      | 0x5040   | D7–5 | -           | reserved                        | -               |           | -    | -       | 0 when being read. |
| Timer Control | (8 bits) | D4   | WDTRST      | Watchdog timer reset            | 1 Reset         | 0 Ignored | 0    | W       | -                  |
| Register      |          | D3–0 | WDTRUN[3:0] | Watchdog timer run/stop control | Other than 1010 | 1010      | 1010 | R/W     |                    |
| (WDT_CTL)     |          |      |             |                                 | Run             | Stop      |      |         |                    |

#### D[7:5] Reserved

#### D4 WDTRST: Watchdog Timer Reset Bit

Resets the watchdog timer.

- 1 (W): Reset
- 0 (W): Disabled
- 0 (R): Normally 0 when read out (default)

To use the watchdog timer, it must be reset by writing 1 to this bit within the NMI/Reset generation cycle (4 seconds when fosci = 32.768 kHz).

This resets the up-counter to 0 and starts counting with a new NMI/Reset generation cycle.

#### D[3:0] WDTRUN[3:0]: Watchdog Timer Run/Stop Control Bits

Controls the watchdog timer Run/Stop. Values other than 0b1010 (R/W): Run 0b1010 (R/W): Stop (default)

The watchdog timer must also be reset to prevent generation of an unnecessary NMI or Reset while the watchdog timer operates.

| Register name | Address  | Bit  | Name  | Function              |   | Setting |   | Init.   | R/W | Remarks            |  |
|---------------|----------|------|-------|-----------------------|---|---------|---|---------|-----|--------------------|--|
| Watchdog      | 0x5041   | D7–2 | -     | reserved              | - |         |   | -       | -   | 0 when being read. |  |
| Timer Status  | (8 bits) |      |       |                       |   |         |   |         |     |                    |  |
| Register      |          | D1   | WDTMD | NMI/Reset mode select | 1 | Reset   | 0 | NMI     | 0   | R/W                |  |
| (WDT_ST)      |          | D0   | WDTST | NMI status            | 1 | NMI oc- | 0 | Not oc- | 0   | R                  |  |
|               |          |      |       |                       |   | curred  |   | curred  |     |                    |  |

#### 0x5041: Watchdog Timer Status Register (WDT\_ST)

#### D[7:2] Reserved

#### D1 WDTMD: NMI/Reset Mode Select Bit

Selects NMI or Reset generation on counter overflow.

1 (R/W): Reset

0 (R/W): NMI (default)

Setting this bit to 1 outputs a reset signal when the counter overflows. Setting to 0 outputs an NMI signal.

#### D0 WDTST: NMI Status Bit

Indicates a counter overflow and NMI occurrence.

- 1 (R): NMI occurred (counter overflow)
- 0 (R): NMI did not occur (default)

This bit confirms that the watchdog timer was the source of the NMI.

The WDTST set to 1 is cleared to 0 by resetting the watchdog timer.

This is also set by a counter overflow if reset output is selected, but is cleared by initial resetting and cannot be confirmed.

### **17.5 Precautions**

- When the watchdog timer is running, this must be reset by software within a 131,072 fosc1 seconds (4 seconds when fosc1 = 32.768 kHz) cycle.
- The watchdog timer must also be reset to prevent generation of an unnecessary NMI or Reset while the watchdog timer operates.

# **18 UART**

### 18.1 UART Configuration

The S1C17702 incorporates a single-channel UART. The UART transfers asynchronous data with external devices at a transfer rate of 150 to 460,800 bps (115,200 bps in IrDA mode). It includes a 2-byte receive data buffer and 1-byte transmit data buffer and is capable of full-duplex communications. The transfer clock can be either the internal clock using the timer module or an external clock input via the SCLK (P25) pin. Data length (7 or 8 bits), stop bit length (1 or 2 bits), and parity mode (even, odd, no parity) can be selected via the software. The start bit is fixed at 1 bit. Overrun errors, framing errors, and parity errors can be detected while receiving data. The UART generates three different interrupt types (transmit buffer empty, receive buffer full, and receive error) and enables efficient processing of serial data transfer using interrupt processing.

This UART module also incorporates an RZI modulation/demodulation circuit that enables IrDA 1.0-compatible infrared communications simply by adding basic external circuits.

Figure 18.1.1 illustrates the UART configuration.



Figure 18.1.1: UART configuration

- Note: The UART modules for the two channels have the same functions except for control register addresses. For this reason, the description in this section applies to all UART channels. The "x" in the register name indicates the channel number (0 or 1). Register addresses are indicated either as Ch.0" or "Ch.1".
  - E.g.: UART\_CTLx register (0x4104/0x4124) Ch.0: UART\_CTL0 register (0x4104) Ch.1: UART\_CTL1 register (0x4124)

### 18.2 UART Pin

Table 18.2.1 lists the UART input/output pins.

| Pin name    | I/O | Qty | Function                                                    |  |  |  |  |
|-------------|-----|-----|-------------------------------------------------------------|--|--|--|--|
| SIN0 (P23)  | 1   | 1   | UART Ch.0 data input pin                                    |  |  |  |  |
|             |     |     | Inputs serial data sent from an external device.            |  |  |  |  |
| SOUT0 (P24) | 0   | 1   | UART Ch.0 data output pin                                   |  |  |  |  |
|             |     |     | Outputs serial data sent to an external device.             |  |  |  |  |
| SCLK0 (P25) | 1   | 1   | UART Ch.0 clock input pin                                   |  |  |  |  |
|             |     |     | Inputs the external clock when used for the transfer clock. |  |  |  |  |
| SIN1 (P10)  | 1   | 1   | UART Ch.1 data input pin                                    |  |  |  |  |
|             |     |     | Inputs serial data sent from an external device.            |  |  |  |  |
| SOUT1 (P11) | 0   | 1   | UART Ch.1 data output pin                                   |  |  |  |  |
|             |     |     | Outputs serial data sent to an external device.             |  |  |  |  |
| SCLK1 (P12) | 1   | 1   | UART Ch.1 clock input pin                                   |  |  |  |  |
| . ,         |     |     | Inputs the external clock when used for the transfer clock. |  |  |  |  |

| Table 18 | 3.2.1: U/ | ART pir | ı list |
|----------|-----------|---------|--------|
|----------|-----------|---------|--------|

The UART input/output pins (SIN*x*, SOUT*x*, SCLK*x*) are shared with general purpose input/output port pins (P23, P24, P25) and are initially set as general purpose input/output port pins. The function must be switched using the P2\_PMUX, P1\_PMUX register setting to use general purpose input/output port pins as UART input/output pins. Switch the pins to serial interface mode by setting the following control bits to 1.

#### UART Ch.0

 $\text{P23}\rightarrow\text{SIN0}$ 

\* P23MUX: P23 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D3/0x52a2)

 $P24 \rightarrow SOUT0$ 

\* P24MUX: P24 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D4/0x52a2)

 $P25 \rightarrow SCLK0$  (only when using external clock)

\* P25MUX: P25 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D5/0x52a2)

#### UART Ch.1

 $\text{P10}\rightarrow\text{SIN1}$ 

\* P10MUX: P10 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D0/0x52a1)

 $\text{P11} \rightarrow \text{SOUT1}$ 

\* P11MUX: P11 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D1/0x52a1)

 $P12 \rightarrow SCLK1$  (only when using external clock)

\* P12MUX: P12 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D2/0x52a1)

For detailed information on pin function switching, refer to "10.2 Input/output Pin Function Selection (Port MUX)."

### 18.3 Transfer Clock

The UART transfer clock can be set to internal or external using SSCK (D0/UART\_MODx register).

\* **SSCK**: Input Clock Select Bit in the UART Ch.*x* Mode (UART\_MOD*x*) Register (D0/0x4103/0x4123)

#### Note: Make sure the UART is halted (when RXEN/UART\_CTLx register = 0) before changing SSCK.

\* RXEN: UART Enable Bit in the UART Control (UART\_CTLx) Register (D0/0x4104/0x4124)

#### Internal clock

Setting SSCK to 0 (the default value) selects the internal clock. UART Ch.0 uses the 8-bit timer Ch.0 output clock as the transfer timer, while UART Ch.1 uses the 8-bit timer Ch.1 output clock. Thus, bit timers must be programmed to output a clock suited to the transfer rate.

For more information on 8-bit timer control, see "12 8-bit Timer (T8F)."

#### External clock

Setting SSCK to 1 selects the external clock. In this case, set P25 to the SCLK pin (see Section 18.2) to input the external clock.

- Note: The UART generates a sampling clock that divides the 8-bit timer output into 1/16 divisions. Be careful when setting the transfer rate.
  - To input the external clock via the SCLK pin, the clock frequency must be less than half of the PCLK and have a duty ratio of 50%.

### 18.4 Transfer Data Settings

Set the following conditions to set the transfer data format.

- Data length: 7 or 8 bits
- Start bit: Fixed at 1 bit
- Stop bit: 1 or 2 bits
- Parity bit: Even, odd, no parity

## Note: Make sure the UART is halted (when RXEN/UART\_CTL*x* register = 0) before changing transfer data format settings.

\* RXEN: UART Enable Bit in the UART Ch.x Control (UART\_CTLx) Register (D0/0x4104/0x4124)

#### **Data length**

The data length is selected by CHLN (D4/UART\_MODx register). Setting CHLN to 0 (default) sets the data length to 7 bits. Setting CHLN to 1 sets the data length to 8 bits.

\* CHLN: Character Length Select Bit in the UART Ch.x Mode (UART\_MODx) Register (D4/0x4103/0x4123)

#### Stop bit

The stop bit length is selected by STPB (D1/UART\_MODx register). Setting STPB to 0 (default) sets the stop bit length to 1 bit. Setting STPB to 1 sets the stop bit length to 2 bits.

\* STPB: Stop Bit Select Bit in the UART Ch.x Mode (UART\_MODx) Register (D1/0x4103/0x4123)

#### Parity bit

Whether the parity function is enabled or disabled is selected by PREN (D3/UART\_MODx register). Setting PREN to 0 (default) disables the parity function. In this case, no parity bit is added to the transfer data and the data is not checked for parity when received. Setting PREN to 1 enables the parity function. In this case, a parity bit is added to the transfer data and the data is checked for parity when received.

When the parity function is enabled, the parity mode is selected by PMD (D2/UART\_MODx register). Setting PMD to 0 (default) adds a parity bit and checks for even parity. Setting PMD to 1 adds a parity bit and checks for odd parity.

\* **PREN**: Parity Enable Bit in the UART Ch.x Mode (UART\_MODx) Register (D3/0x4103/0x4123)

\* PMD: Parity Mode Select Bit in the UART Ch.x Mode (UART\_MODx) Register (D2/0x4103/0x4123)

| Sampling clock (sclk-1/16)                                                                 |
|--------------------------------------------------------------------------------------------|
| CHLN = 0, PREN = 0, STPB = 0 <u>s1 ( D0 ) D1 ) D2 ( D3 ) D4 ) D5 ( D6 ) s2</u>             |
| CHLN = 0, PREN = 1, STPB = 0                                                               |
| CHLN = 0, PREN = 0, STPB = 1                                                               |
| CHLN = 0, PREN = 1, STPB = 1                                                               |
| CHLN = 1, PREN = 0, STPB = 0 <u>s1 ( D0 ) D1 ) D2 ( D3 ) D4 ( D5 ) D6 ( D7 )</u> s2        |
| CHLN = 1, PREN = 1, STPB = 0 <u>s1 ( D0 ) D1 ) D2 ( D3 ) D4 ( D5 ) D6 ( D7 ) p</u> s2      |
| CHLN = 1, PREN = 0, STPB = 1                                                               |
| CHLN = 1, PREN = 1, STPB = 1S1 (_D0 ) (D1 ) (D2 ) (D3 ) (D4 ) (D5 ) (D6 ) (D7 ) (p) (s2 s3 |
| s1: Start bit, s2 & s3: Stop bits, p: Parity bit                                           |

Figure 18.4.1: Transfer data format

### 18.5 Data Transfer Control

Make the following settings before starting data transfers.

- (1) Select input clock. (See Section 18.3.)
- To use the internal clock, program the 8-bit timer to output the transfer clock. See Section 12.
- (2) Set the transfer data format. (See Section 18.4.)
- (3) To use the IrDA interface, set IrDA mode. (See Section 18.8.)
- (4) Set interrupt conditions to use UART interrupts. (See Section 18.7.)

## Note: Make sure the UART is halted (when RXEN/UART\_CTLx register = 0) before changing the above settings.

\* RXEN: UART Enable Bit in the UART Ch.x Control (UART\_CTLx) Register (D0/0x4104/0x4124)

#### Permitting data transfers

Set the RXEN bit (D0/UART\_CTLx register) to 1 to permit data transfers. This switches transfer circuits to enable transfers.

#### Note: Do not set the RXEN bit to 0 while the UART is sending or receiving data.

#### Data transfer control

To start data transmission, program the transmission data to the UART\_TXDx register (0x4101/0x4121).

\* UART\_TXDx: UART Ch.x Transmit Data Register (0x4101/0x4121)

The data is written to the transmit data buffer, and the transmission circuit starts sending data.

The buffer data is sent to the transmit shift register, and the start bit is output from the SOUT pin. The data in the shift register is then output from the LSB. The transfer data bit is shifted in sync with the sampling clock rising edge and output in sequence via the SOUT pin. Following output of MSB, the parity bit (if parity is enabled) and stop bit are output.

The transmission circuit includes the TDBE (D0/UART\_STx register) and TRBS (D2/UART\_STx register) status flags.

- \* TDBE: Transmit Data Buffer Empty Flag in the UART Ch.x Status (UART\_STx) Register (D0/0x4100/0x4120)
- \* TRBS: Transmit Busy Flag in the UART Ch.x Status (UART\_STx) Register (D2/0x4100/0x4120)

The TDBE flag indicates the transmit data buffer status. This flag switches to 0 when the application program programs data to the transmit data buffer and reverts to 1 when the buffer data is sent to the transmit shift register. Interrupts can be generated when this flag is 1 (see Section 18.7). Subsequent data is sent after confirming that the transmit data buffer is empty either by using this interrupt or by inspecting the TDBE flag. The transmission buffer size is 1 byte, but a shift register is provided separately to allow data to be written while the previous data is being sent. Always confirm that the transmit data buffer is empty before writing transmission data. Writing data while the TDBE flag is 0 will overprogram earlier transmission data inside the transmit data buffer.

The TRBS flag indicates the shift register status. This flag switches to 1 when transmission data is loaded from the transmit data buffer to the shift register and reverts to 0 once the data is sent. Read this flag to check whether the transmission circuit is operating or at standby.



S1: Start bit, S2: Stop bit, P: Parity bit, Wr: data writing to transmit data buffer

Figure 18.5.1: Data transmission timing chart

#### Data reception control

The receiving circuit is launched by setting the RXEN bit to 1, enabling data to be received from an external serial device.

When the external serial device sends the start bit, the receiving circuit detects its Low level and starts sampling the following data bits. The data bits are sampled at the sampling clock rising edge, and the lead bit is loaded into the receive shift register as LSB. Once the MSB has been received into the shift register, the received data is loaded into the receive data buffer. If parity checking is enabled, the receiving circuit checks parity at the same time by checking the parity bit received immediately after the MSB.

The receive data buffer, a 2-byte FIFO, receives data until full.

Received data in the buffer can be read from the UART\_RXDx register (0x4102/0x4122). The oldest data is read out first, clearing the register.

#### \* UART\_RXDx: UART Ch.x Receive Data Register (0x4102/0x4122)

The receiving circuit includes the RDRY (D1/UART\_STx register) and RD2B (D3/UART\_STx register) buffer status flags.

\* RDRY: Receive Data Ready Flag in the UART Ch.x Status (UART\_STx) Register (D1/0x4100/0x4120)

\* RD2B: Second Byte Receive Flag in the UART Ch.x Status (UART\_STx) Register (D3/0x4100/0x4120)

The RDRY flag indicates that the receive data buffer still contains data. The RD2B flag indicates that the receive data buffer is full.

(1) 
$$RDRY = 0, RD2B = 0$$

The receive data buffer contents need not be read, since no data has been received.

(2) RDRY = 1, RD2B = 0

One data item has been received. Read the receive data buffer contents once. This resets the RDRY flag. The buffer reverts to state (1) above.

If the receive data buffer contents are read twice, the second data read will be invalid.

#### (3) RDRY = 1, RD2B = 1

Two data items have been received. Read the receive data buffer contents twice. The receive data buffer outputs the oldest data first. This resets the RD2B flag. The buffer then reverts to the state in (2) above. The second read outputs the most recent received data, after which the buffer reverts to the state in (1) above.

Even when the receive data buffer is full, the shift register can start receiving 8-bit data one more time. An overrun error will occur if receiving is finished before the receive data buffer has been read. In this case, the last received data cannot be read. The contents of the receive data buffer must be read out before an overrun error occurs. For detailed information on overrun errors, refer to Section 18.6.

The volume of data received can be checked by reading these flags.

The UART allows receive buffer full interrupts to be generated once data has been received in the receive data buffer. These interrupts can be used to read the receive data buffer. With default settings, a receive buffer full interrupt occurs when the receive data buffer receives one item of data (status (2) above). This can be changed by setting the RBFI bit (D1/UART\_CTLx register) to 1 so that an interrupt occurs when the receive data buffer receives two items of data.

\* **RBFI**: Receive Buffer Full Interrupt Condition Setup Bit in the UART Ch.*x* Control (UART\_CTL*x*) Register (D1/0x4104/0x4124)

Three error flags are also provided in addition to the flags previously mentioned. See Section 18.6 for detailed information on flags and receive errors.



Figure 18.5.2: Data receiving timing chart

#### Blocking data transfers

After a data transfer is completed (both transmission and reception), data transfers are blocked by writing 0 to the RXEN bit. Confirm that the TDBE flag is 1 and the TRBS and RDRY flags are both 0 before blocking data transfer.

Setting the RXEN bit to 0 empties the transmission data buffer, clearing any remaining data. The data being transferred cannot be guaranteed if RXEN is set to 0 while data is being sent or received.

### **18.6 Receive Errors**

Three different receive errors may be detected while receiving data.

Since receive errors are interrupt factors, they can be processed by generating interrupts. For more information on UART interrupt control, refer to Section 18.7.

#### **Parity error**

If PREN (D3/UART\_MODx register) has been set to 1 (parity enabled), data received is checked for parity. Data received in the shift register is checked for parity when sent to the receive data buffer. The matching is checked against the PMD (D2/UART\_MODx register) setting (odd or even parity). If the result is a non-match, a parity error is issued, and the parity error flag PER (D5/UART\_STx register) is set to 1.

Even if this error occurs, the data received is sent to the receive data buffer, and the receiving operation continues. However, the received data cannot be guaranteed if a parity error occurs.

The PER flag (D5/UART\_STx register) is reset to 0 by writing as 1.

- \* **PREN**: Parity Enable Bit in the UART Ch.*x* Mode (UART\_MOD*x*) Register (D3/0x4103/0x4123)
- \* PMD: Parity Mode Select Bit in the UART Ch.x Mode (UART\_MODx) Register (D2/0x4103/0x4123)
- \* **PER**: Parity Error Flag in the UART Ch.*x* Status (UART\_ST*x*) Register (D5/0x4100/0x4120)

#### **Framing error**

A framing error occurs if the stop bit is received as 0 and the UART determines sync offset. If the stop bit is set to two bits, only the first bit is checked.

The framing error flag FER (D6/UART\_STx register) is set to 1 if this error occurs. The received data is still transferred to the receive data buffer if this error occurs and the receiving operation continues, but the data cannot be guaranteed, even if no framing error occurs for subsequent data receiving.

The FER flag (D6/UART\_STx register) is reset to 0 by writing as 1.

\* FER: Framing Error Flag in the UART Ch.x Status (UART\_STx) Register (D6/0x4100/0x4120)

#### **Overrun error**

Even if the receive data buffer is full (two data items already received), a third item of data can be received in the shift register. However, if the receive data buffer is not emptied (by reading out data received) by the time this data has been received, the third data received in the shift register will not be sent to the buffer and an overrun error will occur.

If an overrun error occurs, the overrun error flag OER (D4/UART\_STx register) is set to 1.

The receiving operation continues even if this error occurs.

The OER flag (D4/UART\_STx register) is reset to 0 by writing as 1.

\* **OER**: Overrun Error Flag in the UART Ch.x Status (UART\_STx) Register (D4/0x4100/0x4120)

### 18.7 UART Interrupts

The UART includes a function for generating the following three different interrupt types.

- Transmit buffer empty interrupt
- Receive buffer full interrupt
- Receive error interrupt

The UART outputs one interrupt signal shared by the three above interrupt factor types to the interrupt controller (ITC). Inspect the status flag or error flag to determine the interrupt factor occurring.

#### Transmit buffer empty interrupt

To use this interrupt, set TIEN (D4/UART\_CTLx register) to 1. If TIEN is set to 0 (default), interrupt requests for this factor will not be sent to the ITC.

\* TIEN: Transmit Buffer Empty Interrupt Enable Bit in the UART Ch.x Control (UART\_CTLx) Register (D4/0x4104/0x4124)

When transmission data written to the transmit data buffer is transferred to the shift register, the UART sets the TDBE bit (D0/UART\_STx register) to 1, indicating that the transmit data buffer is empty. If transmit buffer empty interrupts are permitted (TIEN = 1), an interrupt request pulse is sent simultaneously to the ITC.

\* TDBE: Transmit Data Buffer Empty Flag in the UART Ch.x Status (UART\_STx) Register (D0/0x4100/0x4120)

An interrupt occurs if other interrupt conditions are met.

You can inspect the TDBE flag in the UART interrupt handler routine to determine whether the UART interrupt is attributable to a transmit buffer empty. If TDBE is 0, the next transmission data can be written to the transmit data buffer by the interrupt handler routine.

#### **Receive buffer full interrupt**

To use this interrupt, set RIEN (D5/UART\_CTLx register) to 1. If RIEN is set to 0 (default), interrupt requests for this factor will not be sent to the ITC.

\* **RIEN**: Receive Buffer Full Interrupt Enable Bit in the UART Ch.*x* Control (UART\_CTL*x*) Register (D5/0x4104/0x4124)

If the specified volume of received data is loaded into the receive data buffer when a receive buffer full interrupt is permitted (RIEN = 1), the UART outputs an interrupt request pulse to the ITC. If RBFI (D1/UART\_CTLx register) is 0, an interrupt request pulse is output as soon as one item of received data is loaded into the receive data buffer (RDRY flag (D1/UART\_STx register) is set to 1). If RBFI (D1/UART\_CTLx register) is 1, an interrupt request pulse is output as soon as two items of received data are loaded into the receive data buffer (RD2B flag (D3/UART\_STx register) is set to 1).

- \* **RBFI**: Receive Buffer Full Interrupt Condition Ch.*x* Setup Bit in the UART Control (UART\_CTL*x*) Register (D1/0x4104/0x4124)
- \* RDRY: Receive Data Ready Flag in the UART Ch.x Status (UART\_STx) Register (D1/0x4100/0x4120)
- \* RD2B: Second Byte Receive Flag in the UART Ch.x Status (UART\_STx) Register (D3/0x4100/0x4120)

An interrupt occurs if other interrupt conditions are met.

You can inspect the RDRY and RD2B flags in the UART interrupt handler routine to determine whether the UART interrupt is attributable to a receive buffer full. If RDRY or RD2B is 1, the received data can be read from the receive data buffer by the interrupt handler routine.

#### **Receive error interrupt**

To use this interrupt, set REIEN (D6/UART\_CTL register) to 1. If REIEN is set to 0 (default), interrupt requests will not be sent to the ITC for this factor.

\* REIEN: Receive Error Interrupt Enable Bit in the UART Control (UART\_CTL) Register (D6/0x4104)

The UART sets the error flags shown below to 1 if a parity error, framing error, or overrun error is detected when receiving data. If receive error interrupts are permitted (REIEN = 1), an interrupt request pulse is output at the same time to the ITC.

- \* PER: Parity Error Flag in the UART Ch.x Status (UART\_STx) Register (D5/0x4100/0x4120)
- \* FER: Framing Error Flag in the UART Ch.x Status (UART\_STx) Register (D6/0x4100/0x4120)
- \* OER: Overrun Error Flag in the UART Ch.x Status (UART\_STx) Register (D4/0x4100/0x4120)

If other interrupt conditions are satisfied, an interrupt occurs.

Inspect the error flags above as part of the UART interrupt handler routine to determine whether the UART interrupt was caused by a receive error. If any of the error flags has the value 1, the interrupt handler routine will proceed with error recovery.

#### Interrupt vectors

The UART interrupt vector numbers and vector addresses are as listed below.

| Channel | Vector number | Vector address |
|---------|---------------|----------------|
| Ch.0    | 16 (0x10)     | TTBR + 0x40    |
| Ch.1    | 17 (0x11)     | TTBR + 0x44    |

#### Table 18.7.1: UART interrupt vector

#### Other interrupt settings

The ITC allows the priority of UART interrupts to be set between level 0 (the default value) and level 7 for each channel. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### 18.8 IrDA Interface

This UART module incorporates an RZI modulation/demodulation circuit enabling implementation of IrDA 1.0-compatible infrared communication simply by adding basic external circuits.

The transmission data output from the UART transmit shift register is input to the modulation circuit and output from the SOUT pin after the Low pulse has been modulated to a 3/16 sclk cycle.



Figure 18.8.1: Transmission signal waveform

The received IrDA signal is input to the demodulation circuit and the Low pulse width is converted to 16 sclk cycles before entry to the receive shift register. The demodulation circuit uses the pulse detection clock selected from the prescaler output clock separately from the transfer cock to detect Low pulses input (when minimum pulse width = 1.41 µs/115,200 bps).



#### IrDA enable

To use the IrDA interface function, set IRMD (D0/UART\_EXPx register) to 1. This enables the RZI modulation/demodulation circuit.

\* IRMD: IrDA Mode Select Bit in the UART Ch.x Expansion (UART\_EXPx) Register (D0/0x4105/0x4125)

Note: This must be set before setting other UART conditions.

#### 18 UART

#### IrDA receive detection clock selection

The input pulse detection clock is selected from among the prescaler output clock PCLK-1/1 to PCLK-1/128 using IRCLK[2:0] (D[6:4]/UART\_EXPx register).

\* **IRCLK[2:0]**: IrDA Receive Detection Clock Select Bits in the UART Ch. Expansion (UART\_EXP*x*) Register (D[6:4]/0x4105/0x4125)

| IRCLK[2:0] | Prescaler output clock |  |  |  |  |  |  |  |  |  |
|------------|------------------------|--|--|--|--|--|--|--|--|--|
| 0x7        | PCLK-1/128             |  |  |  |  |  |  |  |  |  |
| 0x6        | PCLK-1/64              |  |  |  |  |  |  |  |  |  |
| 0x5        | PCLK-1/32              |  |  |  |  |  |  |  |  |  |
| 0x4        | PCLK-1/16              |  |  |  |  |  |  |  |  |  |
| 0x3        | PCLK-1/8               |  |  |  |  |  |  |  |  |  |
| 0x2        | PCLK-1/4               |  |  |  |  |  |  |  |  |  |
| 0x1        | PCLK-1/2               |  |  |  |  |  |  |  |  |  |
| 0x0        | PCLK-1/1               |  |  |  |  |  |  |  |  |  |
| `          |                        |  |  |  |  |  |  |  |  |  |

#### Table 18.8.1: IrDA receive detection clock selection

(Default: 0x0)

This clock must be selected as a clock faster than the 8-bit timer or transfer clock sclk input via the SCLKx pin. The demodulation circuit treats Low pulses with a width of at least 2 IrDA receive detection clock cycles as valid and converts them to 16 sclk cycle width Low pulses. Select the prescaler output clock to enable detection of input pulses with a minimum width of 1.41  $\mu$ s.

#### Serial data transfer control

Data transfer control in IrDA mode is identical to that for normal interfaces. For detailed information on data format settings and data transfer and interrupt control methods, refer to the previous discussions.

### **18.9 Control Register Details**

| Address |           | Register name                    | Function                               |  |  |  |  |  |  |  |  |
|---------|-----------|----------------------------------|----------------------------------------|--|--|--|--|--|--|--|--|
| 0x4100  | UART_ST0  | UART Ch.0 Status Register        | Transfer, buffer, error status display |  |  |  |  |  |  |  |  |
| 0x4101  | UART_TXD0 | UART Ch.0 Transmit Data Register | Transmission data                      |  |  |  |  |  |  |  |  |
| 0x4102  | UART_RXD0 | UART Ch.0 Receive Data Register  | Received data                          |  |  |  |  |  |  |  |  |
| 0x4103  | UART_MOD0 | UART Ch.0 Mode Register          | Transfer data format setting           |  |  |  |  |  |  |  |  |
| 0x4104  | UART_CTL0 | UART Ch.0 Control Register       | Data transfer control                  |  |  |  |  |  |  |  |  |
| 0x4105  | UART_EXP0 | UART Ch.0 Expansion Register     | IrDA mode setting                      |  |  |  |  |  |  |  |  |
| 0x4120  | UART_ST1  | UART Ch.1 Status Register        | Transfer, buffer, error status display |  |  |  |  |  |  |  |  |
| 0x4121  | UART_TXD1 | UART Ch.1 Transmit Data Register | Transmission data                      |  |  |  |  |  |  |  |  |
| 0x4122  | UART_RXD1 | UART Ch.1 Receive Data Register  | Received data                          |  |  |  |  |  |  |  |  |
| 0x4123  | UART_MOD1 | UART Ch.1 Mode Register          | Transfer data format setting           |  |  |  |  |  |  |  |  |
| 0x4124  | UART_CTL1 | UART Ch.1 Control Register       | Data transfer control                  |  |  |  |  |  |  |  |  |
| 0x4125  | UART_EXP1 | UART Ch.1 Expansion Register     | IrDA mode setting                      |  |  |  |  |  |  |  |  |

#### Table 18.9.1: UART register list

The UART registers are described in detail below. These are 8-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

| Register name   | Address  | Bit | Name | Function                        |   | Set   | ting | g         | Init. | R/W                | Remarks               |
|-----------------|----------|-----|------|---------------------------------|---|-------|------|-----------|-------|--------------------|-----------------------|
| UART Ch.x       | 0x4100   | D7  | -    | reserved                        | - |       |      | -         | -     | 0 when being read. |                       |
| Status Register | 0x4120   | D6  | FER  | Framing error flag              | 1 | Error | 0    | Normal    | 0     | R/W                | Reset by writing 1.   |
| (UART_STx)      | (8 bits) | D5  | PER  | Parity error flag               | 1 | Error | 0    | Normal    | 0     | R/W                |                       |
|                 |          | D4  | OER  | Overrun error flag              | 1 | Error | 0    | Normal    | 0     | R/W                |                       |
|                 |          | D3  | RD2B | Second byte receive flag        | 1 | Ready | 0    | Empty     | 0     | R                  |                       |
|                 |          | D2  | TRBS | Transmit busy flag              | 1 | Busy  | 0    | Idle      | 0     | R                  | Shift register status |
|                 |          | D1  | RDRY | Receive data ready flag         | 1 | Ready | 0    | Empty     | 0     | R                  |                       |
|                 |          | D0  | TDBE | Transmit data buffer empty flag | 1 | Empty | 0    | Not empty | 1     | R                  |                       |

#### 0x4100/0x4120: UART Ch.x Status Registers (UART\_STx)

The "x" in register names indicates the channel number (0 or 1).

#### 0x4100: UART Ch.0 Status Register (UART\_ST0) 0x4120: UART Ch.1 Status Register (UART\_ST1)

#### D7 Reserved

#### D6 FER: Framing Error Flag

Indicates whether a framing error has occurred.

- 1 (R): Error occurred
- 0 (R): No error (default)
- 1 (W): Reset to 0
- 0 (W): Disabled

FER is set to 1 when a framing error occurs. Framing errors occur when data is received with the stop bit set to 0.

FER is reset by writing 1.

#### D5 PER: Parity Error Flag

Indicates whether a parity error has occurred.

- 1 (R): Error occurred
- 0 (R): No error (default)
- 1 (W): Reset to 0
- 0 (W): Disabled

PER is set to 1 when a parity error occurs. Parity checking is enabled only when PREN (D3/ UART\_MODx register) is set to 1 and is performed when received data is transferred from the shift register to the receive data buffer.

PER is reset by writing 1.

#### D4 OER: Overrun Error Flag

Indicates whether an overrun error has occurred.

- 1 (R): Error occurred
- 0 (R): No error (default)
- 1 (W): Reset to 0
- 0 (W): Disabled

OER is set to 1 when an overrun error occurs. Overrun errors occur when data is received in the shift register when the receive data buffer is already full and additional data is sent. The receive data buffer is not overwritten if this error occurs. The shift register is overwritten as soon as the error occurs. OER is reset by writing 1.

#### D3 RD2B: Second Byte Received Flag

Indicates that the receive data buffer contains two items of received data.

- 1 (R): Second byte can be read
- 0 (R): Second byte not received (default)

RD2B is set to 1 when the second byte of data is loaded into the receive data buffer and is reset to 0 when the first data is read from the receive data buffer.

#### D2 TRBS: Transmit Busy Flag

Indicates the transmit shift register status.

1 (R): Operating

0 (R): Standby (default)

TRBS is set to 1 when transmission data is loaded from the transmit data buffer into the shift register and is reset to 0 when the data transfer is complete. Inspect TRBS to determine whether the transmit circuit is operating or at standby.

#### D1 RDRY: Receive Data Ready Flag

Indicates that the receive data buffer contains valid received data.

1 (R): Data can be read

0 (R): Buffer empty (default)

RDRY is set to 1 when received data is loaded into the receive data buffer and is reset to 0 when all data has been read from the receive data buffer.

#### D0 TDBE: Transmit Data Buffer Empty Flag

Indicates the state of the transmit data buffer.

- 1 (R): Buffer empty (default)
- 0 (R): Data exists

TDBE is reset to 0 when transmit data is written to the transmit data buffer and is set to 1 when the data is transferred to the shift register.

#### 0x4101/0x4121: UART Ch.x Transmit Data Registers (UART\_TXDx)

| Register name | Address  | Bit  | Name | Function      | Setting            | Init. | R/W | Remarks |
|---------------|----------|------|------|---------------|--------------------|-------|-----|---------|
| UART Ch.x     | 0x4101   | D7–0 |      | Transmit data | 0x0 to 0xff (0x7f) | 0x0   | R/W |         |
| Transmit Data | 0x4121   |      |      | TXD7(6) = MSB |                    |       |     |         |
| Register      | (8 bits) |      |      | TXD0 = LSB    |                    |       |     |         |
| (UART_TXDx)   |          |      |      |               |                    |       |     |         |

The "x" in register names indicates the channel number (0 or 1).

#### 0x4101: UART Ch.0 Transmit Data Register (UART\_TXD0) 0x4121: UART Ch.1 Transmit Data Register (UART\_TXD1)

#### D[7:0] TXD[7:0]: Transmit Data

Program transmit data to be set in the transmit data buffer. (Default: 0x0)

The UART begins transmitting when data is written to this register. Data written to TXD[7:0] is retained until sent to the transmit data buffer.

Transmitting data from within the transmit data buffer generates a transmit buffer empty interrupt factor.

TXD7 (MSB) is invalid in 7-bit mode.

Serial converted data is output from the SOUT pin, with the LSB first bits set to 1 as High level and bits set to 0 as Low level.

This register can also be read from.

#### 0x4102/0x4122: UART Ch.x Receive Data Registers (UART\_RXDx)

| Register name | Address  | Bit  | Name     | Function                         | Setting            | Init. | R/W | Remarks            |
|---------------|----------|------|----------|----------------------------------|--------------------|-------|-----|--------------------|
| UART Ch.x     | 0x4102   | D7-0 | RXD[7:0] | Receive data in the receive data | 0x0 to 0xff (0x7f) | 0x0   | R   | Older data in the  |
| Receive       | 0x4122   |      |          | buffer                           |                    |       |     | buffer is read out |
| Data Register | (8 bits) |      |          | RXD7(6) = MSB                    |                    |       |     | first.             |
| (UART_RXDx)   |          |      |          | RXD0 = LSB                       |                    |       |     |                    |

The "x" in register names indicates the channel number (0 or 1).

0x4102: UART Ch.0 Receive Data Register (UART\_RXD0) 0x4122: UART Ch.1 Receive Data Register (UART RXD1)

#### D[7:0] RXD[7:0]: Receive Data

Data in the receive data buffer is read out in sequence, starting with the oldest. Received data is placed in the receive data buffer. The receive data buffer is a 2-byte FIFO that allows proper data receipt until it fills, even if data is not read out. If the buffer is full and the shift register also contains received data, an overrun error will occur, unless the data is read out before receipt of the subsequent data starts.

The receive circuit includes two receive buffer status flags: RDRY (D1/UART\_STx register) and RD2B (D3/UART\_STx register). The RDRY flag indicates the presence of valid received data in the receive data buffer, while RD2B flag indicates the presence of two items of received data in the receive data buffer.

A receive buffer full interrupt occurs when the received data in the receive data buffer reaches the number specified by RBFI (D1/UART\_CTLx register).

0 is loaded into RXD7 in 7-bit mode.

Serial data input via the SIN pin is converted to parallel, with the initial bit as LSB, the High level bit as 1, and the Low level bit as 0. This data is then loaded into the receive data buffer.

This register is read-only. (Default: 0x0)

| Register name | Address  | Bit  | Name | Function           |   | Set         | ting | g         | Init. | R/W | Remarks            |
|---------------|----------|------|------|--------------------|---|-------------|------|-----------|-------|-----|--------------------|
| UART Ch.x     | 0x4103   | D7–5 | -    | reserved           |   | -           |      |           | -     | -   | 0 when being read. |
| Mode Register | 0x4123   | D4   | CHLN | Character length   | 1 | 8 bits      | 0    | 7 bits    | 0     | R/W |                    |
| (UART_MODx)   | (8 bits) | D3   | PREN | Parity enable      | 1 | With parity | 0    | No parity | 0     | R/W |                    |
|               |          | D2   | PMD  | Parity mode select | 1 | Odd         | 0    | Even      | 0     | R/W |                    |
|               |          | D1   | STPB | Stop bit select    | 1 | 2 bits      | 0    | 1 bit     | 0     | R/W |                    |
|               |          | D0   | SSCK | Input clock select | 1 | External    | 0    | Internal  | 0     | R/W |                    |

#### 0x4103/0x4123: UART Ch.x Mode Registers (UART\_MODx)

The "x" in register names indicates the channel number (0 or 1).

0x4103: UART Ch.0 Mode Register (UART\_MOD0) 0x4123: UART Ch.1 Mode Register (UART\_MOD1)

#### D[7:5] Reserved

D4 CHLN: Character Length Select Bit

Selects the serial transfer data length. 1 (R/W): 8 bits 0 (R/W): 7 bits (default)

#### D3 PREN: Parity Enable Bit

Enables the parity function. 1 (R/W): With parity

0 (R/W): No parity (default)

PREN is used to select receive data parity checking and to determine whether a parity bit is added to transmitted data. Setting PREN to 1 parity-checks the received data. A parity bit is automatically added to the transmitted data. If PREN is set to 0, no parity bit is checked or added.

#### D2 PMD: Parity Mode Select Bit

Selects the parity mode. 1 (R/W): Odd parity 0 (R/W): Even parity (default)

Writing 1 to PMD selects odd parity; writing 0 to it selects even parity. Parity checking and parity bit addition are enabled only when PREN (D3) is set to 1. The PMD setting is disabled if PREN (D3) is 0.

#### D1 STPB: Stop Bit Select Bit

Selects the stop bit length. 1 (R/W): 2 bits

0 (R/W): 1 bit (default)

Writing 1 to STPB selects two stop bits; writing 0 to it selects one bit. The start bit is fixed at one bit.

#### D0 SSCK: Input Clock Select Bit

Selects the input clock.

1 (R/W): External clock (SCLK*x*)

0 (R/W): Internal clock (default)

Selects whether the internal clock (8-bit timer output clock) or external clock (input via SCLK*x* pin) is used. Writing 1 to SSCK selects the external clock; Writing 0 to it selects the internal clock.

| Register name           | Address  | Bit  | Name  | Function                           |   | Set     | ttin | g       | Init. | R/W | Remarks            |
|-------------------------|----------|------|-------|------------------------------------|---|---------|------|---------|-------|-----|--------------------|
| UART Ch.x               | 0x4104   | D7   | -     | reserved                           |   |         | _    |         | -     | -   | 0 when being read. |
| <b>Control Register</b> | 0x4124   | D6   | REIEN | Receive error int. enable          | 1 | Enable  | 0    | Disable | 0     | R/W |                    |
| (UART_CTLx)             | (8 bits) | D5   | RIEN  | Receive buffer full int. enable    | 1 | Enable  | 0    | Disable | 0     | R/W |                    |
|                         |          | D4   | TIEN  | Transmit buffer empty int. enable  | 1 | Enable  | 0    | Disable | 0     | R/W |                    |
|                         |          | D3–2 | -     | reserved                           |   |         | -    |         | -     | -   | 0 when being read. |
|                         |          | D1   | RBFI  | Receive buffer full int. condition | 1 | 2 bytes | 0    | 1 byte  | 0     | R/W |                    |
|                         |          | D0   | RXEN  | UART enable                        | 1 | Enable  | 0    | Disable | 0     | R/W |                    |

#### 0x4104/0x4124: UART Ch.x Control Registers (UART\_CTLx)

The "x" in register names indicates the channel number (0 or 1).

0x4104: UART Ch.0 Control Register (UART\_CTL0) 0x4124: UART Ch.1 Control Register (UART\_CTL1)

#### D7 Reserved

#### D6 REIEN: Receive Error Interrupt Enable Bit

Permits interrupt requests to the ITC when a receive error occurs. 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Set this bit to 1 to process receive errors using interrupts.

#### D5 RIEN: Receive Buffer Full Interrupt Enable Bit

Permits interrupt requests to the ITC caused when the received data quantity in the receive data buffer reaches the quantity specified in RBFI (D1). 1 (R/W): Permitted

0 (R/W): Prohibited (default)

Set this bit to 1 to read receive data using interrupts.

#### D4 TIEN: Transmit Buffer Empty Interrupt Enable Bit

Permits interrupt requests to the ITC caused when transmission data in the transmit data buffer is sent to the shift register (i.e. when data transmission begins). 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Set this bit to 1 to program data to the transmit data buffer using interrupts.

#### D[3:2] Reserved

#### D1 RBFI: Receive Buffer Full Interrupt Condition Setup Bit

Sets the quantity of data in the receive buffer to generate a receive buffer full interrupt.

1 (R/W): 2 bytes

0 (R/W): 1 byte (default)

If receive buffer full interrupts are permitted (RIEN = 1), the UART outputs an interrupt request pulse to the ITC when the quantity of received data specified by RBFI is loaded into the receive data buffer. If the RBFI bit is 0, an interrupt request pulse is output as soon as one item of received data is loaded into the receive data buffer (when the RDRY flag (D1/UART\_STx register) is set to 1). If RBFI is 1, an interrupt request pulse is output as soon as two items of received data are loaded into the receive data buffer (when the RD2B flag (D3/UART\_STx register) is set to 1).

#### D0 RXEN: UART Enable Bit

Permits data transfer by the UART.

1 (R/W): Permitted

0 (R/W): Prohibited (default)

Set RXEN to 1 before starting UART transfers. Setting RXEN to 0 will stop data transfers. Set the transfer conditions while RXEN is 0.

Preventing transfers by writing 0 to RXEN also clears transmit data buffer.

| Register name | Address  | Bit  | Name       | Function                     | Setting    |            | Init. | R/W | Remarks            |
|---------------|----------|------|------------|------------------------------|------------|------------|-------|-----|--------------------|
| UART Ch.x     | 0x4105   | D7   | -          | reserved                     |            | _          | -     | -   | 0 when being read. |
| Expansion     | 0x4125   | D6-4 | IRCLK[2:0] | IrDA receive detection clock | IRCLK[2:0] | Clock      | 0x0   | R/W |                    |
| Register      | (8 bits) |      |            | select                       | 0x7        | PCLK-1/128 |       |     |                    |
| (UART_EXPx)   |          |      |            |                              | 0x6        | PCLK-1/64  |       |     |                    |
|               |          |      |            |                              | 0x5        | PCLK-1/32  |       |     |                    |
|               |          |      |            |                              | 0x4        | PCLK-1/16  |       |     |                    |
|               |          |      |            |                              | 0x3        | PCLK-1/8   |       |     |                    |
|               |          |      |            |                              | 0x2        | PCLK-1/4   |       |     |                    |
|               |          |      |            |                              | 0x1        | PCLK-1/2   |       |     |                    |
|               |          |      |            |                              | 0x0        | PCLK-1/1   |       |     |                    |
|               |          | D3–1 | -          | reserved                     |            | -          | -     | -   | 0 when being read. |
|               |          | D0   | IRMD       | IrDA mode select             | 1 On       | 0 Off      | 0     | R/W |                    |

#### 0x4105/0x4125: UART Ch.x Expansion Registers (UART\_EXPx)

The "x" in register names indicates the channel number (0 or 1).

#### 0x4105: UART Ch.0 Expansion Register (UART\_EXP0) 0x4125: UART Ch.1 Expansion Register (UART\_EXP1)

#### D7 Reserved

#### D[6:4] IRCLK[2:0]: IrDA Receive Detection Clock Select Bits

Select the prescaler output clock used as the IrDA input pulse detection clock.

| Prescaler output clock |  |  |  |  |  |
|------------------------|--|--|--|--|--|
| PCLK-1/128             |  |  |  |  |  |
| PCLK-1/64              |  |  |  |  |  |
| PCLK-1/32              |  |  |  |  |  |
| PCLK-1/16              |  |  |  |  |  |
| PCLK-1/8               |  |  |  |  |  |
| PCLK-1/4               |  |  |  |  |  |
| PCLK-1/2               |  |  |  |  |  |
| PCLK-1/1               |  |  |  |  |  |
|                        |  |  |  |  |  |

#### Table 18.9.2: IrDA receive detection clock selection

(Default: 0x0)

This clock must be selected as a clock faster than the 8-bit timer or transfer clock sclk input via the SCLK pin.

The demodulation circuit treats Low pulses with a width of at least 2 IrDA receive detection clock cycles as valid. Select the appropriate prescaler output clock to enable detection of input pulses with a minimum width of  $1.41 \,\mu s$ .

#### D[3:1] Reserved

#### D0 IRMD: IrDA Mode Select Bit

Switches the IrDA interface function on and off. 1 (R/W): On 0 (R/W): Off (default)

Set this to 1 to use the IrDA interface. When this bit is set to 0, this module functions as a normal UART, with no IrDA functions.

### 18.10 Precautions

- The following UART bits should be set with transfers blocked (RXEN = 0).
  - All UART\_MODx register (0x4103/0x4123) bits (SSCK, STPB, PMD, PREN, CHLN)
  - RBFI bit in the UART\_CTL*x* register (0x4104/0x4124)
  - All UART\_EXP*x* register (0x4105/0x4125) bits (IRMD, IRCLK[2:0])
  - \* **RXEN**: UART Enable Bit in the UART Ch.x Control (UART\_CTLx) Register (D0/0x4104/0x4124)
- Do not set RXEN to 0 while the UART is transmitting or receiving data.
- The UART transfer rate is capped at 460,800 bps (115,200 bps in IrDA mode). Do not set faster transfer rates.
- Preventing transfer by setting RXEN to 0 clears (initializes) the transmit data buffer. Before writing 0 to RXEN, confirm the absence of data in the buffer awaiting transmission.
- The IrDA receive detection clock must be selected as a clock faster than the 8-bit timer or transfer clock sclk input via the SCLK pin.
- The IrDA interface demodulation circuit treats Low pulses with a width of at least 2 IrDA receive detection clock cycles as valid. Select the appropriate prescaler output clock to enable detection of input pulses with a minimum width of 1.41 µs as an IrDA receive detection clock.

### 19.1 SPI Configuration

The S1C17702 incorporates a synchronized serial interface module (SPI). This SPI module supports both Master and Slave modes and is used for 8-bit data transfers. Four different data transfer timing patterns (clock phase and polarity) can be selected.

The SPI module includes a transmit data buffer and receive data buffer separate from the shift register, and is capable of generating two different interrupt types (transmit buffer empty and receive buffer full). This allows easy processing of continuous serial data transfer using interrupts.

Figure 19.1.1 illustrates the SPI module configuration.



Figure 19.1.1: SPI module configuration

### 19.2 SPI Input/Output Pins

Table 19.2.1 lists the SPI pins.

| Pin name     | Pin name I/O Qty Function |   |                                                                        |  |  |  |  |  |
|--------------|---------------------------|---|------------------------------------------------------------------------|--|--|--|--|--|
| SDI (P20)    | 1                         | 1 | SPI data input pin                                                     |  |  |  |  |  |
|              |                           |   | Inputs serial data from SPI bus.                                       |  |  |  |  |  |
| SDO (P21)    | 0                         | 1 | SPI data output pin                                                    |  |  |  |  |  |
|              |                           |   | Outputs serial data to SPI bus.                                        |  |  |  |  |  |
| SPICLK (P22) | I/O                       | 1 | SPI external clock input/output pin                                    |  |  |  |  |  |
|              |                           |   | Outputs SPI clock when SPI is in Master mode.                          |  |  |  |  |  |
|              |                           |   | Inputs external clock when SPI is used in Slave mode.                  |  |  |  |  |  |
| #SPISS (P17) | I                         | 1 | SPI slave selection signal (active Low) input pin                      |  |  |  |  |  |
|              |                           |   | SPI (Slave mode) is selected as slave device by Low input to this pin. |  |  |  |  |  |

Table 19.2.1: SPI pin list

The SPI input/output pins (SDI, SDO, SPICLK, #SPISS) are shared with general purpose input/output port pins (P20, P21, P22, P17) and are initially set as general purpose input/output port pins. The function must be switched using the P2\_PMUX and P1\_PMUX register settings to use general purpose input/output port pins as SPI input/output pins. Switch the pins to SPI mode by setting the following control bits to 1.

#### $\text{P20}\rightarrow\text{SDI}$

\* P20MUX: P20 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D0/0x52a2)

#### $\text{P21}\rightarrow\text{SDO}$

\* P21MUX: P21 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D1/0x52a2)

#### $\text{P22} \rightarrow \text{SPICLK}$

\* P22MUX: P22 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D2/0x52a2)

#### $\text{P17} \rightarrow \#\text{SPISS}$

\* P17MUX: P17 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D7/0x52a1)

For detailed information on pin function switching, refer to "10.2 Input/Output Pin Function Selection (Port MUX)."

### 19.3 SPI Clock

The Master mode SPI uses the 16-bit timer Ch.1 output clock or a PCLK-1/4 clock to generate the SPI clock. This clock is output from the SPICLK pin to the slave device while also driving the shift register.

Use MCLK (D9/SPI\_CTL register) to select whether the 16-bit timer Ch.1 output clock or PCLK-1/4 clock is used. Setting MCLK to 1 selects the 16-bit timer Ch.1 output clock; setting to 0 selects the PCLK-1/4 clock.

\* MCLK: SPI Clock Source Select Bit in the SPI Control (SPI\_CTL) Register (D9/0x4326)

Using the 16-bit timer Ch.1 output clock enables programmable transfer rates. For more information on 16-bit timer control, see "11 16-bit Timer (T16)."



In Slave mode, the SPI clock is input via the SPICLK pin.

Note: The duty ratio of the clock input via the SPICLK pin must be 50%.

### 19.4 Data Transfer Condition Settings

The SPI module can be set to Master or Slave modes. The SPI clock polarity and phase can also be set via the SPI\_CTL register. The data length is fixed at 8 bits.

# Note: Make sure the SPI module is halted (when SPEN/SPI\_CTL register = 0) before Master/Slave mode selection and clock condition settings.

\* SPEN: SPI Enable Bit in the SPI Control (SPI\_CTL) Register (D0/0x4326)

#### Master/Slave mode selection

MSSL (D1/SPI\_CTL register) is used to set the SPI module to Master mode or Slave mode. Setting MSSL to 1 sets Master mode; setting it to 0 (default) sets Slave mode. In Master mode, data is transferred using the internal clock. In Slave mode, data is transferred by inputting the master device clock.

\* MSSL: Master/Slave Mode Select Bit in the SPI Control (SPI\_CTL) Register (D1/0x4326)

#### SPI clock polarity and phase settings

The SPI clock polarity is selected by CPOL (D2/SPI\_CTL register). Setting CPOL to 1 treats the SPI clock as active Low; setting it to 0 (default) treats it as active High.

\* CPOL: Clock Polarity Select Bit in the SPI Control (SPI\_CTL) Register (D2/0x4326)

The SPI clock phase is selected by CPHA (D3/SPI\_CTL register).

\* CPHA: Clock Phase Select Bit in the SPI Control (SPI\_CTL) Register (D3/0x4326)

As shown below, these control bits set transfer timing.



Figure 19.4.1: Clock and data transfer timing

#### MSB initial/LSB initial settings

Use MLSB (D8/SPI\_CTL register) to select whether the data MSB or LSB is input or output first. MSB initial is set when MLSB is 0 (the default value); LSB initial is set when MLSB is 1.

\* MLSB: LSB/MSB First Mode Select Bit in the SPI Control (SPI\_CTL) Register (D8/0x4326)

# Note: When the SPI module is used in master mode with CPHA set to 0, the clock may change a minimum of one system clock (PCLK) cycle time from change of the first transmit data bit.



Figure 19.4.2: SDO and SPICLK Change Timings when CPHA = 0

The half SPICLK cycle will be secured from change of data to change of the clock for the second and following transmit data bits and the second and following bytes during continuous transfer.

### 19.5 Data Transfer Control

Make the following settings before starting data transfers.

- (1) Set the 16-bit timer Ch.1 to output the SPI clock. (See Section 11.)
- (2) Select Master mode or Slave mode. (See Section 19.4.)
- (3) Set clock conditions. (See Section 19.4.)
- (4) Set the interrupt conditions to use SPI interrupts. (See Section 19.6.)

## Note: Make sure the SPI is halted (when SPEN/SPI\_CTL register = 0) before changing the above settings.

\* SPEN: SPI Enable Bit in the SPI Control (SPI\_CTL) Register (D0/0x4326)

#### Permitting data transfers

Set the SPEN bit (D0/SPI\_CTL register) to 1 to permit SPI operations. This enables SPI transfers and permits clock input/output.

#### Note: Do not set SPEN to 0 when the SPI module is transferring data.

#### Data transfer control

To start data transmission, program the transmission data to the SPI\_TXD register (0x4322).

\* SPI\_TXD: SPI Transmit Data Register (0x4322)

The data is written to the transmit data buffer, and the SPI module begins sending data. The buffer data is sent to the transmit shift register. In Master mode, the module starts clock output from the SPICLK pin. In Slave mode, the module awaits clock input from the SPICLK pin. The data in the shift register is shifted in sequence at the clock rising or falling edge, as determined by CPHA (D3/SPI\_CTL register) and CPOL (D2/SPI\_CTL register) (see Figure 19.4.1) and sent from the SDO pin with MSB leading.

\* CPHA: Clock Phase Select Bit in the SPI Control (SPI\_CTL) Register (D3/0x4326)

\* CPOL: Clock Polarity Select Bit in the SPI Control (SPI\_CTL) Register (D2/0x4326)

The SPI module includes the SPTBE (D0/SPI\_ST register) and SPBSY (D2/SPI\_ST register) status flags for transfer control.

- \* SPTBE: Transmit Data Buffer Empty Flag in the SPI Status (SPI\_ST) Register (D0/0x4320)
- \* SPBSY: Transfer Busy Flag in the SPI Status (SPI\_ST) Register (D2/0x4320)

The SPTBE flag indicates the transmit data buffer status. This flag switches to 0 when the application program programs data to the SPI\_TXD register (transmit data buffer) and reverts to 1 when the buffer data is sent to the transmit shift register. Interrupts can be generated when this flag is 1 (see Section 19.6). Subsequent data is sent after confirming that the transmit data buffer is empty either by using this interrupt or by inspecting the SPTBE flag. The transmission buffer size is 1 byte, but a shift register is provided separately to allow data to be written while the previous data is being sent. Always confirm that the transmit data buffer is empty before writing transmission data. Writing data while the SPTBE flag is 0 will overprogram earlier transmission data inside the transmit data buffer.

In Master mode, the SPBSY flag indicates the shift register status. This flag switches to 1 when transmission data is loaded from the transmit data buffer to the shift register and reverts to 0 once the data is sent. Read this flag to check whether the SPI module is operating or at standby.

The Slave mode SPBSY flag indicates the SPI slave selection signal (#SPISS pin) status. The flag has the value 1 when the SPI module is selected in Slave mode and the value 0 when the module is not selected.

#### Data receipt control

In Master mode, dummy data is written to the SPI\_TXD register (0x4322). Writing to the SPI\_TXD register creates the trigger for receipt as well as transmission start. Writing actual transmission data enables simultaneous transfers.

This starts the SPI clock output from SPICLK.

In Slave mode, the module waits until the clock is input from SPICLK. Slave mode involves only data receipt.

#### 19 SPI

There is no need to program to the SPI\_TXD register if no transmission is required. The receiving operation is started by clock input from the master device. If data is transferred simultaneously, the transmission data is written to the SPI\_TXD register before the clock is input.

The data is contained in sequence in the shift register at the rising or falling edge for the clock determined by CPHA (D3/SPI\_CTL register) and CPOL (D2/SPI\_CTL register). (See Figure 19.4.1.) The received data is loaded into the receive data buffer once the 8 bits of data are received in the shift register.

Received data in the buffer can be read from the SPI\_RXD register (0x4324).

\* SPI\_RXD: SPI Receive Data Register (0x4324)

The SPI module includes an SPRBF flag (D1/SPI\_ST register) for receipt control.

\* SPRBF: Receive Data Buffer Full Flag in the SPI Status (SPI\_ST) Register (D1/0x4320)

The SPRBF flag indicates the receive data buffer status. This flag is set to 1 when the data received in the shift register is loaded into the receive data buffer, indicating that the receive data can be read out. It reverts to 0 when the buffer data is read out from the SPI\_RXD register. An interrupt can be generated as soon as the flag is set to 1 (see Section 19.6). The received data should be read out either by using this interrupt or by inspecting the SPRBF flag to confirm that the receive data buffer contains valid receive data. The receive data buffer is 1 byte in size, but a shift register is also provided, enabling received data to be retained in the buffer even while the subsequent data is being received. Note that the receive data buffer should be read out before receiving the subsequent data is complete. If receiving the subsequent data is complete before the receive data buffer contents are read out, the newly received data will overprogram the previous received data in the buffer.

In Master mode, the SPBSY flag indicating the shift register state can be used in the same way while transferring data.



Figure 19.5.1: Data transmission/receiving timing chart (MSB first)

#### Blocking data transfers

After a data transfer is completed (both transmission and reception), data transfers are blocked by writing 0 to the SPEN bit. Confirm that the SPTBE flag is 1 and the SPBSY flag is 0 before blocking data transfer. The data being transferred cannot be guaranteed if SPEN is set to 0 while data is being sent or received.

### 19.6 SPI Interrupts

The SPI module includes a function for generating the following two different interrupt types.

- Transmit buffer empty interrupt
- Receive buffer full interrupt

The SPI module outputs one interrupt signal shared by the three above interrupt factor types to the interrupt controller (ITC). Inspect the status flag to determine the interrupt factor occurring.

#### Transmit buffer empty interrupt

To use this interrupt, set SPTIE (D4/SPI\_CTL register) to 1. If SPTIE is set to 0 (default), interrupt requests for this factor will not be sent to the ITC.

\* SPTIE: Transmit Data Buffer Empty Interrupt Enable Bit in the SPI Control (SPI\_CTL) Register (D4/0x4326)

When transmission data written to the transmit data buffer is transferred to the shift register, the SPI module sets the SPTBE bit (D0/SPI\_ST register) to 1, indicating that the transmit data buffer is empty. If transmit buffer empty interrupts are permitted (SPTIE = 1), an interrupt request pulse is sent simultaneously to the ITC.

\* SPTBE: Transmit Data Buffer Empty Flag in the SPI Status (SPI\_ST) Register (D0/0x4320)

An interrupt occurs if other interrupt conditions are met.

You can inspect the SPTBE flag in the SPI interrupt handler routine to determine whether the SPI interrupt is attributable to a transmit buffer empty. If SPTBE is 1, the next transmission data can be written to the transmit data buffer by the interrupt handler routine.

#### **Receive buffer full interrupt**

To use this interrupt, set SPRIE (D5/SPI\_CTL register) to 1. If SPRIE is set to 0 (default), interrupt requests for this factor will not be sent to the ITC.

\* SPRIE: Receive Data Buffer Full Interrupt Enable Bit in the SPI Control (SPI\_CTL) Register (D5/0x4326)

When data received in the shift register is loaded into the receive data buffer, the SPI module sets the SPRBF bit (D1/SPI\_ST register) to 1, indicating that the receive data buffer contains readable received data. If receive buffer full interrupts are permitted (SPRIE = 1), an interrupt request pulse is output to the ITC at the same time.

\* SPRBF: Receive Data Buffer Full Flag in the SPI Status (SPI\_ST) Register (D1/0x4320)

An interrupt occurs if other interrupt conditions are met.

You can inspect the SPRBF flag in the SPI interrupt handler routine to determine whether the SPI interrupt is attributable to a receive buffer full. If SPRBF is 1, the received data can be read from the receive data buffer by the interrupt handler routine.

#### Interrupt vectors

The SPI interrupt vector numbers and vector addresses are as listed below.

Vector number: 18 (0x12)Vector address: TTBR + 0x48

#### Other interrupt settings

The SPI interrupt priority can be set for the ITC between level 0 (default) and level 7. The PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1 to generate actual interrupts. For specific information on interrupt processing, refer to "6 Interrupt Controller (ITC)."

### **19.7 Control Register Details**

| Address |         | Register name              | Function                                      |  |  |  |  |  |  |  |  |  |
|---------|---------|----------------------------|-----------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0x4320  | SPI_ST  | SPI Status Register        | Transfer, buffer status display               |  |  |  |  |  |  |  |  |  |
| 0x4322  | SPI_TXD | SPI Transmit Data Register | Transmission data                             |  |  |  |  |  |  |  |  |  |
| 0x4324  | SPI_RXD | SPI Receive Data Register  | Received data                                 |  |  |  |  |  |  |  |  |  |
| 0x4326  | SPI_CTL | SPI Control Register       | SPI mode and data transfer permission setting |  |  |  |  |  |  |  |  |  |

#### Table 19.7.1: SPI register list

The SPI registers are described in detail below. These are 16-bit registers.

| Note: • | • When data is written to the registers, | the "Reserved" | bits must always be written as 0 and |
|---------|------------------------------------------|----------------|--------------------------------------|
|         | not 1.                                   |                |                                      |

#### 0x4320: SPI Status Register (SPI\_ST)

| Register name | Address   | Bit   | Name  | Function                        | Setting |        |   | Init.     | R/W                | Remarks |  |
|---------------|-----------|-------|-------|---------------------------------|---------|--------|---|-----------|--------------------|---------|--|
| SPI Status    | 0x4320    | D15–3 | -     | reserved                        | -       |        | - | -         | 0 when being read. |         |  |
| Register      | (16 bits) | D2    | SPBSY | Transfer busy flag (master)     | 1       | Busy   | 0 | Idle      | 0                  | R       |  |
| (SPI_ST)      |           |       |       | ss signal low flag (slave)      | 1       | ss = L | 0 | ss = H    |                    |         |  |
|               |           | D1    | SPRBF | Receive data buffer full flag   | 1       | Full   | 0 | Not full  | 0                  | R       |  |
|               |           | D0    | SPTBE | Transmit data buffer empty flag | 1       | Empty  | 0 | Not empty | 1                  | R       |  |

#### D[15:3] Reserved

#### D2 SPBSY: Transfer Busy Flag (Master Mode)/ss Signal Low Flag (Slave Mode)

#### Master mode

Indicates the SPI transfer status.

1 (R): Operating

0 (R): Standby (default)

SPBSY is set to 1 when the SPI starts data transfer in Master mode and is maintained at 1 while transfer is underway.

It is cleared to 0 once the transfer is complete.

#### Slave mode

Indicates the slave selection (#SPISS) signal status.

- 1 (R): Low level (this SPI is selected)
- 0 (R): High level (this SPI is not selected) (default)

SPBSY is set to 1 when the master device sets the #SPISS signal to active to select this SPI module (slave device). It is returned to 0 when the master device clears the SPI module selection by returning the #SPISS signal to inactive.

#### D1 SPRBF: Receive Data Buffer Full Flag

Indicates the receive data buffer status.

1 (R): Data full

0 (R): No data (default)

SPRBF is set to 1 when data received in the shift register is sent to the receive data buffer (when receiving is complete), indicating that the data can be read. It reverts to 0 once the buffer data is read from the SPI\_RXD register (0x4324).

#### D0 SPTBE: Transmit Data Buffer Empty Flag

Indicates the state of the transmit data buffer.

- 1 (R): Empty (default)
- 0 (R): Data exists

SPTBE is set to 0 when transmit data is written to the SPI\_TXD register (transmit data buffer, 0x4322), and is set to 1 when the data is transferred to the shift register (when transmission starts). Transmission data is written to the SPI\_TXD register when this bit is 1.

#### 0x4322: SPI Transmit Data Register (SPI\_TXD)

| Register name | Address   | Bit   | Name       | Function                 | Setting     |     | R/W | Remarks            |
|---------------|-----------|-------|------------|--------------------------|-------------|-----|-----|--------------------|
| SPI Transmit  | 0x4322    | D15-8 | -          | reserved                 | -           | -   | -   | 0 when being read. |
| Data Register | (16 bits) | D7–0  | SPTDB[7:0] | SPI transmit data buffer | 0x0 to 0xff | 0x0 | R/W |                    |
| (SPI_TXD)     |           |       |            | SPTDB7 = MSB             |             |     |     |                    |
|               |           |       |            | SPTDB0 = LSB             |             |     |     |                    |

#### D[15:8] Reserved

#### D[7:0] SPTDB[7:0]: SPI Transmit Data Buffer Bits

Set the transmission data to be written to the transmit data buffer. (Default: 0x0)

In Master mode, transmission is started by writing data to this register. In Slave mode, the contents of this register are sent to the shift register and transmission begins when the clock is input from the master.

SPTBE (D0/SPI\_ST register) is set to 1 (empty) as soon as data written to this register has been transferred to the shift register. A transmit buffer empty interrupt is generated at the same time. The subsequent transmit data can then be written, even while data is being transmitted.

Serial converted data is output from the SDO pin with MSB leading, with the bit set to 1 as High level and the bit set to 0 as Low level.

## Note: Make sure that SPEN (D0/SPI\_CTL register) is set to 1 before writing data to the SPI\_TXD register to start data transmission/reception.

#### 0x4324: SPI Receive Data Register (SPI\_RXD)

| Register name | Address   | Bit   | Name       | Function                | Setting     |     | R/W | Remarks            |
|---------------|-----------|-------|------------|-------------------------|-------------|-----|-----|--------------------|
| SPI Receive   | 0x4324    | D15–8 | -          | reserved                | -           | -   | -   | 0 when being read. |
| Data Register | (16 bits) | D7–0  | SPRDB[7:0] | SPI receive data buffer | 0x0 to 0xff | 0x0 | R   |                    |
| (SPI_RXD)     |           |       |            | SPRDB7 = MSB            |             |     |     |                    |
|               |           |       |            | SPRDB0 = LSB            |             |     |     |                    |

#### D[15:8] Reserved

#### D[7:0] SPRDB[7:0]: SPI Receive Data Buffer Bits

Contain the received data. (Default: 0x0)

SPRBF (D1/SPI\_ST register) is set to 1 (data full) as soon as data is received and the shift register data has been transferred to the receive data buffer. A receive buffer full interrupt is generated at the same time. Data can then be read until subsequent data is received. If receiving the subsequent data is complete before the register has been read out, the new received data overprograms the contents.

Serial data input from the SDI pin with MSB leading is converted to parallel, with the High level bit set to 1 and the Low level bit set to 0. The data is the loaded into this register.

This register is read-only.

| Register name | Address   | Bit    | Name  | Function                               | Setting |          | g | Init.    | R/W | Remarks            |                    |
|---------------|-----------|--------|-------|----------------------------------------|---------|----------|---|----------|-----|--------------------|--------------------|
| SPI Control   | 0x4326    | D15-10 | -     | reserved                               |         | _        |   |          | -   | -                  | 0 when being read. |
| Register      | (16 bits) | D9     | MCLK  | SPI clock source select                | 1       | T16 Ch.1 | 0 | PCLK-1/4 | 0   | R/W                |                    |
| (SPI_CTL)     |           | D8     | MLSB  | LSB/MSB first mode select              | 1       | LSB      | 0 | MSB      | 0   | R/W                |                    |
|               |           | D7–6   | -     | reserved                               |         | -        |   | -        | -   | 0 when being read. |                    |
|               |           | D5     | SPRIE | Receive data buffer full int. enable   | 1       | Enable   | 0 | Disable  | 0   | R/W                |                    |
|               |           | D4     | SPTIE | Transmit data buffer empty int. enable | 1       | Enable   | 0 | Disable  | 0   | R/W                |                    |
|               |           | D3     | СРНА  | Clock phase select                     | 1       | Data out | 0 | Data in  | 0   | R/W                | These bits must be |
|               |           | D2     | CPOL  | Clock polarity select                  | 1       | Active L | 0 | Active H | 0   |                    | set before setting |
|               |           | D1     | MSSL  | Master/slave mode select               | 1       | Master   | 0 | Slave    | 0   | R/W                | SPEN to 1.         |
|               |           | D0     | SPEN  | SPI enable                             | 1       | Enable   | 0 | Disable  | 0   | R/W                |                    |

#### 0x4326: SPI Control Register (SPI\_CTL)

#### D[15:10] Reserved

#### D9 MCLK: SPI Clock Source Select Bit

Selects the SPI clock source.

1 (R/W): 16-bit timer Ch.1 0 (R/W): PCLK-1/4 (default)

#### D8 MLSB: LSB/MSB First Mode Select Bit

Selects whether data is transferred with MSB first or LSB first. 1 (R/W): LSB first 0 (R/W): MSB first (default)

#### D[7:6] Reserved

#### D5 SPRIE: Receive Data Buffer Full Interrupt Enable Bit

Permits or prohibits receive data buffer full SPI interrupts. 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Setting SPRIE to 1 permits the output of SPI interrupt requests to the ITC due to a receive data buffer full. These interrupt requests are generated when the data received in the shift register is transferred to the receive data buffer (when receipt is complete).

SPI interrupts are not generated by receive data buffer full if SPRIE is set to 0.

#### D4 SPTIE: Transmit Data Buffer Empty Interrupt Enable Bit

Permits or prohibits transmit data buffer empty SPI interrupts. 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Setting SPTIE to 1 permits the output of SPI interrupt requests to the ITC due to a transmit data buffer empty. These interrupt requests are generated when the data written to the transmit data buffer is transferred to the shift register (when transmission starts).

SPI interrupts are not generated by transmit data buffer empty if SPTIE is set to 0.

#### D3 CPHA: SPI Clock Phase Select Bit

Selects the SPI clock phase. (Default: 0) Sets the data transfer timing together with CPOL (D2). (See Figure 19.7.1.)

#### D2 CPOL: SPI Clock Polarity Select Bit

Selects the SPI clock polarity. 1 (R/W): Active Low

0 (R/W): Active High (default)

Sets the data transfer timing together with CPHA (D3). (See Figure 19.7.1.)



MSSL: Master/Slave Mode Select Bit

Sets the SPI module to Master or Slave mode.

1 (R/W): Master mode 0 (R/W): Slave mode (default)

Setting MSSL to 1 selects Master mode; setting it to 0 selects Slave mode. Master mode performs data transfer with the clock generated by the 16-bit timer Ch.1. In Slave mode, data is transferred by inputting the clock from the master device.

#### D0 SPEN: SPI Enable Bit

D1

Permits or prohibits SPI module operation. 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Setting SPEN to 1 starts the SPI module operation, enabling data transfer. Setting SPEN to 0 stops the SPI module operation.

#### Note: The SPEN bit should be set to 0 before setting the CPHA, CPOL, and MSSL bits.

### **19.8 Precautions**

- The duty ratio of the clock input via the SPICLK pin must be 50%.
- The SPI\_CTL register (0x4326) must not be accessed while the SPBSY flag (D2/SPI\_ST register) is 1 or the SPRBF flag (D1/SPI\_ST register) is 1.
  - \* SPBSY: Transfer Busy Flag in the SPI Status (SPI\_ST) Register (D2/0x4320)
  - \* SPRBF: Receive Data Buffer Full Flag in the SPI Status (SPI\_ST) Register (D1/0x4320)
- When the SPI module is used in master mode with CPHA (D3/SPI\_CTL register) set to 0, the clock may change a minimum of one system clock (PCLK) cycle time from change of the first transmit data bit.



Figure 19.8.1: SDO and SPICLK Change Timings when CPHA = 0

- The half SPICLK cycle will be secured from change of data to change of the clock for the second and following transmit data bits and the second and following bytes during continuous transfer.
- Make sure that SPEN (D0/SPI\_CTL register) is set to 1 before writing data to the SPI\_TXD register to start data transmission/reception.
  - \* SPEN: SPI Enable Bit in the SPI Control (SPI\_CTL) Register (D0/0x4326)
- The SPEN bit should be set to 0 before setting the CPHA (D3/SPI\_CTL register), CPOL (D2/SPI\_CTL register), and MSSL (D1/SPI\_CTL register) bits.
  - \* CPHA: Clock Phase Select Bit in the SPI Control (SPI\_CTL) Register (D3/0x4326)
  - \* CPOL: Clock Polarity Select Bit in the SPI Control (SPI\_CTL) Register (D2/0x4326)
  - \* MSSL: Master/Slave Mode Select Bit in the SPI Control (SPI\_CTL) Register (D1/0x4326)

# 20 I<sup>2</sup>C

### 20.1 I<sup>2</sup>C Configuration

The S1C17702 incorporates an I<sup>2</sup>C bus interface module for high-speed synchronized serial communications. The I<sup>2</sup>C module operates as a master device (as single master only) using the clock fed from the 16-bit timer Ch.2. It supports standard (100 kbps) and fast (400 kbps) modes as well as 7-bit/10-bit slave address mode. It incorporates a noise filter function to help improve the reliability of data transfers.

This module is capable of generating two different types of interrupts (transmit buffer empty and receive buffer full interrupts) for easy and continuous processing of serial data transfers with interrupts.

Figure 20.1.1 shows the  $I^2C$  module configuration.



Figure 20.1.1: I<sup>2</sup>C module configuration

### 20.2 I<sup>2</sup>C Input/Output Pins

Table 20.2.1 lists the I<sup>2</sup>C pins.

| Pin name I/O Qty Function |     |   |                                                                                                                                                      |  |  |  |  |  |
|---------------------------|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| SDA (P14)                 | I/O | 1 | I <sup>2</sup> C data input/output pin<br>Inputs serial data from the I <sup>2</sup> C bus.<br>Also outputs serial data to the I <sup>2</sup> C bus. |  |  |  |  |  |
| SCL (P15)                 | I/O | 1 | I <sup>2</sup> C clock input/output pin<br>Inputs SCL line status.<br>Also outputs a serial clock.                                                   |  |  |  |  |  |

Table 20.2.1: I<sup>2</sup>C pin list

The I<sup>2</sup>C input/output pins (SDA, SCL) are shared with general purpose input/output port pins (P14, P15) and are initially set as general purpose input/output port pins. The function must be switched using the P1\_PMUX register setting to use general purpose input/output port pins as I<sup>2</sup>C input/output pins. Switch the pins to I<sup>2</sup>C mode by setting the following control bits to 1.

#### $\text{P14}\rightarrow\text{SDA}$

\* P14MUX: P14 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D4/0x52a1)

#### $P15 \rightarrow SCL$

\* P15MUX: P15 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D5/0x52a1)

For detailed information on pin function switching, refer to "10.2 Input/Output Pin Function Selection (Port MUX)."

#### Note: The pins go to high impedance status when the port function is switched.

The SCL and SDA pins do not output a high level, so these lines should be pulled up to  $V_{DD}$  with an external pull-up resistor. Be sure to avoid pulling these pins up to a voltage that exceeds the  $V_{DD}$  level.



Figure 20.2.1: I<sup>2</sup>C connection example

### 20.3 I<sup>2</sup>C Clock

The I<sup>2</sup>C module uses the internal clock output by the 16-bit timer Ch.2 as the synchronizing clock. This clock is output from the SCL pin to the slave device while also driving the shift register. The clock should be programmed to output a signal matching the transfer rate from the 16-bit timer Ch.2. For more information on 16-bit timer control, refer to "11 16-bit Timer (T16)."

When the I<sup>2</sup>C module is used to communicate with a slave device that performs clock stretching, the maximum transfer rate is limited to 50 kbps in standard mode or 200 kbps in fast mode.

The I<sup>2</sup>C module does not function as a slave device. The SCL input pin is used to check the I<sup>2</sup>C bus SCL signal status. It is not used for synchronization clock input.

### 20.4 Settings Before Data Transfer

The I<sup>2</sup>C module includes an optional noise filter function that can be selected via the application program.

#### **Noise filter function**

The I<sup>2</sup>C module incorporates a function for filtering noise from the SDA and SCL pin input signals. This function is enabled by setting NSERM (D4/I2C\_CTL register) to 1.

Note that using this function requires setting the  $I^2C$  clock (16-bit timer Ch.2 output clock) frequency to 1/6 or less of PCLK.

\* NSERM: Noise Remove On/Off Bit in the I<sup>2</sup>C Control (I2C\_CTL) Register (D4/0x4342)

### 20.5 Data Transfer Control

Make the following settings before starting data transfers.

- (1) Set the 16-bit timer Ch.2 to output the  $I^2C$  clock. (See Section 11.)
- (2) Select the option function. (See section 20.4.)
- (3) Set the interrupt conditions to use I<sup>2</sup>C interrupts. (See Section 20.6.)
- Note: Make sure the I<sup>2</sup>C module is halted (when I2CEN/I2C\_EN register = 0) before changing the above settings.

\* I2CEN: I2C Enable Bit in the I2C Enable (I2C\_EN) Register (D0/0x4340)

#### Permitting data transfers

Set the I2CEN (D0/I2C\_EN register) to 1 to permit I<sup>2</sup>C operations. This enables I<sup>2</sup>C transfers and permits clock input/output.

#### Note: Do not set I2CEN to 0 when the I2C module is transferring data.

#### Data transfer start

To start data transfers, the I<sup>2</sup>C master (this module) must generate the start condition. The slave address is then sent to establish communications.

#### (1) Generate start condition

The start condition applies when the SCL line is maintained at High and the SDA line is maintained at Low.



Figure 20.5.1: Start condition

The start condition is generated by setting STRT (D0/I2C\_CTL register) to 1.

\* **STRT**: Start Control Bit in the I<sup>2</sup>C Control (I2C\_CTL) Register (D0/0x4342)

STRT is automatically reset to 0 once the start condition is generated. The  $I^{2}C$  bus is busy from this point on.

#### (2) Slave address transmission

Once the start condition has been generated, the I<sup>2</sup>C master (this module) sends a bit indicating the slave address and transfer direction for communications. I<sup>2</sup>C slave addresses are either 7-bit or 10-bit. This module uses an 8-bit transfer data register to send the slave address and transfer direction bit, enabling single transfers in 7-bit address mode. In 10-bit mode, data is sent twice or three times under software control. Figure 20.5.2 gives the configuration of the address data.

7-bit address D7 D6 D5 D4 D3 D2 D1 D0 A6 ( A5 ) A0 | DIR A4 🕺 A3 A2 A1 Transfer direction Slave address 0: master  $\rightarrow$  slave (transmission) 1: slave  $\rightarrow$  master (reception) 10-bit address D6 D5 D4 D3 D2 D1 D0 D7 First transmit data 1 1 1 1 0 A9 A8 0 2 high order slave address bits D7 D6 D5 D4 D3 D2 D1 D0 Second transmit data ( Α7 A6 🚶 A5 🕺 A4 X A3 X A2 X A1 A0 8 low order slave address bits (When receiving data) Issue a repeated start condition after the second data has been sent and then send the third data as shown below. D5 D4 D3 D2 D1 D0 D7 D6 Third transmit data 0 A9 🛛 A8 1 1 1 1 1 2 high order slave address bits Figure 20.5.2: Slave address and transmission data specifying transfer direction

Transfer direction indicates the data transfer direction after the slave address. This is set to 0 when sending data from the master to the slave and to 1 when receiving data from the slave.

To send a slave address, set the transmission address to RTDT[7:0] (D[7:0]/I2C\_DAT register). At the same time, set the TXE (D9/I2C\_DAT register) transmitting the address to 1.

\* RTDT[7:0]: Receive/Transmit Data Bits in the I<sup>2</sup>C Data (I2C\_DAT) Register (D[7:0]/0x4344)

\* **TXE**: Transmit Execution Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D9/0x4344)

After the slave address has been output, data can be sent and received as many times as required. Data must be sent or received according to the transfer direction set together with the slave address.

#### Data transmission control

The procedure for transmitting data is described below. Data transmission is performed by the same procedure as for slave address transmission.

To send byte data, set the transmission data to RTDT[7:0] (D[7:0]/I2C\_DAT register). Set TXE (D9/I2C\_DAT register) to 1 to transmit 1 byte.

When TXE is set to 1, the I<sup>2</sup>C module begins data transmission in sync with the clock. If the previous data is currently being transmitted, data transmission starts after this has been completed.

The I<sup>2</sup>C module first transfers the data written to the shift register, then starts outputting the clock from SCL. Resetting TXE to 0 at this point generates an interrupt, enabling the subsequent transmission data and TXE to be reset.

The data bits in the shift register are shifted in sequence at the clock falling edge and output via the SDA pin with the MSB leading.

The I<sup>2</sup>C module outputs 9 clocks with each data transmission. In the 9th clock cycle, an ACK or NAK is received from the slave device with the SDA signal as high impedance.

The slave device returns ACK(0) to the master if the data is received. If the data is not received, SDA is not pulled down, which the I<sup>2</sup>C module interprets to mean an NAK(1) (transmission failed).



#### Figure 20.5.3: ACK and NAK

The I<sup>2</sup>C module includes two status bits, TBUSY (D8/I2C\_CTL register) and RTACK (D8/I2C\_DAT register), for transmission control.

- \* TBUSY: Transmit Busy Flag in the I<sup>2</sup>C Control (I2C\_CTL) Register (D8/0x4342)
- \* RTACK: Receive/Transmit ACK Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D8/0x4344)

The TBUSY flag indicates the data transmission status. This flag becomes 1 when transmission starts (including slave address transmission) and reverts to 0 once data transmission ends.

Inspect the flag to check whether the I<sup>2</sup>C module is currently transmitting or at standby.

The RTACK bit indicates whether or not the slave device returned an ACK for the previous transmission. RTACK is 0 if an ACK was returned and 1 if ACK was not returned.

#### Data receipt control

The procedure for receiving data is described below. To receive data, the slave address must be sent with the transfer direction bit set to 1.

To receive data, set RXE (D10/I2C\_DAT register) to 1 for receiving 1 byte.

TXE (D9/I2C\_DAT register) is set to 1 when sending the slave address, but RXE can also be set to 1 at the same time. If both TXE and RXE are set to 1, TXE takes priority.

\* RXE: Receive Execution Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D10/0x4344)

When the RXE bit is set to 1, allowing receiving to start, the I<sup>2</sup>C module starts outputting the clock from the SCL pin with the SDA line at high impedance. The data is shifted into the shift register from the MSB first in sync with the clock.

RXE is reset to 0 when D7 is loaded.

The receive data is loaded to RTDT[7:0] once the 8-bit data has been received in the shift register. The I<sup>2</sup>C module includes two status bits for receive control: RBRDY (D11/I2C\_DAT register) and RBUSY (D9/ I2C\_CTL register).

\* **RBRDY**: Receive Buffer Ready Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D11/0x4344)

\* RBUSY: Receive Busy Flag in the I<sup>2</sup>C Control (I2C\_CTL) Register (D9/0x4342)

The RBRDY flag indicates the receive data status. This flag becomes 1 when the data received in the shift register is loaded to RTDT[7:0] and reverts to 0 when the receive data is read out from RTDT[7:0]. Interrupts can also be generated once the flag value becomes 1.

The RBUSY flag indicates the receiving operation status. This flag is 1 when receiving starts and reverts to 0 when the data is received. Inspect the flag to determine whether the I<sup>2</sup>C module is currently receiving or in standby.

To wait for reception using polling, follow the procedures given below using the RBUSY flag.

Interrupts to the CPU are prohibited because polling accurately determines the two state transitions 3 and 4.

- 1. Prohibits CPU interrupts using di command.
- 2. Writes 1 to RXE to prepare for receiving.
- 3. Waits for RBUSY to become 1 (reception start).
- 4. Waits for RBUSY to become 0 (reception end).
- 5. Reads out RTDT (received data).
- 6. Returns to CPU interrupt permitted state using ei command.

The I<sup>2</sup>C module outputs 9 clocks with each data receipt. In the 9th clock cycle, an ACK or NAK is sent to the slave. The bit state sent can be set in RTACK (D8/I2C\_DAT register). To send ACK, set RTACK to 0. To send NAK, set RTACK to 1.

#### Data transfer end (Stop condition generation)

To end data transfers after all data has been transferred, the I<sup>2</sup>C master (this module) must generate a stop condition. This stop condition applies when the SCL line is maintained at High and the SDA line changes from Low to High.



The stop condition is generated by setting STP (D1/I2C\_CTL register) to 1.

\* STP: Stop Control Bit in the I<sup>2</sup>C Control (I2C\_CTL) Register (D1/0x4342)

When STP is set to 1, the I<sup>2</sup>C module switches the SDA line from Low to High and generates a stop condition while maintaining the I<sup>2</sup>C bus SCL line at High. The I<sup>2</sup>C bus subsequently switches to free state.

Before STP can be set to 1, confirm that TBUSY or RBUSY is reset to 0 from 1 (this indicates that the I<sup>2</sup>C module has finished data transmit/receive operation) and then make the wait time longer than 1/4 of the I<sup>2</sup>C clock cycle set. When generating a stop condition to the slave device with a clock stretch function, STP must be set to 1 after data transfer (including ACK/NAK transfer) has finished and the time for the slave device to finish clock stretching has elapsed. STP is reset to 0 when the stop condition is generated.

#### Continuing data transfer (Repeated start condition generation)

To make it possible to continue with a different data transfer after data transfer completion, the I<sup>2</sup>C master (this module) can generate a repeated start condition.



Repeated start condition

Figure 20.5.5: Repeated start condition

The repeated start condition is generated by setting STRT (D0/I2C\_CTL register) to 1 when the I<sup>2</sup>C bus is busy.

\* **STRT**: Start Control Bit in the I2C Control (I2C\_CTL) Register (D0/0x4342)

STRT is automatically reset to 0 once the repeated start condition is generated. Slave address transmission is subsequently possible with the I<sup>2</sup>C bus remaining in the busy state.

#### Prohibiting data transfer

After the stop condition has been generated, write 0 to I2CEN to disable data transfers. To determine whether the stop condition has been generated, check to see if STP is automatically cleared to 0 after it is set to 1 by polling.

When I2CEN is set to 0 while the I<sup>2</sup>C bus is in busy status, the SCL and SDA output levels and transfer data at that point cannot be guaranteed.

#### **Timing chart**







### 20.6 I<sup>2</sup>C Interrupts

The I<sup>2</sup>C module includes a function for generating the following two different interrupt types.

- Transmit buffer empty interrupt
- Receive buffer full interrupt

The I<sup>2</sup>C module outputs one interrupt signal shared by the two above interrupt factor types to the interrupt controller (ITC).

#### Transmit buffer empty interrupt

To use this interrupt, set TINTE (D0/I2C\_ICTL register) to 1. If TINTE is set to 0 (default), interrupt requests for this factor will not be sent to the ITC.

\* TINTE: Transmit Interrupt Enable Bit in the I<sup>2</sup>C Interrupt Control (I2C\_ICTL) Register (D0/0x4346)

If transmit buffer empty interrupts are permitted (TINTE = 1), an interrupt request pulse is output to the ITC as soon as the transmit data set in RTDT[7:0] (D[7:0]/I2C\_DAT register) is transferred to the shift register.

\* RTDT[7:0]: Receive/Transmit Data Bits in the I<sup>2</sup>C Data (I2C\_DAT) Register (D[7:0]/0x4344)

The transmit buffer empty interrupt will only occur during data transmission.

#### To clear the cause of transmit buffer empty interrupt

The cause of transmit buffer empty interrupt can be cleared by writing data to RTDT[7:0]. If TXE (D9/I2C\_DAT register) is set to 0 at the same time, the I<sup>2</sup>C module only clears the cause of interrupt without sending the data written.

\* TXE: Transmit Execution Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D9/0x4344)

#### **Receive buffer full interrupt**

To use this interrupt, set RINTE (D1/I2C\_ICTL register) to 1. If RINTE is set to 0 (default), interrupt requests for this factor will not be sent to the ITC.

\* RINTE: Receive Interrupt Enable Bit in the I<sup>2</sup>C Interrupt Control (I2C\_ICTL) Register (D1/0x4346)

If receive buffer full interrupts are permitted (RINTE = 1), an interrupt request pulse is output to the ITC as soon as the data received in the shift register is loaded to RTDT[7:0].

The receive buffer full interrupt will only occur during data reception.

#### To clear the cause of receive buffer full interrupt

The cause of receive buffer full interrupt can be cleared by reading data from RTDT[7:0].

Note: After an I<sup>2</sup>C interrupt occurs, determine whether a transmit buffer empty interrupt or a receive buffer full interrupt has occurred according to the I<sup>2</sup>C master transmit/receive processing being executed at that time. Note that it cannot be checked using a register.

#### Interrupt vectors

The I<sup>2</sup>C interrupt vector numbers and vector addresses are as listed below.

Vector number: 19 (0x13) Vector address: TTBR + 0x4c

#### Other interrupt settings

The ITC allows the priority of I<sup>2</sup>C interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### 20.7 Control Register Details

| Address |          | Register name                               | Function                                             |  |  |  |  |  |  |  |  |
|---------|----------|---------------------------------------------|------------------------------------------------------|--|--|--|--|--|--|--|--|
| 0x4340  | I2C_EN   | I <sup>2</sup> C Enable Register            | I <sup>2</sup> C module enable                       |  |  |  |  |  |  |  |  |
| 0x4342  | I2C_CTL  | I <sup>2</sup> C Control Register           | I <sup>2</sup> C control and transfer status display |  |  |  |  |  |  |  |  |
| 0x4344  | I2C_DAT  | I <sup>2</sup> C Data Register              | Transfer data                                        |  |  |  |  |  |  |  |  |
| 0x4346  | I2C_ICTL | I <sup>2</sup> C Interrupt Control Register | I <sup>2</sup> C interrupt control                   |  |  |  |  |  |  |  |  |

#### Table 20.7.1: I<sup>2</sup>C register list

The I<sup>2</sup>C module registers are described in detail below. These are 16-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

#### 0x4340: I<sup>2</sup>C Enable Register (I2C\_EN)

| Register name                | Address   | Bit   | Name  | Function                | Setting |        |           | Init. | R/W                | Remarks |
|------------------------------|-----------|-------|-------|-------------------------|---------|--------|-----------|-------|--------------------|---------|
| I <sup>2</sup> C Enable Reg- | 0x4340    | D15–1 | -     | reserved                | _       |        | -         | -     | 0 when being read. |         |
| ister                        | (16 bits) |       |       |                         |         |        |           |       |                    | -       |
| (I2C_EN)                     |           | D0    | I2CEN | I <sup>2</sup> C enable | 1       | Enable | 0 Disable | 0     | R/W                |         |

#### D[15:1] Reserved

#### D0 I2CEN: I<sup>2</sup>C Enable Bit

Permits or prohibits I<sup>2</sup>C module operation.

1 (R/W): Permitted

0 (R/W): Prohibited (default)

Setting I2CEN to 1 starts the I<sup>2</sup>C module operation, enabling data transfer. Setting I2CEN to 0 stops the I<sup>2</sup>C module operation.

| Register name            | Address   | Bit    | Name  | Function            | Setting |       |   | Init.   | R/W | Remarks            |                    |
|--------------------------|-----------|--------|-------|---------------------|---------|-------|---|---------|-----|--------------------|--------------------|
| I <sup>2</sup> C Control | 0x4342    | D15–10 | -     | reserved            | -       |       |   | -       | -   | 0 when being read. |                    |
| Register                 | (16 bits) | D9     | RBUSY | Receive busy flag   | 1       | Busy  | 0 | Idle    | 0   | R                  |                    |
| (I2C_CTL)                |           | D8     | TBUSY | Transmit busy flag  | 1       | Busy  | 0 | Idle    | 0   | R                  |                    |
|                          |           | D7–5   | -     | reserved            |         | _     |   |         | -   | -                  | 0 when being read. |
|                          |           | D4     | NSERM | Noise remove on/off | 1       | On    | 0 | Off     | 0   | R/W                |                    |
|                          |           | D3–2   | -     | reserved            |         | -     | - |         | -   | -                  | 0 when being read. |
|                          |           | D1     | STP   | Stop control        | 1       | Stop  | 0 | Ignored | 0   | R/W                |                    |
|                          |           | D0     | STRT  | Start control       | 1       | Start | 0 | Ignored | 0   | R/W                |                    |

#### 0x4342: I<sup>2</sup>C Control Register (I2C\_CTL)

#### D[15:10] Reserved

#### D9 RBUSY: Receive Busy Flag

Indicates the I<sup>2</sup>C receipt status.

1 (R): Operating

0 (R): Standby (default)

RBUSY is set to 1 when the I<sup>2</sup>C starts data receiving and is maintained at 1 while receiving is underway. It is cleared to 0 once receipt is complete.

#### D8 TBUSY: Transmit Busy Flag

Indicates the I<sup>2</sup>C transmission status.

- 1 (R): Operating
- 0 (R): Standby (default)

TBUSY is set to 1 when the I<sup>2</sup>C starts data transmission and is maintained at 1 while transmission is underway. It is cleared to 0 once transmission is complete.

#### D[7:5] Reserved

#### D4 NSERM: Noise Remove On/Off Bit

Turns the noise filter function on or off. 1 (R/W): On

0 (R/W): Off (default)

The I<sup>2</sup>C module incorporates a function for filtering noise from the SDA and SCL pin input signals. This function is enabled by setting NSERM to 1.

Note that using this function requires setting the  $I^2C$  clock (16-bit timer Ch.2 output clock) frequency to 1/6 or less of PCLK.

#### D[3:2] Reserved

#### D1 STP: Stop Control Bit

Generates the stop condition.

1 (R/W): Stop condition generated

0 (R/W): Disabled (default)

With STP set at 1, the I<sup>2</sup>C module generates the stop condition by changing the SDA line from Low to High while maintaining the I<sup>2</sup>C bus SCL line at High. The I<sup>2</sup>C bus subsequently becomes free.

Before STP can be set to 1, confirm that TBUSY or RBUSY is reset to 0 from 1 (this indicates that the I<sup>2</sup>C module has finished data transmit/receive operation) and then make the wait time longer than 1/4 of the I<sup>2</sup>C clock cycle set. When generating a stop condition to the slave device with a clock stretch function, STP must be set to 1 after data transfer (including ACK/NAK transfer) has finished and the time for the slave device to finish clock stretching has elapsed.

STP is automatically reset to 0 if the stop condition is generated.

#### D0 STRT: Start Control Bit

Generates the start condition. 1 (R/W): Start condition generated 0 (R/W): Disabled (default)

With STRT set at 1, the I<sup>2</sup>C module generates the start condition by changing the SDA line to Low while maintaining the I<sup>2</sup>C bus SCL line at High.

The repeated start condition can be generated by setting STRT to 1 when the I<sup>2</sup>C bus is busy.

STRT is automatically reset to 0 once the start condition or repeated start condition is generated. The  $I^2C$  bus subsequently becomes busy.

| Register name         | Address   | Bit    | Name      | Function              | Setting |          |     | Init.   | R/W | Remarks |                    |
|-----------------------|-----------|--------|-----------|-----------------------|---------|----------|-----|---------|-----|---------|--------------------|
| I <sup>2</sup> C Data | 0x4344    | D15-12 | -         | reserved              | -       |          |     |         | -   | -       | 0 when being read. |
| Register              | (16 bits) | D11    | RBRDY     | Receive buffer ready  | 1       | Ready    | 0   | Empty   | 0   | R       |                    |
| (I2C_DAT)             |           | D10    | RXE       | Receive execution     | 1       | Receive  | 0   | Ignored | 0   | R/W     |                    |
|                       |           | D9     | ТХЕ       | Transmit execution    | 1       | Transmit | 0   | Ignored | 0   | R/W     |                    |
|                       |           | D8     | RTACK     | Receive/transmit ACK  | 1       | Error    | 0   | ACK     | 0   | R/W     |                    |
|                       |           | D7–0   | RTDT[7:0] | Receive/transmit data |         | 0x0 te   | o 0 | xff     | 0x0 | R/W     |                    |
|                       |           |        |           | RTDT7 = MSB           |         |          |     |         |     |         |                    |
|                       |           |        |           | RTDT0 = LSB           |         |          |     |         |     |         |                    |

#### 0x4344: I<sup>2</sup>C Data Register (I2C\_DAT)

#### D[15:12] Reserved

#### D11 RBRDY: Receive Buffer Ready Flag

Indicates the receive buffer status.

1 (R): Receive data exists

0 (R): No receive data (default)

The RBRDY flag becomes 1 when the data received in the shift register is loaded to RTDT[7:0] (D[7:0]) and reverts to 0 when the receive data is read out from RTDT[7:0]. Interrupts can also be generated once the flag value becomes 1.

Note: Use the RBUSY flag when awaiting reception using polling. The RBRDY flag cannot be used to await reception with polling. For more information on awaiting reception control procedures using polling, refer to "Data receipt control" in "20.5 Data Transfer Control."

#### D10 RXE: Receive Execution Bit

Receives 1 byte of data. 1 (R/W): Data receipt start

0 (R/W): Disabled (default)

Setting RXE to 1 and TXE (D9) to 0 starts receiving for 1 byte of data. RXE can be set to 1 for subsequent receipt, even if the slave address is being sent or data is being received. RXE is reset to 0 as soon as D7 is loaded to the shift register.

#### D9 TXE: Transmit Execution Bit

Transmits 1 byte of data. 1 (R/W): Data transmission start

0 (R/W): Disabled (default)

Transmission is started by setting the transmission data to RTDT[7:0] (D[7:0]) and writing 1 to TXE. TXE can be set to 1 for subsequent transmission, even if the slave address or data is being sent. TXE is reset to 0 as soon as the data set in RTDT[7:0] is transferred to the shift register.

#### D8 RTACK: Receive/Transmit ACK Bit

When transmitting data Indicates the response bit status. 1 (R/W): Error (NAK) 0 (R/W): ACK (default)

RTACK becomes 0 when ACK is returned from the slave after 1 byte of data is sent, indicating that the slave has received the data correctly. If RTACK is 1, the slave device is not operating or the data was not received correctly.

When receiving data Sets the response bit sent to the slave. 1 (R/W): Error (NAK) 0 (R/W): ACK (default)

To return an ACK after data has been received, RTACK should be set to 0 before the I<sup>2</sup>C module sends the response bit.

To return an NAK, set RTACK to 1.

#### D[7:0] RTDT[7:0]: Receive/Transmit Data Bits

#### When sending data

Set the transmission data. (Default: 0x0)

Data transmission is started by setting TXE (D9) to 1. If a slave address or data is currently being transmitted, transmission begins once the previous transmission is completed. Serial converted data is output from the SDA pin with MSB leading and bits set to 0 as Low level.

A transmit buffer empty interrupt factor is generated as soon as the data written to this register is transferred to the shift register, after which the subsequent transmission data can be written.

#### When receiving data

Read the receive data. (Default: 0x0)

Data receipt is started by setting RXE (D10) to 1. If a slave address is currently being transmitted or data is currently being received, the new receipt starts once the previous data has been transferred. The RBRDY flag (D11) is set and a receive buffer full interrupt factor generated as soon as receipt is complete and the shift register data is transferred to this register. Data can then be read until the subsequent data has been received. If the subsequent data is received before this register is read out, the contents are overwritten by the most received data.

Serial data input from the SDA pin with MSB leading is converted to parallel, with the High level bit set to 1 and the Low level bit set to 0, then loaded to this register.

#### 0x4346: I<sup>2</sup>C Interrupt Control Register (I2C\_ICTL)

| Register name              | Address   | Bit   | Name  | Function                  | Setting |        |           | Init. | R/W | Remarks            |
|----------------------------|-----------|-------|-------|---------------------------|---------|--------|-----------|-------|-----|--------------------|
| I <sup>2</sup> C Interrupt | 0x4346    | D15–2 | -     | reserved                  |         | _      |           | -     | -   | 0 when being read. |
| Control Register           | (16 bits) | D1    | RINTE | Receive interrupt enable  | 1       | Enable | 0 Disable | 0     | R/W |                    |
| (I2C_ICTL)                 |           | D0    | TINTE | Transmit interrupt enable | 1       | Enable | 0 Disable | 0     | R/W |                    |

#### D[15:2] Reserved

#### D1 RINTE: Receive Interrupt Enable Bit

Permits or prohibits receive buffer full I2C interrupts.

1 (R/W): Permitted

0 (R/W): Prohibited (default)

Setting RINTE to 1 permits the output of I<sup>2</sup>C interrupt requests to the ITC due to a receive data buffer full. These interrupt requests are generated when the data received in the shift register is transferred to RTDT[7:0] (D[7:0]/I2C\_DAT register) (when receipt is complete).

I<sup>2</sup>C interrupts are not generated by receive data buffer full if RINTE is set to 0.

#### D0 TINTE: Transmit Interrupt Enable Bit

Permits or prohibits transmit buffer empty I<sup>2</sup>C interrupts.

1 (R/W): Permitted

0 (R/W): Prohibited (default)

Setting TINTE to 1 permits the output of  $I^2C$  interrupt requests to the ITC due to a transmit buffer empty. These interrupt requests are generated when the data written to RTDT[7:0] (D[7:0]/I2C\_DAT register) is transferred to the shift register.

I<sup>2</sup>C interrupts are not generated by transmit buffer empty if TINTE is set to 0.

# 21 Remote Controller (REMC)

### 21.1 REMC Configuration

The S1C17702 incorporates a remote controller (REMC) module for generating infrared remote control communication signals. The REMC module consists of a carrier generation circuit for generating a carrier signal using the prescaler output clock, an 8-bit down-counter for counting the transferred data length, a modulation circuit for generating transmission data of the specified carrier length, and an edge detection circuit for detecting input signal rising and falling edges.

The module is also capable of generating counter underflow interrupts indicating that the specified data length has been transmitted and input rising/falling edge detection interrupts for data receipt processing. Figure 21.1.1 shows the REMC module configuration.



### 21.2 REMC Input/output Pin

Table 21.2.1 lists the REMC input/output pins.

| Pin name   | I/O | Qty | Function                                                                                   |  |
|------------|-----|-----|--------------------------------------------------------------------------------------------|--|
| REMI (P02) | I   |     | Remote control transmit data input pin<br>Inputs receive data.                             |  |
| REMO (P03) | 0   |     | Remote control transmit data output pin<br>Outputs modulated remote control transmit data. |  |

Table 21.2.1: REMC input/output pin list

The REMC module input/output pins (REMI, REMO) are shared with general purpose input/output port pins (P02, P03) and are initially set as general purpose input/output port pins. The function must be switched using the P0\_PMUX register setting to use general purpose input/output port pins as REMC input/output pins. Switch the pins to REMC input/output by setting the following control bits to 1.

#### $\text{P02} \rightarrow \text{REMI}$

\* P02MUX: P02 Port Function Select Bit in the P0 Port Function Select (P0\_PMUX) Register (D2/0x52a0)

#### $\text{P03} \rightarrow \text{REMO}$

\* P03MUX: P03 Port Function Select Bit in the P0 Port Function Select (P0\_PMUX) Register (D3/0x52a0)

For detailed information on pin function switching, refer to "10.2 Input/output Pin Function Selection (Port MUX)."

### 21.3 Carrier Generation

The REMC module incorporates a carrier generation circuit that generates a carrier signal for transmission in accordance with the clock set by the software and carrier H and L section lengths.

The prescaler output clock is used for the carrier signal generation clock. The prescaler generates 15 different clocks, dividing the PCLK clock from 1/1 to 1/16K. One is selected by CGCLK[3:0] (D[15:12]/REMC\_PSC register).

\* CGCLK[3:0]: Carrier Generator Clock Select Bits in the REMC Prescaler Clock Select (REMC\_PSC) Register (D[15:12]/0x5340)

| CGCLK[3:0] | Prescaler output clock | CGCLK[3:0] | Prescaler output clock |
|------------|------------------------|------------|------------------------|
| Oxf        | Reserved               | 0x7        | PCLK-1/128             |
| 0xe        | PCLK-1/16384           | 0x6        | PCLK-1/64              |
| 0xd        | PCLK-1/8192            | 0x5        | PCLK-1/32              |
| Охс        | PCLK-1/4096            | 0x4        | PCLK-1/16              |
| 0xb        | PCLK-1/2048            | 0x3        | PCLK-1/8               |
| 0xa        | PCLK-1/1024            | 0x2        | PCLK-1/4               |
| 0x9        | PCLK-1/512             | 0x1        | PCLK-1/2               |
| 0x8        | PCLK-1/256             | 0x0        | PCLK-1/1               |

| Table 21.3.1: | Carrier | generation | clock | selection |
|---------------|---------|------------|-------|-----------|

(Default: 0x0)

For more information on prescaler control, refer to "9 Prescaler (PSC)."

### Note: The prescaler must run before the REMC module.

The carrier H and L section lengths are set by REMCH[5:0] (D[5:0]/REMC\_CARH register) and REMCL[5:0] (D[13:8]/REMC\_CARL register), respectively. These registers set a value corresponding to the number of clock cycles selected above + 1.

- \* **REMCH[5:0]**: H Carrier Length Setup Bits in the REMC H Carrier Length Setup (REMC\_CARH) Register (D[5:0]/ 0x5342)
- \* REMCL[5:0]: L Carrier Length Setup Bits in the REMC L Carrier Length Setup (REMC\_CARL) Register (D[13:8]/0x5342)

The carrier H and L section lengths can be calculated as follows:

Carrier H section length = 
$$\frac{\text{REMCH} + 1}{\text{clk}_{in}}$$
 [s]  
Carrier L section length =  $\frac{\text{REMCL} + 1}{\text{clk}_{in}}$  [s]

REMCH: Carrier H section length register data value

- REMCL: Carrier L section length register data value
- clk\_in: Prescaler output clock frequency

The carrier signal is generated from these settings as shown in Figure 21.3.1.



### 21.4 Data Length Counter Clock Settings

The data length counter is an 8-bit counter for setting data lengths when transmitting data.

When a value corresponding to the data pulse width is written during data transmission, the data length counter begins counting down from that value, generating an underflow interrupt factor and halting when the counter reaches 0.

The subsequent transmit data is set using this interrupt.

This counter is also used for data receiving, enabling measurement of the receive data length. Interrupts can be generated at the input signal rising or falling edges when receiving data. The data pulse length can be obtained from the difference between data pulses by setting the data length counter to 0xff using the interrupt when the input changes and by reading out the count value when a subsequent interrupt occurs due to input changes.

This data length counter count clock also uses a prescaler output clock and can select one of 15 different types. The prescaler output clock is selected by the control bit LCCLK[3:0] (D[11:8]/REMC\_CFG register) provided separately to the carrier generation clock.

\* LCCLK[3:0]: Length Counter Clock Select Bits in the REMC Prescaler Clock Select (REMC\_CFG) Register (D[11:8]/0x5340)

| LCCLK[3:0] | Prescaler output clock | LCCLK[3:0] | Prescaler output clock |
|------------|------------------------|------------|------------------------|
| Oxf        | Reserved               | 0x7        | PCLK-1/128             |
| 0xe        | PCLK-1/16384           | 0x6        | PCLK-1/64              |
| 0xd        | PCLK-1/8192            | 0x5        | PCLK-1/32              |
| Охс        | PCLK-1/4096            | 0x4        | PCLK-1/16              |
| 0xb        | PCLK-1/2048            | 0x3        | PCLK-1/8               |
| 0xa        | PCLK-1/1024            | 0x2        | PCLK-1/4               |
| 0x9        | PCLK-1/512             | 0x1        | PCLK-1/2               |
| 0x8        | PCLK-1/256             | 0x0        | PCLK-1/1               |

| Table 21.4.1: Data | length counter | clock selection |
|--------------------|----------------|-----------------|
| Table 21.4.1. Data | length counter | CIOCK Selection |

(Default: 0x0)

The data length counter can count up to 256. The count clock should be selected to ensure that the data length fits within this range.

### 21.5 Data Transfer Control

Make the following settings before starting data transfers.

- (1) Set the carrier signal. (See Section 21.3.)
- (2) Select the data length counter clock. (See Section 21.4.)
- (3) Set the interrupt conditions. (See Section 21.6.)

# Note: Make sure the REMC module is halted (when REMEN/REMC\_CFG register = 0) before changing the above settings.

\* REMEN: REMC Enable Bit in the REMC Configuration (REMC\_CFG) Register (D0/0x5340)

### Data transfer control



(1) Data transmit mode setting

Set REMC to transmit mode by writing 0 to REMMD (D1/REMC\_CFG register).

\* REMMD: REMC Mode Select Bit in the REMC Configuration (REMC\_CFG) Register (D1/0x5340)

(2) Permit data transmission

Permit REMC operation by setting REMEN (D0/REMC\_CFG register) to 1. This initiates REMC transmission.

Set REMDT (D0/REMC\_ST register) to 0 and REMLEN[7:0] (D[7:0]/REMC\_LCNT register) to 0x0 before setting REMEN to 1 to prevent unnecessary data transmission.

(3) Transmission data settings

Set the data to be transmitted (High or Low) to REMDT (D0/REMC\_ST register).

\* REMDT: Transmit/Receive Data Bit in the REMC Status (REMC\_ST) Register (D0/0x5344)

Setting REMDT to 1 outputs High; setting it to 0 outputs Low from the REMO pin after being modulated by the carrier signal.

(4) Data pulse length setting

Set the value corresponding to the data pulse length (High or Low section) at the start of transmission to REMLEN[7:0] (D[15:8]/REMC\_LCNT register) to set to the data length counter.

\* **REMLEN[7:0]**: Transmit/Receive Data Length Count Bits in the REMC Length Counter (REMC\_LCNT) Register (D[15:8]/0x5344)

#### 21 REMOTE CONTROLLER (REMC)

Given below are the values to which the data length counter is set:

Setting = Data pulse length (seconds) x prescaler output clock frequency (Hz)

The data length counter begins counting down from the value written using the prescaler output clock selected. An underflow interrupt factor occurs when the data length counter value reaches 0. If interrupts are permitted, an REMC interrupt request is output to the interrupt controller (ITC). The data length counter stops counting when it reaches 0.

#### (5) Interrupt processing

To transmit the subsequent data, set the subsequent data (step 3) and set the data pulse length (step 4) as part of the interrupt handler routine generated by the data length counter underflow.

#### (6) Data transmission end

To end data transmission, set REMEN to 0 after the final data transmission is complete (after underflow interrupt has occurred).

### Data receipt control





#### (1) Data receipt mode setting

Set REMC to receipt mode by writing 1 to REMMD (D1/REMC\_CFG register).

#### (2) Permit data receipt

Permit REMC operation by setting REMEN (D0/REMC\_CFG register) to 1. This initiates REMC transmission (input edge detection operation).

REMC detects input changes (signal rising or falling edges) by sampling the input signal from the REMI pin using the prescaler output clock selected for carrier generation. If a signal edge is detected, a rising or falling edge interrupt factor is generated. An REMC interrupt request is output to the ITC if interrupts are permitted. Rising edge and falling edge interrupts can be individually permitted or blocked.

Note that if the signal level after the input has changed is not detected for at least two continuous sampling clock cycles, the interrupt factor is interpreted as noise, and no rising or falling edge interrupt is generated.

### (3) Interrupt processing

When a rising edge or falling edge interrupt occurs, 0xff is written to REMLEN[7:0] (D[15:8]/REMC\_LCNT register) as part of the interrupt handler routine and set as the value of the data length counter.

The data length counter begins counting down using the selected prescaler output clock from the value written.

The data received can be read out from REMDT (D0/REMC\_LCNT register).

The subsequent trailing or rising edge interrupt is generated once the data pulse ends, at which point the data length counter is read out. The data length can be calculated from the difference between 0xff and the value read. To receive the subsequent data, set the data length counter to 0xff once again, then wait for the subsequent interrupt.

If the data length counter becomes 0 after being set to 0xff without the occurrence of an edge interrupt, either data receiving is complete or a receive error has occurred. Data length counter underflow interrupts are generated even when receiving data and should be used for end/error processing.

#### (4) Data receipt end

To end data receipt, program 0 to REMEN after the final data has been received.

### 21.6 REMC Interrupts

The REMC module includes functions to generate the following three different interrupt types.

- · Underflow interrupt
- · Rising edge interrupt
- · Falling edge interrupt

The REMC module outputs one interrupt signal shared by the three interrupt factors above to the interrupt controller (ITC). To identify the interrupt factor that occurred, inspect the interrupt flag within the REMC module.

### **Underflow interrupt**

Generated when the data length counter has counted down to 0, this interrupt request sets the interrupt flag REMUIF (D0/REMC\_IFLG register) inside the REMC to 1.

When data is being transmitted, the underflow interrupt indicates that the specified data length has been transmitted. When receiving data, the underflow interrupt indicates that data has been received or that a receive error has occurred.

\* REMUIF: Underflow Interrupt Flag in the REMC Interrupt Flag (REMC\_INT) Register (D0/0x5346)

To use this interrupt, set REMUIE (D0/REMC\_IMSK register) to 1. If REMUIE is set to 0 (default), REMUIF will not be set to 1, and the interrupt request attributable to this factor will not be sent to the ITC.

\* REMUIE: Underflow Interrupt Enable Bit in the REMC Interrupt Mask (REMC\_IMSK) Register (D0/0x5346)

When REMUIF is set to 1, REMC outputs an interrupt request signal to the ITC. This interrupt request sets the REMC interrupt flag to 1 within the ITC, and generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

REMUIF should be inspected as part of the REMC interrupt handler routine to determine whether the REMC interrupt is attributable to data length counter underflow.

The interrupt factor should be cleared as part of the interrupt handler routine by resetting both the ITC REMC interrupt flag and REMC module REMUIF (i.e., setting both to 1).

### **Rising edge interrupt**

Generated when the REMI pin input signal changes from Low to High, this interrupt request sets the interrupt flag REMRIF (D1/REMC\_IFLG register) to 1 within the REMC.

When data is being received, the data length counter can be operated between this interrupt and a falling edge interrupt to calculate the received data pulse width from that count value.

\* REMRIF: Rising Edge Interrupt Flag in the REMC Interrupt Flag (REMC\_INT) Register (D1/0x5346)

To use this interrupt, set REMRIE (D1/REMC\_IMSK register) to 1. If REMRIE is set to 0 (default), REMRIF is not set to 1 and the interrupt request for this factor is not sent to the ITC.

\* REMRIE: Rising Edge Interrupt Enable Bit in the REMC Interrupt Mask (REMC\_INT) Register (D1/0x5346)

When REMRIF is set to 1, REMC outputs an interrupt request to the ITC. This interrupt request signal sets the REMC interrupt flag to 1 within the ITC, generating an interrupt if the ITC and S1C17 core interrupt conditions are met.

REMRIF should be inspected as part of the REMC interrupt handler routine to determine whether the REMC interrupt is attributable to input signal rising edge.

The interrupt factor should be cleared as part of the interrupt handler routine by resetting both the ITC REMC interrupt flag and REMC module REMRIF (i.e., setting both to 1).

### Falling edge interrupt

Generated when the REMI pin input signal changes from High to Low, this interrupt request sets the interrupt flag REMRIF (D2/REMC\_INT register) to 1 within the REMC.

When data is being received, the data length counter can be operated between this interrupt and a falling edge interrupt to calculate the received data pulse width from that count value.

\* REMFIF: Falling Edge Interrupt Flag in the REMC Interrupt Flag (REMC\_INT) Register (D2/0x5346)

To use this interrupt, set REMFIE (D2/REMC\_IMSK register) to 1. If REMFIE is set to 0 (default), REMFIF is not set to 1 and the interrupt request for this factor is not sent to the ITC.

\* REMFIE: Falling Edge Interrupt Enable Bit in the REMC Interrupt Mask (REMC\_INT) Register (D2/0x5346)

When REMFIF is set to 1, REMC outputs an interrupt request to the ITC. This interrupt request signal sets the REMC interrupt flag to 1 within the ITC, generating an interrupt if the ITC and S1C17 core interrupt conditions are met.

REMFIF should be inspected as part of the REMC interrupt handler routine to determine whether the REMC interrupt is attributable to input signal falling edge.

The interrupt factor should be cleared as part of the interrupt handler routine by resetting both the ITC REMC interrupt flag and REMC module REMFIF (i.e., setting both to 1).

### Interrupt vectors

The REMC interrupt vector numbers and vector addresses are as listed below.

Vector number: 17 (0x11) Vector address: TTBR + 0x44

### Other interrupt settings

The ITC allows the priority of REMC interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### 21.7 Control Register Details

#### Table 21.7.1: REMC register list

| Address |           | Register name                      | Function                                      |
|---------|-----------|------------------------------------|-----------------------------------------------|
| 0x5340  | REMC_CFG  | REMC Configuration Register        | Clock and transfer control                    |
| 0x5342  | REMC_CAR  | REMC Carrier Length Setup Register | Carrier H/L section length setting            |
| 0x5344  | REMC_LCNT | REMC Length Counter Register       | Transfer bit and transfer data length setting |
| 0x5346  | REMC_INT  | REMC Interrupt Mask Register       | Interrupt control                             |

The REMC registers are described in detail below. These are 16-bit registers.

Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.

### 0x5340: REMC Configuration Register (REMC\_CFG)

| Register name         | Address                 | Bit    | Name       | Function                                                | Set                                                                                                                 | ting                                                                                                                                                                                                        | Init. | R/W | Remarks            |
|-----------------------|-------------------------|--------|------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|--------------------|
| REMC<br>Configuration | <b>0x5340</b> (16 bits) | D15–12 | CGCLK[3:0] | Carrier generator clock select (Prescaler output clock) | CGCLK[3:0]<br>LCCLK[3:0]                                                                                            | Clock                                                                                                                                                                                                       | 0x0   | R/W |                    |
| (REMC_CFG)            | (10 0.3)                | D11-8  |            | Length counter clock select<br>(Prescaler output clock) | 0xf<br>0xe<br>0xd<br>0xc<br>0xb<br>0xb<br>0xa<br>0x9<br>0x8<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0 | reserved<br>PCLK-1/16384<br>PCLK-1/8192<br>PCLK-1/4096<br>PCLK-1/2048<br>PCLK-1/2048<br>PCLK-1/2048<br>PCLK-1/128<br>PCLK-1/128<br>PCLK-1/128<br>PCLK-1/16<br>PCLK-1/18<br>PCLK-1/2<br>PCLK-1/2<br>PCLK-1/2 | 0x0   | R/W |                    |
|                       |                         | D7–2   | _          | reserved                                                |                                                                                                                     | -                                                                                                                                                                                                           | -     | -   | 0 when being read. |
|                       |                         | D1     | REMMD      | REMC mode select                                        | 1 Receive                                                                                                           | 0 Transmit                                                                                                                                                                                                  | 0     | R/W |                    |
|                       |                         | D0     | REMEN      | REMC enable                                             | 1 Enable                                                                                                            | 0 Disable                                                                                                                                                                                                   | 0     | R/W |                    |

### D[15:12] CGCLK[3:0]: Carrier Generator Clock Select Bits

Select a carrier generation clock from the 15 prescaler output clocks.

| CGCLK[3:0] | Prescaler output clock | CGCLK[3:0] | Prescaler output clock |  |  |
|------------|------------------------|------------|------------------------|--|--|
| 0xf        | Reserved               | 0x7        | PCLK-1/128             |  |  |
| 0xe        | PCLK-1/16384           | 0x6        | PCLK-1/64              |  |  |
| 0xd        | PCLK-1/8192            | 0x5        | PCLK-1/32              |  |  |
| 0xc        | PCLK-1/4096            | 0x4        | PCLK-1/16              |  |  |
| 0xb        | PCLK-1/2048            | 0x3        | PCLK-1/8               |  |  |
| 0xa        | PCLK-1/1024            | 0x2        | PCLK-1/4               |  |  |
| 0x9        | PCLK-1/512             | 0x1        | PCLK-1/2               |  |  |
| 0x8        | PCLK-1/256             | 0x0        | PCLK-1/1               |  |  |

#### Table 21.7.2: Carrier generation clock selection

(Default: 0x0)

### D[11:8] LCCLK[3:0]: Length Counter Clock Select Bits

Select a data length counter clock from the 15 prescaler output clocks.

|            | -                      |            |                        |
|------------|------------------------|------------|------------------------|
| LCCLK[3:0] | Prescaler output clock | LCCLK[3:0] | Prescaler output clock |
| Oxf        | Reserved               | 0x7        | PCLK-1/128             |
| 0xe        | PCLK-1/16384           | 0x6        | PCLK-1/64              |
| 0xd        | PCLK-1/8192            | 0x5        | PCLK-1/32              |
| 0xc        | PCLK-1/4096            | 0x4        | PCLK-1/16              |
| 0xb        | PCLK-1/2048            | 0x3        | PCLK-1/8               |
| 0xa        | PCLK-1/1024            | 0x2        | PCLK-1/4               |
| 0x9        | PCLK-1/512             | 0x1        | PCLK-1/2               |
| 0x8        | PCLK-1/256             | 0x0        | PCLK-1/1               |
|            |                        |            |                        |

Table 21.7.3: Carrier generation clock selection

(Default: 0x0)

Note: The clock should be set only while the REMC module is stopped (REMEN(D0) = 0).

### D[7:2] Reserved

### D1 REMMD: REMC Mode Select Bit

Selects the transfer direction. 1 (R/W): Receive

0 (R/W): Transmit (default)

### 21 REMOTE CONTROLLER (REMC)

#### D0 REMEN: REMC Enable Bit

Permits or prohibit data transfer by the REMC module 1 (R/W): Permitted 0 (R/W): Prohibited (default)

Setting REMEN to 1 begins transmission or receiving in accordance with REMMD (D1) settings. Setting REMEN to 0 halts REMC module operations.

### 0x5342: REMC Carrier Length Setup Register (REMC\_CAR)

| Register name | Address   | Bit    | Name       | Function               | Setting     |     | R/W | Remarks            |
|---------------|-----------|--------|------------|------------------------|-------------|-----|-----|--------------------|
| REMC Carrier  | 0x5342    | D15–14 | -          | reserved               | -           | -   | -   | 0 when being read. |
| Length Setup  | (16 bits) | D13–8  | REMCL[5:0] | L carrier length setup | 0x0 to 0x3f | 0x0 | R/W |                    |
| Register      |           | D7–6   | -          | reserved               | -           | -   | -   | 0 when being read. |
| (REMC_CAR)    |           | D5–0   | REMCH[5:0] | H carrier length setup | 0x0 to 0x3f | 0x0 | R/W |                    |

#### D[15:14] Reserved

### D[13:8] REMCL[5:0]: L Carrier Length Setup Bits

Set the carrier signal L section length. (Default: 0x0)

Specify a value corresponding to the number of carrier generation clock cycles selected by CGCLK[3:0] (D[15:12]/REMC\_CFG register) + 1.

Calculate carrier L section length as follows:

Carrier L section length =  $\frac{\text{REMCL} + 1}{\text{clk in}} [s]$ 

REMCL: REMCL[5:0] settings

clk\_in: Prescaler output clock frequency

The H section length is specified by REMCH[5:0] (D[5:0]). The carrier signal is generated from these settings as shown in Figure 21.7.1.

#### D[7:6] Reserved

### D[5:0] REMCH[5:0]: H Carrier Length Setup Bits

Set the carrier signal H section length. (Default: 0x0)

Specify a value corresponding to the number of carrier generation clock cycles selected by CGCLK[3:0] (D[15:12]/REMC\_CFG register) + 1.

Calculate carrier H section length as follows:

Carrier H section length =  $\frac{\text{REMCH} + 1}{\text{clk in}} [s]$ 

REMCH: REMCH[5:0] settings

clk\_in: Prescaler output clock frequency

The L section length is specified by REMCL[5:0] (D[13:8]). The carrier signal is generated from these settings as shown in Figure 21.7.1.

Example: CGCLK[3:0] = 0x2 (PCLK-1/4), REMCH[5:0] = 2, REMCL[5:0] = 1



### 0x5344: REMC Length Counter Register (REMC\_LCNT)

| Register name    | Address   | Bit   | Name        | Function                           | Setting     |         | Init. | R/W | Remarks            |
|------------------|-----------|-------|-------------|------------------------------------|-------------|---------|-------|-----|--------------------|
| REMC Length      | 0x5344    | D15-8 | REMLEN[7:0] | Transmit/receive data length count | 0x0 to 0xff |         | 0x0   | R/W |                    |
| Counter Register | (16 bits) |       |             | (down counter)                     |             |         |       |     |                    |
| (REMC_LCNT)      |           | D7–1  | -           | reserved                           | -           |         | -     | -   | 0 when being read. |
|                  |           | D0    | REMDT       | Transmit/receive data              | 1 1 (H)     | 0 0 (L) | 0     | R/W |                    |

### D[15:8] REMLEN[7:0]: Transmit/Receive Data Length Count Bits

Sets the data length counter value and begins counting. (Default: 0x0)

The counter stops when it reaches 0 and generates an underflow interrupt factor.

### For data transmission

Sets the transmit data length for data transmission.

When a value corresponding to the data pulse width is written, the data length counter begins counting down from that value, generating an underflow interrupt and halting when the counter reaches 0. The subsequent transmit data is set using this interrupt.

### For data receiving

Interrupts can be generated at the input signal rising or falling edges when receiving data. The data pulse length can be obtained from the difference by setting the data length counter to 0xff using the interrupt when the input changes and reading out the count value when the next interrupt occurs due to an input change.

### D[7:1] Reserved

### D0 REMDT: Transmit/Receive Data Bit

Sets the transmit data for data transmission. Receive data can be read when receiving data. 1 (R/W): 1 (H) 0 (R/W): 0 (L) (default)

If REMEN (D0/REMC\_CFG register) is set to 1, the REMDT setting is modulated by the carrier signal for data transmission and output from the REMO pin. For data receiving, this bit is set to the value corresponding to the signal level of the data pulse input.

| Register name    | Address   | Bit    | Name   | Function                      |   | Setting           |   | Init.         | R/W | Remarks            |                     |
|------------------|-----------|--------|--------|-------------------------------|---|-------------------|---|---------------|-----|--------------------|---------------------|
| REMC Interrupt   | 0x5346    | D15-11 | -      | reserved                      |   | _                 |   | -             | -   | 0 when being read. |                     |
| Control Register | (16 bits) | D10    | REMFIF | Falling edge interrupt flag   | 1 | Cause of          | 0 | Cause of      | 0   | R/W                | Reset by writing 1. |
| (REMC_INT)       |           | D9     | REMRIF | Rising edge interrupt flag    | 1 | interrupt         |   | interrupt not | 0   | R/W                |                     |
|                  |           | D8     | REMUIF | Underflow interrupt flag      | 1 | occurred occurred |   | 0             | R/W |                    |                     |
|                  |           | D7–3   | -      | reserved                      | _ |                   |   | -             | -   | 0 when being read. |                     |
|                  |           | D2     | REMFIE | Falling edge interrupt enable | 1 | Enable            | 0 | Disable       | 0   | R/W                |                     |
|                  |           | D1     | REMRIE | Rising edge interrupt enable  | 1 | Enable            | 0 | Disable       | 0   | R/W                |                     |
|                  |           | D0     | REMUIE | Underflow interrupt enable    | 1 | Enable            | 0 | Disable       | 0   | R/W                |                     |

### 0x5346: REMC Interrupt Control Register (REMC\_INT)

This register indicates the occurrence status of interrupt factors arising from data length counter underflow, input signal rising edge, or input signal falling edge. When an REMC interrupt occurs, the interrupt flag in this register should be inspected to identify the interrupt factor.

Setting the corresponding interrupt enable bit to 1 sets the interrupt flag to 1 when a data length counter underflow, input signal rising edge, or input signal falling edge occurs. The REMC outputs an interrupt request signal to the ITC at the same time, which sets the REMC interrupt flag to 1 within the ITC and generates an interrupt if the ITC and S1C17 core interrupt conditions are met.

# Note: • To prevent interrupt recurrences, the REMC module interrupt flag must be reset within the interrupt handler routine following an REMC interrupt.

• To prevent generating unnecessary interrupts, reset the interrupt flag before permitting interrupts by the interrupt enable bit.

### D[15:11] Reserved

### D10 REMFIF: Falling Edge Interrupt Flag

Interrupt flag indicating the falling edge interrupt occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting REMFIE (D2/REMC\_IMSK register) to 1 sets SIF1 to 1 at the input signal falling edge.

### D9 REMRIF: Rising Edge Interrupt Flag

Interrupt flag indicating the rising edge interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting REMRIF (D1/REMC\_IMSK register) to 1 sets REMRIE to 1 at the input signal falling edge.

### D8 REMUIF: Underflow Interrupt Flag

Interrupt flag indicating the underflow interrupt factor occurrence status.

- 1(R): Interrupt factor present
- 0(R): No interrupt factor (default)
- 1(W): Reset flag
- 0(W): Disabled

Setting REMUIE (D1/REMC\_IMSK register) to 1 sets REMUIF to 1 when a data length counter underflow occurs.

### D[7:3] Reserved

### D2 REMFIE: Falling Edge Interrupt Enable Bit

Permits or blocks input signal falling edge interrupts.

1 (R/W): Interrupt permitted

0 (R/W): Interrupt prohibited (default)

### 21 REMOTE CONTROLLER (REMC)

### D1 REMRIE: Rising Edge Interrupt Enable Bit

Permits or blocks input signal rising edge interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)

### D0 REMUIE: Underflow Interrupt Enable Bit Permits or blocks data length counter underflow interrupts. 1 (R/W): Interrupt permitted 0 (R/W): Interrupt prohibited (default)

### 21.8 Precautions

- The prescaler must run before operating the REMC module.
- To prevent interrupt recurrences, the REMC module interrupt flag must be reset within the interrupt handler routine following an REMC interrupt.
- To prevent unwanted interrupts, reset the interrupt flag before permitting interrupts with the interrupt enable bit.

# 22 LCD Driver (LCD)

### 22.1 LCD Driver Configuration

The S1C17702 incorporates a pixel-matrix LCD driver capable of driving LCD panels of up to 2,304 pixels (72 segments  $\times$  32 common) in size. Figure 22.1.1 illustrates the LCD driver and driver power supply configuration.



Figure 22.1.1: LCD driver and driver power supply configuration

### 22.2 LCD Power Supply

LCD driver voltages Vc1 to Vc5 are generated using the internal chip LCD voltage regulator and power supply voltage booster circuit. No external power supply is needed. For more information on the LCD power supply, see "4 Power Supply."

### 22.3 LCD Clock

Figure 22.3.1 illustrates the LCD clock feed system.



Figure 22.3.1: LCD clock system

### 22.3.1 LCD Operating Clock

The LCD driver operation clock (LCLK) is generated by the LCD clock generator within the OSC module. For more information on the OSC module, see "7 Oscillator Circuit (OSC)."

### 22.3.2 Frame Signal

The frame signal is generated by dividing LCLK into 1/1024. The frame frequency is as shown below. The time for 1 frame shown in Figures 22.4.1 and 22.4.2 is the frame frequency.

When OSC1 (32.768 kHz typ.) is selected as the LCD clock source

Frame frequency = 64 Hz (typ.)

When HSCLK is selected as the LCD clock source

Frame frequency =  $\frac{\text{fHSCLK}}{512} \times \text{LCKDV}$  [Hz]

fHSCLK: HSCLK (IOSC or OSC3) clock frequency [Hz] LCKDV: HSCLK division ratio 1/32 to 1/512

### 22.4 Driver Duty Switching

Drive duty can be switched between 1/32 and 1/16 using LDUTY[1:0] (D[1:0]/LCD\_CCTL register). Table 22.4.1 shows the correspondence between LDUTY[1:0] settings, drive duty, and maximum display pixel size.

\* LDUTY[1:0]: LCD Duty Select Bits in the LCD Clock Control (LCD\_CCTL) Register (D[1:0]/0x50a2)

|            |          |                  | •                 |                        |
|------------|----------|------------------|-------------------|------------------------|
| LDUTY[1:0] | Duty     | Valid common pin | Valid segment pin | Max display pixel size |
| 0x3        | Reserved | -                | -                 | -                      |
| 0x2        | 1/32     | COM0 to COM31    | SEG0 to SEG71     | 2,304 pixels           |
| 0x1        | 1/16     | COM0 to COM15    | SEG0 to SEG87     | 1,408 pixels           |
| 0x0        | Reserved | -                | -                 | -                      |

#### Table 22.4.1: Drive duty settings

(Default: 0x2)

Pins COM16 to COM31 and SEG87 to SEG72 are set to common output pins when 1/32 duty is selected and to segment output pins when 1/16 duty is selected.

The drive bias is 1/5 (five potentials Vc1, Vc2, Vc3, Vc4, Vc5) for both 1/32 and 1/16 duty. The drive waveforms are as shown in Figure 22.4.1 and 22.4.2, respectively.





COM0 -

21 -

23 -- H

LΗ Н

22 —

Н

SEGO





Figure 22.4.2: 1/16 duty drive waveform

### 22.5 Display Memory

The S1C17702 incorporates 576 bytes of display memory. The display memory is assigned to addresses 0x80000 to 0x8055f. The correspondence between memory bits and common/segment pins varies depending on the items selected, as follows.

- (1) Drive duty (1/32 or 1/16 duty)
- (2) SEG pin assignment (normal or inverted)
- (3) COM pin assignment (normal or inverted)

Figures 22.5.1 and 22.5.2 show the correspondence between display memory and common/segment pins for each drive duty.

Writing 1 to a display memory bit corresponding to pixels on the LCD panel switches on that pixel, while writing 0 turns off the pixel. Since the display memory is RAM allowing reading and writing, bits can be controlled individually using logic operation instructions (read modify program instructions).

Bits not assigned to the display area within the 576 byte display memory can be used as general RAM for reads and programs.

| Address         |          | Address last 8 bits                                                                      |               | COMREV         | COMREV       |
|-----------------|----------|------------------------------------------------------------------------------------------|---------------|----------------|--------------|
| initial 16 bits | Bit      | 0x00 ··· 0x0f 0x10 ··· 0x1f 0x20 ··· 0x2f 0x30 ··· 0x3f 0x40 ··· 0x47 0x48 ··· 0x5f 0x60 |               | = 1            | = 0          |
|                 | D0       |                                                                                          |               | COM0           | COM31        |
|                 | D1       |                                                                                          |               | COM1           | COM30        |
|                 | D2       |                                                                                          |               | COM2           | COM29        |
| 0x800**         | D3       |                                                                                          |               | COM3           | COM28        |
| 0x000**         | D4       |                                                                                          |               | COM4           | COM27        |
|                 | D5       |                                                                                          |               | COM5           | COM26        |
|                 | D6       |                                                                                          |               | COM6           | COM25        |
|                 | D7       |                                                                                          |               | COM7           | COM24        |
|                 | D0       |                                                                                          |               | COM8           | COM23        |
|                 | D1       |                                                                                          |               | COM9           | COM22        |
|                 | D2       |                                                                                          |               | COM10          | COM21        |
| 0x801**         | D3       |                                                                                          |               | COM11          | COM20        |
|                 | D4       |                                                                                          |               | COM12          | COM19        |
|                 | D5       |                                                                                          |               | COM13          | COM18        |
|                 | D6       |                                                                                          |               | COM14          | COM17        |
|                 | D7       | Display area                                                                             |               | COM15          | COM16        |
|                 | D0       |                                                                                          |               | COM16          | COM15        |
|                 | D1       |                                                                                          |               | COM17          | COM14        |
|                 | D2       |                                                                                          |               | COM18          | COM13        |
| 0x802**         | D3       |                                                                                          |               | COM19          | COM12        |
|                 | D4       |                                                                                          |               | COM20          | COM11        |
|                 | D5       |                                                                                          |               | COM21          | COM10        |
|                 | D6       |                                                                                          |               | COM22          | COM9         |
|                 | D7       | Unused area Unav                                                                         | vailable area | COM23          | COM8         |
|                 | D0<br>D1 | (general memory)                                                                         |               | COM24<br>COM25 | COM7<br>COM6 |
|                 | D1<br>D2 |                                                                                          |               | COM25<br>COM26 | COM5         |
|                 | D2<br>D3 |                                                                                          |               | COM20<br>COM27 | COM5<br>COM4 |
| 0x803**         | D3<br>D4 |                                                                                          |               | COM28          | COM3         |
|                 | D4<br>D5 |                                                                                          |               | COM29          | COM2         |
|                 | D6       |                                                                                          |               | COM20          | COM12        |
|                 | D7       |                                                                                          |               | COM31          | COM0         |
|                 | D0       |                                                                                          |               | 001001         | 001110       |
|                 | D1       |                                                                                          |               |                |              |
|                 | D2       |                                                                                          |               |                |              |
|                 | D3       |                                                                                          |               |                |              |
| 0x804**         | D4       |                                                                                          |               |                |              |
|                 | D5       |                                                                                          |               |                |              |
|                 | D6       |                                                                                          |               |                |              |
|                 | D7       |                                                                                          |               |                |              |
|                 | D0       | 1                                                                                        |               |                |              |
|                 | D1       |                                                                                          |               |                |              |
|                 | D2       |                                                                                          |               |                |              |
| 0x805**         | D3       |                                                                                          |               |                |              |
| 0X0U3**         | D4       |                                                                                          |               |                |              |
|                 | D5       |                                                                                          |               |                |              |
|                 | D6       |                                                                                          |               |                |              |
|                 | D7       |                                                                                          |               |                |              |
| SEGREV          |          | SEG0 ··· SEG15 SEG16 ··· SEG31 SEG32 ··· SEG47 SEG48 ··· SEG63 SEG64 ··· SEG71           |               |                |              |
| SEGREV          | = 0      | SEG71 ··· SEG56 SEG55 ··· SEG40 SEG39 ··· SEG24 SEG23 ··· SEG8 SEG7 ··· SEG0             |               |                |              |

Figure 22.5.1: Display memory map (with 1/32 duty selected)

| Initial 16 bits         Bit         0x00 0x01         0x10 0x11         0x20 0x21         0x30 0x31         0x40 0x41         0x50 0x57         0x58         0x59         0x69 0x17         COM         COM <th>Address</th> <th></th> <th colspan="8">Address last 8 bits</th> <th>COMBEV</th> <th>COMREV</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Address  |     | Address last 8 bits |           |          |        |         |           |          |         | COMBEV | COMREV |       |                  |       |           |      |               |      |              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|---------------------|-----------|----------|--------|---------|-----------|----------|---------|--------|--------|-------|------------------|-------|-----------|------|---------------|------|--------------|
| 00         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          | Bit | 0x00 ·              | 0x0f      | 0x10     | 0x1f   | 0x20    | 0x2f      |          |         | 0x40   | 0x4f   | 0x50  | ··· 0x57         | 0x58  | 0x5       | of 0 | 0x60 ··· 0xff |      | = 0          |
| 0x800++         03<br>05<br>05<br>05<br>05<br>06<br>07         COM2<br>COM4<br>COM5<br>COM6<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          | D0  |                     |           | 1        |        |         |           | 1        |         |        |        |       |                  |       |           |      |               |      | COM15        |
| 0x800++         Da<br>B6<br>05<br>07         COM3<br>COM4<br>COM5<br>COM4<br>COM5<br>COM6<br>COM7<br>COM7<br>COM7<br>COM6<br>COM7<br>COM7<br>COM6<br>COM9<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          | D1  |                     |           |          |        |         |           |          |         |        |        |       |                  | COM1  | COM14     |      |               |      |              |
| 0800+**         D4<br>D5<br>D6<br>D6<br>D7<br>Display area 0 (DSPAR = 0)         COM4<br>COM5<br>COM6<br>COM6<br>COM6<br>COM6<br>COM6<br>COM6<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |     |                     |           |          |        |         |           |          |         |        |        |       | COM13            |       |           |      |               |      |              |
| D4<br>D6<br>D6<br>D7<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 02800**  |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM12        |
| D6<br>D7<br>D0<br>D2<br>D2<br>D3<br>D3<br>D3<br>D5<br>D5         Display area 0 (DSPAR = 0)         Display area 0 (DSPAR = 0)         COME<br>COME<br>COME<br>COME<br>COME<br>COME<br>COME<br>COME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x000**  |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               | COM4 | COM11        |
| D7         Display area 0 (DSPAR = 0)         COW7         COM0         COW8         C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM10        |
| D0<br>D1<br>D2<br>D3<br>D5<br>D5<br>D6<br>D7         Display area 0 (DSPAR = 0)         COMe<br>COM         COME         COM         COM         CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM9         |
| 0x801***         D3<br>D2<br>D4<br>D5<br>D6         COM8<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM1 |          |     |                     |           |          |        | Display | area 0 (D | SPAR = 0 | ))      |        |        |       |                  |       |           |      |               |      | COM8         |
| 0x801+*         D2<br>03<br>05<br>05<br>05<br>07         COM10<br>07         COM10<br>COM12<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>COM<br>07         COM00<br>COM15<br>COM<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15<br>COM<br>07         COM00<br>COM15         COM00<br>COM15         COM00<br>COM15         COM00<br>COM15         COM00<br>COM15         COM00<br>COM15         COM00<br>COM15         COM000<br>COM15         COM000<br>COM15         COM0000<br>COM15         COM00000<br>COM15         COM000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |     |                     |           |          |        | ,       |           |          | ,       |        |        |       |                  |       |           |      |               |      |              |
| 0x801++<br>D5<br>D7<br>07<br>0x802++<br>D5<br>D6<br>D7<br>0x802++<br>D5<br>D6<br>D7<br>0x803++<br>D5<br>0x805++<br>D6<br>D7<br>0x805++<br>D6<br>D7<br>0x805++<br>D6<br>D7<br>0x805++<br>D6<br>D7<br>0x805++<br>D6<br>D7<br>0x805++<br>D6<br>D7<br>0x805++<br>D6<br>D7<br>D1<br>D1<br>D1<br>D2<br>D1<br>D2<br>D3<br>D1<br>D1<br>D2<br>D1<br>D1<br>D2<br>D1<br>D1<br>D2<br>D1<br>D1<br>D1<br>D1<br>D2<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x801**         D4<br>D5<br>D5<br>D6<br>D7         D4<br>D7         COM12<br>COM13<br>COM14<br>COM15<br>D7         COM2<br>COM14<br>COM15<br>COM<br>COM15<br>COM<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1<br>COM1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D5         COM13         COM14         COM14         COM14         COM15         COM16         CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x801**  |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D6<br>D7<br>D1<br>D2<br>D2<br>D3<br>D4<br>D6<br>D6<br>D7<br>D7<br>D6<br>D6<br>D7         COM14<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D7         COM15         COM           D1         D1         D2         COM16         COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D0<br>D1<br>D2<br>D3<br>D4<br>D6<br>D6<br>D7         D0<br>D1<br>D2<br>D3<br>D6<br>D7         Unused area<br>(general memory)         Unused area<br>(general memory)         Unused area<br>(general memory)         Unused area<br>COM4 COM<br>COM4 COM<br>COM5 COM<br>COM5 COM<br>COM6 CO<br>COM6 CO<br>COM6 CO<br>COM6 CO<br>COM6 CO<br>COM6 CO<br>COM6 CO<br>COM7 CO<br>COM6 CO<br>COM7 CO<br>COM7 CO<br>COM6 CO<br>COM7 CO<br>CO<br>COM7 CO<br>CO<br>COM7 CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>C                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COMO         |
| D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7<br>D7         COM1<br>COM2<br>COM2<br>COM2<br>COM2<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM<br>COM3<br>COM3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM15        |
| 0x802***         D3<br>D4<br>D5<br>D6<br>D6<br>D7         COM3<br>COM4<br>COM5<br>COM<br>COM5<br>COM<br>COM7<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM8<br>COM7<br>COM9<br>COM9<br>COM9<br>COM9<br>COM11<br>CO<br>COM9<br>COM11<br>CO<br>COM9<br>COM11<br>CO<br>COM9<br>COM11<br>CO<br>COM9<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM9<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>COM11<br>CO<br>CO<br>COM11<br>CO<br>CO<br>COM11<br>CO<br>CO<br>CO<br>COM11<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO<br>CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM14        |
| 0x802***         D4<br>D6<br>D6<br>D7         COM4<br>COM5<br>COM5<br>COM6<br>COM6<br>COM6<br>COM7<br>COM7<br>COM7<br>COM7<br>COM7<br>COM7<br>COM7<br>COM7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          | D2  |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               | COM2 | COM13        |
| D4         D5         D6         COMA         COMS         COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0.0000   | D3  |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               | COM3 | COM12        |
| D6<br>D7<br>0x803**         D0<br>D1<br>D2<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7         Display area 1 (DSPAR = 1)         Unused area<br>(general memory)         Unused area<br>(general memory)         COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x802**  |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM11        |
| D7         Display area 1 (DSPAR = 1)         Unused area<br>(general memory)         Unavailable area<br>(General memory)         COME<br>COME<br>COME<br>COME<br>COME<br>COME<br>COME<br>COME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM10        |
| D0<br>D1<br>D2<br>D2<br>D3<br>D3<br>D4<br>D5         D1splay area 1 (DSPAR = 1)         (general memory)         Dravalage area<br>COM8<br>COM9<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM10<br>COM12<br>COM12<br>COM12<br>COM12<br>COM12<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>COM14<br>C                                  |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM9         |
| D0         COMB         COMS         C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |     | Display             | area 1 (D | SPAR = 1 | )      |         |           |          |         |        |        |       | Unavailable area |       | COM8      |      |               |      |              |
| D2<br>DX803**         D2<br>D4<br>D5<br>D6<br>D6<br>D7         COM10<br>COM12<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |     |                     |           |          |        |         |           |          | '       |        |        |       |                  | (gene | ral memor | y)   |               | COM8 | COM7         |
| 0x803**         D3<br>D4<br>D5<br>D6<br>D7         COM11<br>COM13<br>COM13<br>COM<br>COM<br>COM13<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM<br>COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x803***         D4         D5         COM12         COM         COM13         COM13         COM14         COM14         COM15         COM         COM14         COM15         COM         COM15         COM         COM15         COM         COM15         COM         COM         COM15         COM         COM         COM15         COM         COM         COM15         COM         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D6<br>D6<br>D7         COM13<br>COM14<br>COM<br>COM<br>COM<br>COM         CO<br>COM<br>COM           D0<br>D1<br>D2<br>D3<br>D4<br>D6<br>D6<br>D6<br>D7         CO         COM15         CO           0x804**         D3<br>D4<br>D5         CO         CO         CO           0x805**         D3<br>D4<br>D5         CO         CO         CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x803**  |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D6<br>D7         COM16<br>COM15         COM<br>COM15         COM15         COM15 <thcom15< th=""> <thcom15< th="">         COM15<td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>COM3<br/>COM2</td></thcom15<></thcom15<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM3<br>COM2 |
| D7         COM15         COM           D0<br>D1<br>D2<br>D3<br>D4<br>D4<br>D5<br>D6<br>D7         D0<br>D3<br>D4<br>D4<br>D5         Image: Comparison of the com                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM1         |
| D0         D1           D2         D3           D4         D4           D5         D6           D7         D0           0x805**         D3           D5         D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      | COM0         |
| D2           D33           D4           D5           D6           D7           D7           D7           D8           D8           D9           D8           D9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |     | -                   |           |          |        |         |           |          |         |        |        |       |                  | +     |           |      |               |      |              |
| 0x804**         D3<br>D4<br>D5<br>D6<br>D7           D7           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07           07                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          | D1  |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x004**         D4           D5         D6           D7         D0           D1         D2           D3         D4           D5         D6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          | D2  |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D4         D5           D6         D7           D7         D0           D1         D2           0x805**         D3           D4         D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 02004++  | D3  |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D6         D7           D0         D1           D2         D2           D3         D4           D5         D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0,004*** |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D7<br>D0<br>D1<br>D2<br>D3<br>D3<br>D4<br>D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x805**<br>D1<br>D2<br>D3<br>D4<br>D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x805** D1<br>D2<br>D3<br>D4<br>D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x805**<br>D2<br>D3<br>D4<br>D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |     | 1                   |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x805** D3<br>D4<br>D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| 0x805** D4<br>D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |     | 1                   |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x805**  |     | 1                   |           |          |        |         |           |          |         |        |        |       |                  | 1     |           |      |               |      |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  | 1     |           |      |               |      |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          | D5  | 1                   |           |          |        |         |           |          |         |        |        |       |                  | 1     |           |      |               |      |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |     | 1                   |           |          |        |         |           |          |         |        |        |       |                  |       |           |      |               |      |              |
| SEGREV = 1 SEG0 ··· SEG15 SEG16 ··· SEG31 SEG32 ··· SEG47 SEG48 ··· SEG63 SEG64 ··· SEG79 SEG80 ··· SEG87                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SEGREV   |     | SEG0 ·              | ·· SEG15  | 5 SEG16  | 6 SEG3 | 1 SEG32 | ··· SEG47 | ' SEG48  | · SEG63 | SEG64  | SEG79  | SEG80 | ··· SEG87        | 1     |           |      |               | -    |              |
| SEGREV = 0 SEG87 ··· SEG72 SEG71 ··· SEG56 SEG55 ··· SEG40 SEG39 ··· SEG24 SEG23 ··· SEG8 SEG7 ··· SEG0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |     |                     |           |          |        |         |           |          |         |        |        |       |                  | 1     |           |      |               |      |              |

Figure 22.5.2: Display memory map (with 1/16 duty selected)

### Display area selection (with 1/16 duty selected)

When 1/16 duty is selected as the drive duty, two screen areas can be reserved within the display memory, and DSPAR (D5/LCD\_DCTL register) can be used to switch between the screens. Setting DSPAR to 0 selects display area 0; setting to 1 selects display area 1.

\* DSPAR: Display Memory Area Control Bit in the LCD Display Control (LCD\_DCTL) Register (D5/0x50a0)

### SEG pin assignment

The display memory address assignment for the SEG pins can be inverted using SEGREV (D7/LCD\_DCTL register). When SEGREV is set to 1 (the default value), memory addresses are assigned to SEG pins in ascending order. When SEGREV is set to 0, memory addresses are assigned to SEG pins in descending order. (Refer to Figures 22.5.1 and 22.5.2)

\* **SEGREV**: Segment Output Assignment Control Bit in the LCD Display Control (LCD\_DCTL) Register (D7/0x50a0)

### COM pin assignment

The display memory bit assignment for the COM pins can be inverted using COMREV (D6/LCD\_DCTL register). When COMREV is set to 1 (the default value), memory bits are assigned to COM pins in ascending order. When COMREV is set to 0, memory bits are assigned to COM pins in descending order. (Refer to Figures 22.5.1 and 22.5.2)

\* COMREV: Common Output Assignment Control Bit in the LCD Display Control (LCD\_DCTL) Register (D6/0x50a0)

### 22.6 Display Control

### 22.6.1 Display On/Off

The LCD display state is controlled using DSPC[1:0] (D[1:0]/LCD\_DCTL register).

\* DSPC[1:0]: LCD Display Control Bits in the LCD Display Control (LCD\_DCTL) Register (D[1:0]/0x50a0)

| DSPC[1:0]            | LCD display      |  |  |  |  |  |  |
|----------------------|------------------|--|--|--|--|--|--|
| 0x3                  | All off (static) |  |  |  |  |  |  |
| 0x2 All on (dynamic) |                  |  |  |  |  |  |  |
| 0x1                  | Normal display   |  |  |  |  |  |  |
| 0x0                  | Display off      |  |  |  |  |  |  |
| (Default: 0x0        |                  |  |  |  |  |  |  |

#### Table 22.6.1.1: LCD display control

For normal display, set DSPC[1:0] to 0x1. Note that the clock feed must be underway at the time. (See section 22.3.)

- Note: The LCD power supply may not generate the drive voltage normally if DSPC[1:0] is set to a value other than 0x0 before the clock is supplied to the LCD driver circuit. Make sure that DSPC[1:0] is set to 0x0 before starting the clock supply and alter DSPC[1:0] after the conditions listed below are all met.
  - 1. The LCD clock source oscillator is operating and the output clock is stabilized (oscillation start time and oscillation stabilization time have already been elapsed).
  - 2. The LCD clock settings have been finished.
  - 3. The LCD clock supply is enabled and the clock is fed into the LCD driver circuit.

If display off is selected, the drive voltage feed from the LCD voltage regulator stops, and pins VC1 to VC5 are all set to Vss level.

Since All on and All off directly control the driving waveform output by the LCD driver, display memory data is not altered. Common pins are set to dynamic drive for All on and to static drive for All off. This function can be used to make the display flash on and off without altering the display memory.

DSPC[1:0] is reset to 0x0 (Display off) after initial resetting.

Note: Executing the slp instruction during displaying may cause deterioration of the LCD panel, as it does not reset DSPC[1:0] to 0x0 (Display off). Therefore, be sure to reset DSPC[1:0] to 0x0 (Display off) via software before executing the slp instruction.

### 22.6.2 LCD Contrast Adjustment

The LCD contrast can be adjusted to one of 16 gray levels using LC[3:0] (D[3:0]/LCD\_CADJ register). Contrast is adjusted by controlling the voltages Vc1 to Vc5 output by the internal LCD voltage circuit.

\* LC[3:0]: LCD Contrast Adjustment Bits in the LCD Contrast Adjust (LCD\_CADJ) Register (D[3:0]/0x50a1)

| Table 22.0.2.1. LOD Contrast aujustment |                |  |  |  |  |  |  |  |
|-----------------------------------------|----------------|--|--|--|--|--|--|--|
| LC[3:0]                                 | Contrast       |  |  |  |  |  |  |  |
| Oxf                                     | High (dark)    |  |  |  |  |  |  |  |
| 0xe                                     | $\uparrow$     |  |  |  |  |  |  |  |
| :                                       | :              |  |  |  |  |  |  |  |
| 0x1                                     | $\downarrow$   |  |  |  |  |  |  |  |
| 0x0 Low (light)                         |                |  |  |  |  |  |  |  |
|                                         | (Default: 0x0) |  |  |  |  |  |  |  |

Table 22.6.2.1: LCD contrast adjustment

(Default: 0x0)

LC[3:0] is set to 0x0 after initial resetting. Initialization via software is required to achieve the required contrast.

### 22.6.3 Inverted Display

The LCD display can be inverted (black/white inversion) using merely control bit manipulation, without changing the display memory. Setting DSPREV (D4/LCD\_DCTL register) to 0 inverts the display; setting to 1 returns the display to normal status.

\* **DSPREV**: Reverse Display Control Bit in the LCD Display Control (LCD\_DCTL) Register (D4/0x50a0)

Note that the display will not be inverted if All off is selected using DSPC[1:0] (D[1:0]/LCD\_DCTL register). The display will be inverted if All on is selected.

### 22.6.4 Gradation Display Control

The LCD driver includes a function for generating interrupts for individual frames. These interrupts can be used to produce graduated shades of gray by turning pixels on or off.

Since the actual gray scales available will vary depending on LCD panel characteristics, the graduated shades of gray should be controlled by adjusting frame frequencies and frame intervals for turning pixels on and off. For more information on frame interrupts, refer to section 22.7.

### 22.7 LCD Interrupt

The LCD module includes a function for generating interrupts due to frame signals.

### Frame interrupt

This interrupt request generated for each frame sets the interrupt flag FRMIF (D0/LCD\_IFLG register) to 1 within the LCD module.

See Figures 22.4.1 and 22.4.2 for more information on interrupt timing.

\* FRMIF: Frame Signal Interrupt Flag in the LCD Interrupt Flag (LCD\_IFLG) Register (D0/0x50a6)

To use this interrupt, set FRMIE (D0/LCD\_IMSK register) to 1. When FRMIE is set to 0 (the default value), interrupt requests for this interrupt cause are not sent to the interrupt controller (ITC).

\* FRMIE: Frame Signal Interrupt Enable Bit in the LCD Interrupt Mask (LCD\_IMSK) Register (D0/0x50a5)

If FRMIF is set to 1 while FRMIE is set to 1 (interrupt permitted), the LCD module outputs an interrupt request to the ITC. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core. Within the interrupt handler routine, the interrupt cause should be cleared by resetting (writing 1 to) the LCD module FRMIF, rather than using the ITC LCD interrupt flag.

- Note: To prevent interrupt recurrences, the LCD module interrupt flag FRMIF must be reset within the interrupt handler routine following an LCD interrupt.
  - To prevent unwanted interrupts, FRMIF should be reset before permitting LCD interrupts with FRMIE.

### Interrupt vector

The LCD interrupt vector number and vector address are as shown below:

Vector number: 10(0x0a) Vector address: TTBR + 0x28

### Other interrupt settings

The ITC allows the priority of LCD interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

### 22.8 Control Register Details

| Address |          | Register name                              | Function                                         |  |  |  |  |  |  |
|---------|----------|--------------------------------------------|--------------------------------------------------|--|--|--|--|--|--|
| 0x50a0  | LCD_DCTL | LCD Display Control Register               | LCD display control                              |  |  |  |  |  |  |
| 0x50a1  | LCD_CADJ | LCD Contrast Adjust Register               | Contrast control                                 |  |  |  |  |  |  |
| 0x50a2  | LCD_CCTL | LCD Clock Control Register                 | LCD clock duty selection                         |  |  |  |  |  |  |
| 0x50a3  | LCD_VREG | LCD Voltage Regulator Control Register     | LCD driver voltage regulator control             |  |  |  |  |  |  |
| 0x50a4  | LCD_PWR  | LCD Power Voltage Booster Control Register | LCD power supply voltage booster circuit control |  |  |  |  |  |  |
| 0x50a5  | LCD_IMSK | LCD Interrupt Mask Register                | Interrupt mask setting                           |  |  |  |  |  |  |
| 0x50a6  | LCD_IFLG | LCD Interrupt Flag Register                | Interrupt occurrence status display/reset        |  |  |  |  |  |  |

#### Table 22.8.1: LCD register list

The individual LCD module registers are described below. These are all 8-bit registers.

# Note: When writing data to the registers, always program 0 to bits indicated as "Reserved." Do not program 1.

### 0x50a0: LCD Display Control Register (LCD\_DCTL)

| Register name           | Address  | Bit  | Name      | Function                          |   | Set       | tin | g             | Init. | R/W | Remarks            |
|-------------------------|----------|------|-----------|-----------------------------------|---|-----------|-----|---------------|-------|-----|--------------------|
| LCD Display             | 0x50a0   | D7   | SEGREV    | Segment output assignment control | 1 | Normal    | 0   | Reverse       | 1     | R/W |                    |
| <b>Control Register</b> | (8 bits) | D6   | COMREV    | Common output assignment control  | 1 | Normal    | 0   | Reverse       | 1     | R/W |                    |
| (LCD_DCTL)              |          | D5   | DSPAR     | Display memory area control       | 1 | Area 1    | 0   | Area 0        | 0     | R/W |                    |
|                         |          | D4   | DSPREV    | Reverse display control           | 1 | Normal    | 0   | Reverse       | 1     | R/W |                    |
|                         |          | D3–2 | -         | reserved                          |   |           | -   |               | -     | -   | 0 when being read. |
|                         | ĺ        | D1–0 | DSPC[1:0] | LCD display control               |   | DSPC[1:0] |     | Display       | 0x0   | R/W |                    |
|                         |          |      |           |                                   |   | 0x3       |     | All off       |       |     |                    |
|                         |          |      |           |                                   |   | 0x2       |     | All on        |       |     |                    |
|                         |          |      |           |                                   |   | 0x1       | N   | ormal display |       |     |                    |
|                         |          |      |           |                                   |   | 0x0       |     | Display off   |       |     |                    |

### D7 SEGREV: Segment Output Assignment Control Bit

Inverts memory assignments for SEG pins. 1 (R/W): Normal (default) 0 (R/W): Inverted

When SEGREV is set to 1 (the default value), memory addresses are assigned to SEG pins in ascending order. When SEGREV is set to 0, memory addresses are assigned to SEG pins in descending order. (Refer to Figures 22.5.1 and 22.5.2)

### D6 COMREV: Common Output Assignment Control Bit

Inverts memory assignments for COM pins. 1 (R/W): Normal (default) 0 (R/W): Inverted

When COMREV is set to 1 (the default value), memory bits are assigned to COM pins in ascending order. When COMREV is set to 0, memory bits are assigned to COM pins in descending order. (Refer to Figures 22.5.1 and 22.5.2)

### D5 DSPAR: Display Memory Area Control Bit

Selects the display area when driving using 1/16 duty. 1 (R/W): Display area 1 0 (R/W): Display area 0 (default)

Selects which of the two display areas reserved in the display area is displayed when driving using 1/16 duty. Setting DSPAR to 0 selects display area 0; setting to 1 selects display area 1. Refer to Figure 22.5.2 for more information on display areas.

### D4 DSPREV: Reverse Display Control Bit

Inverts (negative display) the LCD display. 1 (R/W): Normal display (default) 0 (R/W): Inverted display

Setting DSPREV to 0 inverts the LCD panel display; setting to 1 returns the display to normal status. This operation does not affect display memory.

### D[3:2] Reserved

#### 22 LCD DRIVER (LCD)

### D[1:0] DSPC[1:0]: LCD Display Control Bits Control the LCD display.

| Table 22.6.2: LOD display control |                  |  |  |  |  |  |  |  |
|-----------------------------------|------------------|--|--|--|--|--|--|--|
| DSPC[1:0]                         | LCD display      |  |  |  |  |  |  |  |
| 0x3                               | All off (static) |  |  |  |  |  |  |  |
| 0x2                               | All on (dynamic) |  |  |  |  |  |  |  |
| 0x1                               | Normal display   |  |  |  |  |  |  |  |
| 0x0                               | Display off      |  |  |  |  |  |  |  |
|                                   | (Default: 0x0)   |  |  |  |  |  |  |  |

| Table | 2282.   | I CD | display | control |
|-------|---------|------|---------|---------|
| Table | 22.0.2. | LOD  | uispiay | COLLIN  |

For normal display, set DSPC[1:0] to 0x1. Note that the clock feed must be underway at the time. (See section 22.3.)

- Note: The LCD power supply may not generate the drive voltage normally if DSPC[1:0] is set to a value other than 0x0 before the clock is supplied to the LCD driver circuit. Make sure that DSPC[1:0] is set to 0x0 before starting the clock supply and alter DSPC[1:0] after the conditions listed below are all met.
  - 1. The LCD clock source oscillator is operating and the output clock is stabilized (oscillation start time and oscillation stabilization time have already been elapsed).
  - 2. The LCD clock settings have been finished.
  - 3. The LCD clock supply is enabled and the clock is fed into the LCD driver circuit.

If display off is selected, the drive voltage feed from the LCD voltage regulator stops, and pins VC1 to VC5 are all set to Vss level.

Since All on and All off directly control the driving waveform output by the LCD driver, the display memory data is not altered. Common pins will be set to dynamic drive for All on and to static drive for All off. This function can be used to make the display flash on and off without altering display memory.

DSPC[1:0] is reset to 0x0 (Display off) after initial resetting.

Note: Executing the slp instruction during displaying may cause deterioration of the LCD panel, as it does not reset DSPC[1:0] to 0x0 (Display off). Therefore, be sure to reset DSPC[1:0] to 0x0 (Display off) via software before executing the slp instruction.

### 0x50a1: LCD Contrast Adjust Register (LCD\_CADJ)

| Register name   | Address  | Bit  | Name    | Function                | Setting |         | Init. | R/W | Remarks            |
|-----------------|----------|------|---------|-------------------------|---------|---------|-------|-----|--------------------|
| LCD Contrast    | 0x50a1   | D7–4 | -       | reserved                | -       | _       | -     | -   | 0 when being read. |
| Adjust Register | (8 bits) | D3–0 | LC[3:0] | LCD contrast adjustment | LC[3:0] | Display | 0x0   | R/W |                    |
| (LCD_CADJ)      |          |      |         |                         | 0xf     | Dark    |       |     |                    |
|                 |          |      |         |                         | :       | :       |       |     |                    |
|                 |          |      |         |                         | 0x0     | Light   |       |     |                    |

### D[7:4] Reserved

### D[3:0] LC[3:0]: LCD Contrast Adjustment Bits

Adjust LCD contrast by controlling voltages Vc1 to Vc5 output by the internal LCD voltage circuit.

| Table 22.0.0. LOD contrast adjustment |                 |  |  |  |  |  |  |
|---------------------------------------|-----------------|--|--|--|--|--|--|
| LC[3:0]                               | Contrast        |  |  |  |  |  |  |
| 0xf                                   | High (dark)     |  |  |  |  |  |  |
| 0xe                                   | ↑               |  |  |  |  |  |  |
| :                                     | :               |  |  |  |  |  |  |
| 0x1                                   | $\downarrow$    |  |  |  |  |  |  |
| 0x0 Low (light)                       |                 |  |  |  |  |  |  |
|                                       | (Defeuilte Our) |  |  |  |  |  |  |

| Table   |             | contract | adiustment |
|---------|-------------|----------|------------|
| lable 2 | 22.0.J. LUU | contrast | aulusimeni |

(Default: 0x0)

LC[3:0] is set to 0x0 after initial resetting. Initialization via software is required to achieve the required contrast.

### 0x50a2: LCD Clock Control Register (LCD\_CCTL)

| Register name    | Address  | Bit  | Name       | Function        | Set        | Init.    | R/W | Remarks |                    |
|------------------|----------|------|------------|-----------------|------------|----------|-----|---------|--------------------|
| LCD Clock        | 0x50a2   | D7–2 | -          | reserved        | -          |          | -   | _       | 0 when being read. |
| Control Register | (8 bits) | D1–0 | LDUTY[1:0] | LCD duty select | LDUTY[1:0] | Duty     | 0x2 | R/W     |                    |
| (LCD_CCTL)       |          |      |            |                 | 0x3        | reserved |     |         |                    |
|                  |          |      |            |                 | 0x2        | 1/32     |     |         |                    |
|                  |          |      |            |                 | 0x1        | 1/16     |     |         |                    |
|                  |          |      |            |                 | 0x0        | reserved |     |         |                    |

### D[7:2] Reserved

### D[1:0] LDUTY[1:0]: LCD Duty Select Bits

Select the drive duty.

#### Table 22.8.4: Drive duty settings

| LDUTY[1:0] | Duty     | Valid common pin | Valid segment pin | Max display pixel size |
|------------|----------|------------------|-------------------|------------------------|
| 0x3        | Reserved | -                | -                 | -                      |
| 0x2        | 1/32     | COM0 to COM31    | SEG0 to SEG71     | 2,304 pixels           |
| 0x1        | 1/16     | COM0 to COM15    | SEG0 to SEG87     | 1,408 pixels           |
| 0x0        | Reserved | -                | -                 | -                      |

(Default: 0x2)

| Register name    | Address  | Bit  | Name  | Function                       | Setting |       | Init. | R/W | Remarks            |
|------------------|----------|------|-------|--------------------------------|---------|-------|-------|-----|--------------------|
| LCD Voltage      | 0x50a3   | D7–5 | -     | reserved                       | -       |       | -     | -   | 0 when being read. |
| Regulator        | (8 bits) | D4   | LHVLD | LCD heavy load protection mode | 1 On    | 0 Off | 0     | R/W |                    |
| Control Register |          | D3–0 | -     | reserved                       | _       |       | -     | -   | 0 when being read. |
| (LCD_VREG)       |          |      |       |                                |         |       |       |     |                    |

For more information on these control bits, see "0x50a3: LCD Voltage Regulator Control Register (LCD\_VREG)" in section 4.5.

|                  |          |      | •     | •                             |   | •       |   |       |     |         |                    |
|------------------|----------|------|-------|-------------------------------|---|---------|---|-------|-----|---------|--------------------|
| Register name    | Address  | Bit  | Name  | Function                      |   | Setting |   | Init. | R/W | Remarks |                    |
| LCD Power        | 0x50a4   | D7–2 | -     | reserved                      |   | -       | - |       | -   | -       | 0 when being read. |
| Voltage Booster  | (8 bits) |      |       |                               |   |         |   |       |     |         | -                  |
| Control Register |          | D1   | VDSEL | Regulator power source select | 1 | VD2     | 0 | Vdd   | 0   | R/W     |                    |
| (LCD_PWR)        |          | D0   | PBON  | Power voltage booster control | 1 | On      | 0 | Off   | 0   | R/W     |                    |

### 0x50a4: LCD Power Voltage Booster Control Register (LCD\_PWR)

For more information on these control bits, see "0x50a4: LCD Power Voltage Booster Control Register (LCD\_PWR)" in section 4.5.

### 0x50a5: LCD Interrupt Mask Register (LCD\_IMSK)

| Register name | Address  | Bit  | Name  | Function                      | Setting  |           | Init. | R/W | Remarks            |
|---------------|----------|------|-------|-------------------------------|----------|-----------|-------|-----|--------------------|
| LCD Interrupt | 0x50a5   | D7–1 | -     | reserved                      | -        |           | -     | -   | 0 when being read. |
| Mask Register | (8 bits) |      |       |                               |          |           |       |     |                    |
| (LCD_IMSK)    |          | D0   | FRMIE | Frame signal interrupt enable | 1 Enable | 0 Disable | 0     | R/W |                    |

### D[7:1] Reserved

### D0 FRMIE: Frame Signal Interrupt Enable Bit

Permits or prevents frame interrupts.

1 (R/W): Permit interrupt

0 (R/W): Prevent interrupt (default)

Setting FRMIE to 1 permits LCD interrupt requests to the ITC. Setting to 0 prevents interrupts.

### 0x50a6: LCD Interrupt Flag Register (LCD\_IFLG)

| Register name | Address  | Bit  | Name  | Function                    | Setting    |                | Init. | R/W | Remarks             |
|---------------|----------|------|-------|-----------------------------|------------|----------------|-------|-----|---------------------|
| LCD Interrupt | 0x50a6   | D7–1 | -     | reserved                    | -          |                | -     | -   | 0 when being read.  |
| Flag Register | (8 bits) |      |       |                             |            |                |       |     |                     |
| (LCD_IFLG)    |          | D0   | FRMIF | Frame signal interrupt flag | 1 Occurred | 0 Not occurred | 0     | R/W | Reset by writing 1. |

### D[7:1] Reserved

### D0 FRMIF: Frame Signal Interrupt Flag

Interrupt flag indicating the frame interrupt cause occurrence status.

1 (R): Interrupt cause present

0 (R): No interrupt cause (default)

1 (W): Reset flag

0 (W): Disable

FRMIF is the LCD module interrupt flag and is set to the frame signal rising edge 1. If FRMIE (D0/ LCD\_IMSK register) is set to 1 here, an LCD interrupt request signal is output to the ITC. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core. FRMIF is reset by writing 1.

Note: • To prevent interrupt recurrences, the LCD module interrupt flag FRMIF must be reset within the interrupt handler routine following an LCD interrupt.

• To prevent unwanted interrupts, FRMIF should be reset before permitting LCD interrupts with FRMIE.

### 22.9 Precautions

- To prevent interrupt recurrences, the LCD module interrupt flag FRMIF (D0/LCD\_IFLG register) must be reset within the interrupt handler routine following an LCD interrupt.
- To prevent unwanted interrupts, FRMIF (D0/LCD\_IFLG register) should be reset before permitting LCD interrupts with FRMIE (D0/LCD\_IMSK register).
- See "4.6 Precautions" for LCD power supply precautions.
- The LCD power supply may not generate the drive voltage normally if DSPC[1:0] (D[1:0]/LCD\_DCTL register) is set to a value other than 0x0 before the clock is supplied to the LCD driver circuit. Make sure that DSPC[1:0] is set to 0x0 before starting the clock supply and alter DSPC[1:0] after the conditions listed below are all met.
  - 1. The LCD clock source oscillator is operating and the output clock is stabilized (oscillation start time and oscillation stabilization time have already been elapsed).
  - 2. The LCD clock settings have been finished.
  - 3. The LCD clock supply is enabled and the clock is fed into the LCD driver circuit.
- Executing the slp instruction during displaying may cause deterioration of the LCD panel, as it does not reset DSPC[1:0] to 0x0 (Display off). Therefore, be sure to reset DSPC[1:0] to 0x0 (Display off) via software before executing the slp instruction.

# 23 Power Supply Voltage Detection Circuit (SVD)

# 23.1 SVD Module Configuration

The S1C17702 incorporates an SVD (supply voltage detection) circuit to detect power supply voltage drops. Software can be used to turn the SVD circuit on/off, set the comparison voltage, and read out the detection results. Interrupts can also be generated when a voltage drop is detected. Figure 23.1.1 illustrates the SVD circuit configuration.



# 23.2 Comparison Voltage Setting

The SVD circuit compares the power supply voltage (VDD) against the comparison voltage set by the software and outputs results indicating whether the power supply voltage exceeds this comparison voltage. The comparison voltage can be selected from among the 15 listed in Table 23.2.1 with the SVDC[3:0] (D[3:0]/SVD\_CMP register).

\* SVDC[3:0]: SVD Compare Voltage Select Bits in the SVD Compare Voltage (SVD\_CMP) Register (D[3:0]/0x5101)

| Tuble 20.2.11. 00111pu | nson voltage settings |
|------------------------|-----------------------|
| SVDC[3:0]              | Comparison voltage    |
| Oxf                    | 3.2 V                 |
| 0xe                    | 3.1 V                 |
| 0xd                    | 3.0 V                 |
| 0xc                    | 2.9 V                 |
| 0xb                    | 2.8 V                 |
| 0xa                    | 2.7 V                 |
| 0x9                    | 2.6 V                 |
| 0x8                    | 2.5 V                 |
| 0x7                    | 2.4 V                 |
| 0x6                    | 2.3 V                 |
| 0x5                    | 2.2 V                 |
| 0x4                    | 2.1 V                 |
| 0x3                    | 2.0 V                 |
| 0x2                    | 1.9 V                 |
| 0x1                    | 1.8 V                 |
| 0x0                    | Reserved              |
|                        |                       |

Table 23.2.1: Comparison voltage settings

(Default: 0x0)

# 23.3 SVD Circuit Control

Power supply voltage detection using the SVD circuit is initiated by writing 1 to SVDEN (D0/SVD\_EN register) and is stopped by writing 0.

\* SVDEN: SVD Enable Bit in the SVD Enable (SVD\_EN) Register (D0/0x5100)

The results can be read out from the SVDDT (D0/SVD\_RSLT register).

\* SVDDT: SVD Detection Result Bit in the SVD Detection Result (SVD\_RSLT) Register (D0/0x5102)

The detection results and SVDDT readings are as follows.

• When power supply voltage (VDD)  $\geq$  comparison voltage: SVDDT = 0

• When power supply voltage (VDD) < comparison voltage: SVDDT = 1

When SVD interrupts are permitted and SVDEN is set to 1, an interrupt is generated as soon as the power supply voltage drops below the comparison voltage, and the detection result becomes 1. This interrupt can be used to indicate battery depletion and heavy load protection. See the following section for more information on interrupt control.

Note that if a temporary voltage drop causes an interrupt, the interrupt will not be cleared even when the voltage subsequently returns to a value exceeding the comparison voltage. The SVDDT should be read and checked in the interrupt handler routine.

- Note: Up to 500 µs may be required to produce stable detection results after SVD circuit operations start. When reading detection results without using interrupts, allow for this stabilization time before reading SVDDT (D0/SVD\_RSLT register) after writing 1 to SVDEN (D0/SVD\_EN register).
  - Operating the SVD circuit increases current consumption. If power supply voltage detection is not required, stop SVD operations by setting SVDEN to 0.

# 23.4 SVD Interrupt

The SVD module includes a function for generating interrupts when power supply voltage drops are detected.

#### Power supply voltage detection interrupt

This interrupt request is generated when the power supply voltage (VDD) detected value drops below the comparison voltage while SVD is operating (SVDEN (D0/SVD\_EN register) = 1). It sets the interrupt flag SVDIF (D0/SVD\_IFLG register) to 1 within the SVD module. Once set, SVDIF is not reset even if the power supply voltage subsequently returns to a value exceeding the comparison voltage.

\* SVDIF: SVD Interrupt Flag in the SVD Interrupt Flag (SVD\_IFLG) Register (D0/0x5104)

To use this interrupt, set SVDIE (D0/SVD\_IMSK register) to 1. When SVDIE is set to 0 (the default value), interrupt request for this cause will not be sent to the interrupt controller (ITC).

\* SVDIE: SVD Interrupt Enable Bit in the SVD Interrupt Mask (SVD\_IMSK) Register (D0/0x5103)

If SVDIF is set to 1 while SVDIE is set to 1 (interrupt permitted), the SVD module outputs an interrupt request to the ITC. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core.

- Note: To prevent interrupt recurrences, the SVD module interrupt flag SVDIF must be reset within the interrupt handler routine following an SVD interrupt.
  - To prevent unwanted interrupts, reset SVDIF before permitting SVD interrupts with SVDIE.

#### Interrupt vector

The SVD interrupt vector number and vector address are as shown below:

Vector number: 9(0x09) Vector address: TTBR + 0x24

#### Other interrupt settings

The ITC allows the priority of SVD interrupts to be set between level 0 (the default value) and level 7. To generate actual interrupts, the PSR (S1C17 core internal processor status register) IE (interrupt enable) bit must be set to 1.

For more information on interrupt processing, see "6 Interrupt Controller (ITC)."

# 23.5 Control Register Details

| Address |          | Register name                 | Function                                  |
|---------|----------|-------------------------------|-------------------------------------------|
| 0x5100  | SVD_EN   | SVD Enable Register           | SVD operation permission                  |
| 0x5101  | SVD_CMP  | SVD Compare Voltage Register  | Comparison voltage setting                |
| 0x5102  | SVD_RSLT | SVD Detection Result Register | Voltage detection result                  |
| 0x5103  | SVD_IMSK | SVD Interrupt Mask Register   | Interrupt mask setting                    |
| 0x5104  | SVD_IFLG | SVD Interrupt Flag Register   | Interrupt occurrence status display/reset |

#### Table 23.5.1: SVD register list

The individual SVD module registers are described below. These are all 8-bit registers.

Note: When writing data to the registers, always program 0 to bits indicated as "Reserved." Do not program 1.

### 0x5100: SVD Enable Register (SVD\_EN)

| Register name        | Address  | Bit  | Name  | Function   | Setting |        |           | Init. | R/W | Remarks            |
|----------------------|----------|------|-------|------------|---------|--------|-----------|-------|-----|--------------------|
| SVD Enable           | 0x5100   | D7–1 | -     | reserved   | -       |        |           | -     | -   | 0 when being read. |
| Register<br>(SVD_EN) | (8 bits) | D0   | SVDEN | SVD enable | 1       | Enable | 0 Disable | 0     | R/W |                    |

#### D[7:1] Reserved

#### D0 SVDEN: SVD Enable Bit

Permits or prevents SVD circuit operations.

1 (R/W): Permit

0 (R/W): Prevent (default)

Setting SVDEN to 1 initiates power supply voltage detection; setting to 0 stops detection.

- Note: Up to 500 μs may be required to obtain stable detection results after the SVD circuit begins operating. When reading detection results without using interrupts, allow this stabilization time to elapse before reading SVDDT (D0/SVD\_RSLT register) after writing 1 to SVDEN.
  - Operating the SVD circuit increases current consumption. If power supply voltage detection is not required, stop SVD operations by setting SVDEN to 0.

| Register name    | Address  | Bit  | Name      | Function            | Set       | ting     | Init. | R/W | Remarks            |
|------------------|----------|------|-----------|---------------------|-----------|----------|-------|-----|--------------------|
| SVD Compare      | 0x5101   | D7–4 | -         | reserved            | -         | -        | -     | -   | 0 when being read. |
| Voltage Register | (8 bits) | D3–0 | SVDC[3:0] | SVD compare voltage | SVDC[3:0] | Voltage  | 0x0   | R/W |                    |
| (SVD_CMP)        |          |      |           |                     | 0xf       | 3.2 V    | 1     |     |                    |
|                  |          |      |           |                     | 0xe       | 3.1 V    |       |     |                    |
|                  |          |      |           |                     | 0xd       | 3.0 V    |       |     |                    |
|                  |          |      |           |                     | 0xc       | 2.9 V    |       |     |                    |
|                  |          |      |           |                     | 0xb       | 2.8 V    |       |     |                    |
|                  |          |      |           |                     | 0xa       | 2.7 V    |       |     |                    |
|                  |          |      |           |                     | 0x9       | 2.6 V    |       |     |                    |
|                  |          |      |           |                     | 0x8       | 2.5 V    |       |     |                    |
|                  |          |      |           |                     | 0x7       | 2.4 V    |       |     |                    |
|                  |          |      |           |                     | 0x6       | 2.3 V    |       |     |                    |
|                  |          |      |           |                     | 0x5       | 2.2 V    |       |     |                    |
|                  |          |      |           |                     | 0x4       | 2.1 V    |       |     |                    |
|                  |          |      |           |                     | 0x3       | 2.0 V    |       |     |                    |
|                  |          |      |           |                     | 0x2       | 1.9 V    |       |     |                    |
|                  |          |      |           |                     | 0x1       | 1.8 V    |       |     |                    |
|                  |          |      |           |                     | 0x0       | reserved |       |     |                    |

### 0x5101: SVD Compare Voltage Register (SVD\_CMP)

### D[7:4] Reserved

### D[3:0] SVDC[3:0]: SVD Compare Voltage Select Bits

Selects one of 15 comparison voltages for detecting voltage drops.

| SVDC[3:0] | Comparison voltage |
|-----------|--------------------|
| Oxf       | 3.2 V              |
| 0xe       | 3.1 V              |
| 0xd       | 3.0 V              |
| 0xc       | 2.9 V              |
| 0xb       | 2.8 V              |
| 0xa       | 2.7 V              |
| 0x9       | 2.6 V              |
| 0x8       | 2.5 V              |
| 0x7       | 2.4 V              |
| 0x6       | 2.3 V              |
| 0x5       | 2.2 V              |
| 0x4       | 2.1 V              |
| 0x3       | 2.0 V              |
| 0x2       | 1.9 V              |
| 0x1       | 1.8 V              |
| 0x0       | Reserved           |
|           | (Default: 0x0)     |

| Table | 23.5.2 | Com   | parison | voltage | settings |
|-------|--------|-------|---------|---------|----------|
| labic | 20.0.2 | 00111 | panoon  | vonuge  | occungo  |

The SVD circuit compares the power supply voltage (VDD) against the comparison voltage set by SVDC[3:0], and outputs results indicating whether the power supply voltage exceeds this comparison voltage.

### 0x5102: SVD Detection Result Register (SVD\_RSLT)

| Register name   | Address  | Bit  | Name  | Function             | Setting |     |          | Init. | R/W | Remarks            |
|-----------------|----------|------|-------|----------------------|---------|-----|----------|-------|-----|--------------------|
| SVD Detection   | 0x5102   | D7–1 | -     | reserved             | -       |     |          | -     | _   | 0 when being read. |
| Result Register | (8 bits) | D0   | SVDDT | SVD detection result | 1       | Low | 0 Normal | ×     | R   |                    |
| (SVD_RSLT)      |          |      |       |                      |         |     |          |       |     |                    |

#### D[7:1] Reserved

#### D0 SVDDT: SVD Detection Result Bit

Reads out power supply voltage detection results.

1 (R): power supply voltage (VDD) < comparison voltage

0 (R): power supply voltage (VDD)  $\geq$  comparison voltage

The SVD circuit compares the power supply voltage (VDD) against the voltage set in SVDC[3:0] (D[3:0]/ SVD\_CMP register) while SVDEN (D0/SVD\_EN register) = 1. The current power supply voltage status can be checked by reading SVDDT.

### 0x5103: SVD Interrupt Mask Register (SVD\_IMSK)

| Register name | Address  | Bit  | Name  | Function             | Setting |        |           | Init. | R/W | Remarks            |
|---------------|----------|------|-------|----------------------|---------|--------|-----------|-------|-----|--------------------|
| SVD Interrupt | 0x5103   | D7–1 | -     | reserved             | -       |        |           | -     | -   | 0 when being read. |
| Mask Register | (8 bits) | D0   | SVDIE | SVD interrupt enable | 1       | Enable | 0 Disable | 0     | R/W |                    |
| (SVD_IMSK)    |          |      |       |                      |         |        |           |       |     |                    |

#### D[7:1] Reserved

#### D0 SVDIE: SVD Interrupt Enable Bit

Permits or prevents interrupts when a power supply voltage drop is detected.

1 (R/W): Permit interrupt

0 (R/W): Prevent interrupt (default)

Setting SVDIE to 1 permits SVD interrupt requests to the ITC; setting to 0 prevents interrupts.

| Register name | Address  | Bit  | Name  | Function           | Setting |           |   | Init.         | R/W | Remarks            |                     |
|---------------|----------|------|-------|--------------------|---------|-----------|---|---------------|-----|--------------------|---------------------|
| SVD Interrupt | 0x5104   | D7–1 | -     | reserved           | -       |           |   | -             | _   | 0 when being read. |                     |
| Flag Register | (8 bits) | D0   | SVDIF | SVD interrupt flag | 1       | Cause of  | 0 | Cause of      | 0   | R/W                | Reset by writing 1. |
| (SVD_IFLG)    |          |      |       |                    |         | interrupt |   | interrupt not |     |                    |                     |
|               |          |      |       |                    |         | occurred  |   | occurred      |     |                    |                     |

#### 0x5104: SVD Interrupt Flag Register (SVD\_IFLG)

#### D[7:1] Reserved

#### D0 SVDIF: SVD Interrupt Flag

Interrupt flag indicating the power supply voltage drop detection interrupt cause occurrence status. 1 (R): Interrupt cause present

0 (R): No interrupt cause (default)

1 (W): Reset flag

0 (W): Disable

SVDIF, the SVD module interrupt flag, is set to 1 when a power supply voltage drop is detected. If SVDIE (D0/SVD\_IMSK register) is set to 1 here, an SVD interrupt request signal is output to the ITC. An interrupt is generated if interrupt conditions are satisfied for the ITC and S1C17 core. SVDIF is reset by writing a 1 to it.

- Note: To prevent interrupt recurrences, the SVD module interrupt flag SVDIF must be reset within the interrupt handler routine following an SVD interrupt.
  - To prevent unwanted interrupts, reset SVDIF before permitting SVD interrupts with SVDIE (D0/SVD\_IMSK register).

# 23.6 Precautions

- Up to 500 µs may be required to obtain stable detection results after the SVD circuit begins operating. When reading detection results without using interrupts, allow this stabilization time to elapse before reading SVDDT (D0/SVD\_RSLT register) after writing 1 to SVDEN (D0/SVD\_EN register).
- Operating the SVD circuit increases current consumption. If power supply voltage detection is not required, stop SVD operations by setting SVDEN (D0/SVD\_EN register) to 0.
- To prevent interrupt recurrences, the SVD module interrupt flag SVDIF (D0/SVD\_IFLG register) must be reset within the interrupt handler routine following an SVD interrupt.
- To prevent unwanted interrupts, reset SVDIF (D0/SVD\_IFLG register) before permitting SVD interrupts with SVDIE (D0/SVD\_IMSK register).
- The OSC1 clock feed must be underway for SVD operations. If the OSC1 oscillation is halted, initiate oscillation. Allow the oscillation start time and stabilization time to elapse before operating the SVD circuit.

# 24 On-chip Debugger (DBG)

# 24.1 Resource Requirements and Debugging Tool

### Debugging work area

Debugging requires a 64-byte debugging work area. In the S1C17702, RAM addresses 0x0007c0 to 0x0007ff are assigned as the debugging work area. When using the debugging function, avoid using this area for any other user applications.

The start address for this debugging work area can be read from the DBRAM register (0xffff90).

### **Debugging tool**

Debugging involves connecting an ICD (In-Circuit Debugger) such as S5U1C17001H (ICD Mini) to the S1C17702 debug pin and inputting the debug instruction from the PC debugger.

The following tools are required:

- S1C17 Family In-Circuit Debugger (e.g., S5U1C17001H)
- S1C17 Family C compiler package (S5U1C17001C)

### **Debug pins**

The following debug pins are used to connect an ICD (e.g., S5U1C17001H).

#### Table 24.1.1: Debug pin list

| Pin name   | I/O | Qty | Function                                                                  |
|------------|-----|-----|---------------------------------------------------------------------------|
| DCLK (P31) | 0   | 1   | On-chip debugger clock output pin                                         |
|            |     |     | Outputs a clock to the ICD.                                               |
| DSIO (P33) | I/O | 1   | On-chip debugger data input/output pin                                    |
|            |     |     | Used for inputting/outputting debugging data and inputting break signals. |
| DST2 (P32) | 0   | 1   | On-chip debugger status signal output pin                                 |
|            |     |     | Outputs the processor status during debugging.                            |

Shared with general purpose input/output port pins (P31, P32, P33), the on-chip debugger input/output pins (DCLK, DST2, DSIO) are initially set for use as debugger pins. If the debugging function is not used, these pins can be switched via the P3\_PMUX register to enable use as general purpose input/output port pins. Set the control bits shown below to 1 to switch the pins to general purpose input/output port use.

#### $\text{DCLK} \rightarrow \text{P31}$

\* P31MUX: P31 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D1/0x52a3)

#### $\text{DST2} \rightarrow \text{P32}$

\* P32MUX: P32 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D2/0x52a3)

#### $\text{DSIO} \rightarrow \text{P33}$

\* P33MUX: P33 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D3/0x52a3)

For more information on pin function and switching, refer to "10.2 Input/Output Pin Function Selection (Port MUX)."

# 24.2 Debug Break Operation Status

The S1C17 core switches to debug mode when the brk instruction is executed or a debug interrupt is generated by a break signal (Low) input to the DSIO pin. This state persists until the retd instruction is executed.

During this time, hardware interrupts and NMIs are disabled.

The default setting halts peripheral circuit operations. This setting can be modified even when debugging is underway.

### Peripheral circuits that operate using the prescaler output clock

- 8-bit timer
- 16-bit timer
- · PWM & capture timer
- Remote controller
- P port
- UART
- SPI
- I<sup>2</sup>C

With the default settings, the prescaler will stop in debug mode, also stopping the peripheral circuits above that use the prescaler output clock. The prescaler includes PRUND (D1/PSC\_CTL register) to specify prescaler operations during debug mode. When PRUND is set to 1, the prescaler operates even in debug mode, allowing the peripheral circuits above to operate as well. When PRUND is 0 (default), the prescaler and the peripheral circuits above will stop when the S1C17 core switches to debug mode.

\* PRUND: Prescaler Run/Stop Setting (in Debug Mode) Bit in the Prescaler Control (PSC\_CTL) Register (D1/0x4020)

### Peripheral circuits that operate using the OSC1 clock

- Clock timer
- Watchdog timer
- Stopwatch timer
- 8-bit OSC1 timer

The MISC register includes O1DBG (D0/MISC\_OSC1 register) to specify the operation of the above OSC1 peripheral circuits during debug mode. When O1DBG is set to 1, the OSC1 peripheral circuits operate even in debug mode. When O1DBG is 0 (default), the OSC1 peripheral circuits will stop when the S1C17 core switches to debug mode.

\* **O1DBG**: OSC1 Peripheral Control (in Debug Mode) Bit in the OSC1 Peripheral Control (MISC\_OSC1) Register (D0/0x5324)

# 24.3 Additional Debugging Function

The S1C17702 expands the following on-chip debugging functions of the S1C17 core.

#### Branching destination in debug mode

When a debug interrupt is generated, the S1C17 core enters debug mode and branches to the debug processing routine. In this process, the S1C17 core is designed to branch to address 0xfffc00. In addition to this branching destination, the S1C17702 also allows designation of address 0x0 (beginning address of internal RAM) as the branching destination when debug mode is activated. The branching destination address is selected using DBADR (D8/MISC\_IRAMSZ register). When the DBADR is set to "0" (default), the branching destination is set to 0xfffc00. When it is set to "1," the branching destination is set to 0x0.

\* DBADR: Debug Base Address Select Bit in the IRAM Size Select (MISC\_IRAMSZ) Register (D8/0x5326)

#### Adding instruction breaks

The S1C17 core supports two instruction breaks (hardware PC breaks). The S1C17702 increased this number to five, adding the control bits and registers given below.

- \* IBE2: Instruction Break #2 Enable Bit in the Debug Control (DCR) Register (D5/0xfffa0)
- \* IBE3: Instruction Break #3 Enable Bit in the Debug Control (DCR) Register (D6/0xffffa0)
- \* IBE4: Instruction Break #4 Enable Bit in the Debug Control (DCR) Register (D7/0xfffa0)
- \* **IBAR2[23:0]**: Instruction Break Address #2 Bits in the Instruction Break Address (IBAR2) Register 2 (D[23:0]/0xffffb8)
- \* IBAR3[23:0]: Instruction Break Address #3 Bits in the Instruction Break Address (IBAR3) Register 3 (D[23:0]/0xfffbc)
- \* **IBAR4[23:0]**: Instruction Break Address #4 Bits in the Instruction Break Address (IBAR4) Register 4 (D[23:0]/0xffffd0)

Note that the debugger included in the S5U1C17001C (Ver. 1.2.1) or newer is required to use five hardware PC breaks.

# 24.4 Control Register Details

|          |             | lable E li li Bobag le               |                                                          |
|----------|-------------|--------------------------------------|----------------------------------------------------------|
| Address  |             | Register name                        | Function                                                 |
| 0x5322   | MISC_OSC1   | OSC1 Peripheral Control Register     | OSC1 operation peripheral function setting for debugging |
| 0x5326   | MISC_IRAMSZ | IRAM Size Select Register            | IRAM size selection                                      |
| 0xffff90 | DBRAM       | Debug RAM Base Register              | Debug RAM base address display                           |
| 0xffffa0 | DCR         | Debug Control Register               | Debug control                                            |
| 0xffffb8 | IBAR2       | Instruction Break Address Register 2 | Instruction break address #2 setting                     |
| 0xfffbc  | IBAR3       | Instruction Break Address Register 3 | Instruction break address #3 setting                     |
| 0xffffd0 | IBAR4       | Instruction Break Address Register 4 | Instruction break address #4 setting                     |

#### Table 24.4.1: Debug register list

The debug registers are described in detail below. These are 8-bit registers.

- Note: When data is written to the registers, the "Reserved" bits must always be written as 0 and not 1.
  - For debug registers not described here, refer to the S1C17 Core Manual.

## 0x5322: OSC1 Peripheral Control Register (MISC\_OSC1)

| Register name    | Address   | Bit   | Name  | Function                         |   | Setting |        |   | R/W | Remarks            |
|------------------|-----------|-------|-------|----------------------------------|---|---------|--------|---|-----|--------------------|
| OSC1 Peripheral  | 0x5322    | D15–1 | -     | reserved                         |   | _       |        | - | -   | 0 when being read. |
| Control Register | (16 bits) | D0    | O1DBG | OSC1 peripheral control in debug | 1 | Run     | 0 Stop | 0 | R/W |                    |
| (MISC_OSC1)      |           |       |       | mode                             |   |         |        |   |     |                    |

#### D[7:1] Reserved

### D0 O1DBG: OSC1 Peripheral Control in Debug Mode Bit

Sets OSC1 peripheral circuit operation in debug mode.

1 (R/W): Operate

0 (R/W): Stop (default)

OSC1 peripheral circuit refers to the following peripheral circuits that operate using the OSC1 clock.

Clock timer

- Watchdog timer
- Stopwatch timer
- 8-bit OSC1 timer

| Register name   | Address   | Bit   | Name        | Function                  | Setting     |            | Init. | R/W | Remarks            |
|-----------------|-----------|-------|-------------|---------------------------|-------------|------------|-------|-----|--------------------|
| IRAM Size       | 0x5326    | D15–9 | -           | reserved                  | -           |            | -     | -   | 0 when being read. |
| Select Register | (16 bits) | D8    | DBADR       | Debug base address select | 1 0x0       | 0 0xfffc00 | 0     | R/W |                    |
| (MISC_IRAMSZ)   |           | D7–2  | -           | reserved                  | _           |            | -     | -   | 0 when being read. |
|                 |           | D1–0  | IRAMSZ[1:0] | IRAM size select          | IRAMSZ[1:0] | Read cycle | 0x0   | R/W |                    |
|                 |           |       |             |                           | 0x3         | reserved   |       |     |                    |
|                 |           |       |             |                           | 0x2         | reserved   |       |     |                    |
|                 |           |       |             |                           | 0x1         | reserved   |       |     |                    |
|                 |           |       |             |                           | 0x0         | reserved   |       |     |                    |

### 0x5326: IRAM Size Select Register (MISC\_IRAMSZ)

#### D[15:9] Reserved

#### D8 DBADR: Debug Base Address Select Bit

Selects the address to branch to in the event of a debug interrupt. 1(R/W): 0x0 0(R/W): 0xfffc00 (default)

D[7:2] Reserved

#### D[1:0] IRAMSZ[1:0]: IRAM Size Select Bits

Selects the size of the internal RAM to be used.

| IRAMSZ[1:0] | Internal RAM size |  |  |  |  |
|-------------|-------------------|--|--|--|--|
| 0x3         | Reserved          |  |  |  |  |
| 0x2         | Reserved          |  |  |  |  |
| 0x1         | Reserved          |  |  |  |  |
| 0x0         | Reserved          |  |  |  |  |

#### Table 24.4.2 Selecting the size of internal RAM

(Default: 0x0)

- Note: The IRAM Size Select Register is write-protected. The write-protection must be overridden by writing 0x96 to the MISC Protect Register (0x5324). Note that MISC Protect Register (0x5324) should normally be set to a value other than 0x96, except when writing to the IRAM Size Select Register. Unnecessary programs may result in system malfunctions.
  - Do not alter IRAMSZ[1:0] from the default value.

## 0xffff90: Debug RAM Base Register (DBRAM)

| Register name | Address   | Bit    | Name        | Function               | Setting | Init. | R/W | Remarks |
|---------------|-----------|--------|-------------|------------------------|---------|-------|-----|---------|
| Debug RAM     | 0xffff90  | D31-24 | -           | Unused (fixed at 0)    | 0x0     | 0x0   | R   |         |
| Base Register | (32 bits) | D23-0  | DBRAM[23:0] | Debug RAM base address | 0x2fc0  | 0x2f  | R   |         |
| (DBRAM)       |           |        |             |                        |         | c0    |     |         |

#### D[31:24] Not used (Fixed at 0)

### D[23:0] DBRAM[23:0]: Debug RAM Base Address Bits

Read-only register containing the initial address of the debugging work area (64 bytes).

| Register name | Address  | Bit | Name | Function                    | Setting                        |            | Init.   | R/W          | Remarks |     |                     |
|---------------|----------|-----|------|-----------------------------|--------------------------------|------------|---------|--------------|---------|-----|---------------------|
| Debug Control | 0xffffa0 | D7  | IBE4 | Instruction break #4 enable | reak #4 enable 1 Enable 0 Disa |            | Disable | 0            | R/W     |     |                     |
| Register      | (8 bits) | D6  | IBE3 | Instruction break #3 enable | 1                              | Enable     | 0       | Disable      | 0       | R/W |                     |
| (DCR)         |          | D5  | IBE2 | Instruction break #2 enable | 1                              | Enable     | 0       | Disable      | 0       | R/W |                     |
|               |          | D4  | DR   | Debug request flag          | 1                              | Occurred   | 0       | Not occurred | 0       | R/W | Reset by writing 1. |
|               |          | D3  | IBE1 | Instruction break #1 enable | 1                              | Enable     | 0       | Disable      | 0       | R/W |                     |
|               |          | D2  | IBE0 | Instruction break #0 enable | 1 Enable 0 Disable             |            | Disable | 0            | R/W     |     |                     |
|               | ĺ        | D1  | SE   | Single step enable          | 1 Enable 0 Disable             |            | 0       | R/W          |         |     |                     |
|               |          | D0  | DM   | Debug mode                  | 1                              | Debug mode | 0       | User mode    | 0       | R   |                     |

#### **0xffffa0: Debug Control Register (DCR)**

#### D7 IBE4: Instruction Break #4 Enable Bit

Permits or prohibits instruction break #4. 1(R/W): Permit 0(R/W): Prohibit (default)

If this bit is set to 1, the instruction fetch address and the value set in the Instruction Break Address Register 4 (0xffffd0) are compared. If they match, an instruction break is generated. If this bit is set to 0, no comparison is performed.

#### D6 IBE3: Instruction Break #3 Enable Bit

Permits or prohibits instruction break #3. 1(R/W): Permit 0(R/W): Prohibit (default)

If this bit is set to 1, the instruction fetch address and the value set in the Instruction Break Address Register 3 (0xffffbc) are compared. If they match, an instruction break is generated. If this bit is set to 0, no comparison is performed.

#### D5 IBE2: Instruction Break #2 Enable Bit

Permits or prohibits instruction break #2. 1(R/W): Permit 0(R/W): Prohibit (default)

If this bit is set to 1, the instruction fetch address and the value set in the Instruction Break Address Register 2 (0xffffb8) are compared. If they match, an instruction break is generated. If this bit is set to 0, no comparison is performed.

#### D4 DR: Debug Request Flag

Indicates the presence or absence of an external debug request. 1(R): Request generated 0(R): None (default) 1(W): Resets flag 0(W): Invalid

This flag is cleared (reset to 0) when 1 is written. It must be cleared before the debug processing routine is terminated by the retd instruction.

#### D3 IBE1: Instruction Break #1 Enable Bit

Permits or prohibits instruction break #1. 1(R/W): Permit 0(R/W): Prohibit (default)

If this bit is set to 1, the instruction fetch address and the value set in the Instruction Break Address Register 1 (0xffffb4) are compared. If they match, an instruction break is generated. If this bit is set to 0, no comparison is performed.

#### D2 IBE0: Instruction Break #0 Enable Bit

Permits or prohibits instruction break #0. 1(R/W): Permit 0(R/W): Prohibit (default)

If this bit is set to 1, the instruction fetch address and the value set in the Instruction Break Address Register 0 (0xffffb0) are compared. If they match, an instruction break is generated. If this bit is set to 0, no comparison is performed.

## D1 SE: Single Step Enable Bit

Permits or prohibits single-step operations. 1(R/W): Permit 0(R/W): Prohibit (default)

### D0 DM: Debug Mode Bit

Indicates the processor operating mode (debug mode or user mode). 1(R): Debug mode 0(R): User mode (default)

## 0xffffb8: Instruction Break Address Register 2 (IBAR2)

| Register name | Address   | Bit    | Name        | Function                     | Setting         | Init. | R/W | Remarks            |
|---------------|-----------|--------|-------------|------------------------------|-----------------|-------|-----|--------------------|
| Instruction   | 0xffffb8  | D31-24 | -           | reserved                     | _               | -     | -   | 0 when being read. |
| Break Address | (32 bits) | D23-0  | IBAR2[23:0] | Instruction break address #2 | 0x0 to 0xffffff | 0x0   | R/W |                    |
| Register 2    |           |        |             | IBAR223 = MSB                |                 |       |     |                    |
| (IBAR2)       |           |        |             | IBAR20 = LSB                 |                 |       |     |                    |

### D[31:24] Reserved

### D[23:0] IBAR2[23:0]: Instruction Break Address #2 Bits Sets instruction break address #2. (default: 0x000000)

### **0xffffbc: Instruction Break Address Register 3 (IBAR3)**

| Register name | Address   | Bit    | Name        | Function                     | Setting         | Init. | R/W | Remarks            |
|---------------|-----------|--------|-------------|------------------------------|-----------------|-------|-----|--------------------|
| Instruction   | 0xffffbc  | D31-24 | -           | reserved                     | _               | -     | -   | 0 when being read. |
| Break Address | (32 bits) | D23-0  | IBAR3[23:0] | Instruction break address #3 | 0x0 to 0xffffff | 0x0   | R/W |                    |
| Register 3    |           |        |             | IBAR323 = MSB                |                 |       |     |                    |
| (IBAR3)       |           |        |             | IBAR30 = LSB                 |                 |       |     |                    |

#### D[31:24] Reserved

D[23:0] IBAR3[23:0]: Instruction Break Address #3 Bits Sets instruction break address #3. (default: 0x000000)

## 0xffffd0: Instruction Break Address Register 4 (IBAR4)

| Register name | Address   | Bit    | Name        | Function                     | Setting         | Init. | R/W | Remarks            |
|---------------|-----------|--------|-------------|------------------------------|-----------------|-------|-----|--------------------|
| Instruction   | 0xffffd0  | D31-24 | -           | reserved                     | -               | -     | -   | 0 when being read. |
| Break Address | (32 bits) | D23-0  | IBAR4[23:0] | Instruction break address #4 | 0x0 to 0xffffff | 0x0   | R/W |                    |
| Register 4    |           |        |             | IBAR423 = MSB                |                 |       |     |                    |
| (IBAR4)       |           |        |             | IBAR40 = LSB                 |                 |       |     |                    |

#### D[31:24] Reserved

D[23:0] IBAR4[23:0]: Instruction Break Address #4 Bits Sets instruction break address #4. (default: 0x000000)

# 25 Multiplier/Divider

# 25.1 Overview

The S1C17702 incorporates a coprocessor that provides signed/unsigned  $16 \times 16$  bit multiplication functions,  $16 \div 16$  bit division functions, and signed  $16 \times 16$  bit + 32-bit product-sum processor (MAC = Multiply and Accumulator) functions enabling overflow detection.

Use of these functions is discussed below.



Figure 25.1.1: Multiplier/divider block diagram

| Operation               | Cycles          |
|-------------------------|-----------------|
| Multiplication          | 1 cycle         |
| Product-sum calculation | 1 cycle         |
| Division                | 17 to 20 cycles |

Table 25.1.1: Arithmetic cycles

# 25.2 Operating Mode and Output Mode

The multiplier/divider operates in accordance with the operating mode specified by the application program. The multiplier/divider supports six different operations, as shown in Table 25.2.1.

The results of multiplication, division, and product-sum operations are 32-bit data. This means the S1C17 core cannot read out results in a single access cycle. The output mode is provided to specify whether the first 16 bits or last 16 bits of the multiplier/divider arithmetic results are read out.

Specify the operating and output modes by writing 7-bit data to the multiplier/divider internal mode setting register. Use the "ld.cw" instruction for writing.

ld.cw %rd, %rs %rs[6:0] is written to the mode setting register. (%rd: not used)

ld.cw %rd, imm7 imm7[6:0] is written to the mode setting register. (%rd: not used)

| 6 |                     | 4 | 3 |                        | 0 |
|---|---------------------|---|---|------------------------|---|
|   | Output mode setting |   |   | Operating mode setting |   |

Figure 25.2.1: Mode setting registers

| Setting<br>(D[6:4]) | Output mode                                                                                                | Setting<br>(D[3:0]) | Operating mode                                                                                                           |
|---------------------|------------------------------------------------------------------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x0                 | Last 16-bit output mode<br>Last 16 bits of the arithmetic results are<br>read out as coprocessor output.   | 0x0                 | Initialization mode 0<br>Clears the arithmetic results register to 0x0.                                                  |
| 0x1                 | First 16-bit output mode<br>First 16 bits of the arithmetic results are<br>read out as coprocessor output. | 0x1                 | Initialization mode 1<br>Loads the 16-bit arithmetic augend into the<br>last 16 bits of the arithmetic results register. |
| 0x2 to 0x7          | Reserved                                                                                                   | 0x2                 | Initialization mode 2<br>Loads the 32-bit arithmetic augend into the<br>arithmetic results register.                     |
|                     |                                                                                                            | 0x3                 | Arithmetic results reading mode<br>Outputs the arithmetic results register data<br>without performing calculations.      |
|                     |                                                                                                            | 0x4                 | Unsigned multiplication mode<br>Performs unsigned multiplication.                                                        |
|                     |                                                                                                            | 0x5                 | Signed multiplication mode<br>Performs signed multiplication.                                                            |
|                     |                                                                                                            | 0x6                 | Reserved                                                                                                                 |
|                     |                                                                                                            | 0x7                 | Signed product-sum operation mode<br>Performs signed product-sum operation.                                              |
|                     |                                                                                                            | 0x8                 | Unsigned division mode                                                                                                   |
|                     |                                                                                                            |                     | Performs unsigned division.                                                                                              |
|                     |                                                                                                            | 0x9                 | Signed division mode                                                                                                     |
|                     |                                                                                                            | 0xa to 0xf          | Performs signed division.<br>Reserved                                                                                    |
|                     |                                                                                                            |                     | neserveu                                                                                                                 |

#### Table 25.2.1: Mode setting

# 25.3 Multiplication

The multiplication function executes "A (32 bits) = B (16 bits)  $\times$  C (16 bits)."

To perform multiplication, set the operating mode to 0x4 (unsigned multiplication) or 0x5 (signed multiplication). Next, transfer the 16-bit multiplicand (B) and 16-bit multiplier (C) to the multiplier/divider using the "ld.ca" instruction. Half of the arithmetic result (16 bits, A [15:0] or A[31:16], depending on output mode) is returned to the CPU register, together with the flag status.

The remaining half of the arithmetic result is read out by setting the multiplier/divider to arithmetic result reading mode.



Figure 25.3.1: Multiplier mode data paths

Table 25.3.1: Multiplier mode operations

| Mode<br>setting | Ins   | truction          | Operation                                  | Flag | Remarks                          |
|-----------------|-------|-------------------|--------------------------------------------|------|----------------------------------|
| 0x04            | ld.ca |                   |                                            |      | The arithmetic result register   |
| or              |       |                   | %rd ← res[15:0]                            |      | retains arithmetic results until |
| 0x05            | (ext  |                   | $res[31:0] \leftarrow \%rd \times imm7/16$ |      | the results are overwritten by   |
|                 | ld.ca | %rd, <i>imm7</i>  | %rd ← res[15:0]                            |      | another operation.               |
| 0x14            | ld.ca | %rd,%rs           | $res[31:0] \leftarrow \%rd \times \%rs$    |      |                                  |
| or              |       |                   | %rd ← res[31:16]                           |      |                                  |
| 0x15            | (ext  | imm9)             | $res[31:0] \leftarrow \%rd \times imm7/16$ |      |                                  |
|                 | ld.ca | %rd, <i>imm</i> 7 | %rd ← res[31:16]                           |      |                                  |

res: Arithmetic result register

#### Examples:

ld.cw %r0,0x4 ; Mode setting (unsigned multiplication mode & last 16 bit output mode)

ld.ca %r0,%r1 ; Executes "res = %r0 × %r1" and loads the last 16 bits of the result to %r0 register.

- ld.cw %r0,0x13 ; Mode setting (arithmetic result reading mode & first 16 bit output mode)
- ld.ca %r1,%r0 ; Loads the first 16 bits of the result to %r1 register.

## 25.4 Division

The division function executes "A (16 bits) = B (16 bits) ÷ C (16 bits), D (16 bits) = Remainder."

To perform a division, set the operating mode to 0x8 (unsigned division) or 0x9 (signed division). Next, transfer the 16-bit dividend (B) and 16-bit divisor (C) to the multiplier/divider using the "1d.ca" instruction. The quotient will be placed in the lower 16 bits of the arithmetic result register, while the remainder is placed in the upper 16 bits. When the calculation is completed, the 16 bits corresponding to the quotient or remainder as specified in the output mode and the flag status are returned to the CPU register. The other 16 bits of the arithmetic result can be read out by setting the multiplier/divider to arithmetic result reading mode.



Figure 25.4.1 Division mode data path

| Mode<br>setting | Inst  | truction         | Operation                             | Flag                           | Remarks                            |
|-----------------|-------|------------------|---------------------------------------|--------------------------------|------------------------------------|
| 0x08            | ld.ca | %rd,%rs          | res[31:0] ← %rd ÷ %rs                 | psr (CVZN) $\leftarrow$ 0b0000 | The arithmetic result register re- |
| or              |       |                  | %rd $\leftarrow$ res[15:0] (quotient) |                                | tains the calculated result until  |
| 0x09            | (ext  | imm9)            | res[31:0] ← %rd ÷ <i>imm7/16</i>      |                                | it is overwritten by the result of |
|                 | ld.ca | %rd, <i>imm7</i> | %rd $\leftarrow$ res[15:0] (quotient) |                                | another arithmetic operation.      |
| 0x18            | ld.ca | %rd,%rs          | res[31:0] ← %rd ÷ %rs                 |                                |                                    |
| or              |       |                  | %rd ← res[31:16]                      |                                |                                    |
| 0x19            |       |                  | (remainder)                           |                                |                                    |
|                 | (ext  |                  | res[31:0] ← %rd ÷                     |                                |                                    |
|                 | ld.ca | %rd, <i>imm7</i> | <i>imm7/16</i> %rd ← res[31:16]       |                                |                                    |
|                 |       |                  | (remainder)                           |                                |                                    |

res: Arithmetic result register

#### Example:

| ld.cw %r0,0x8  | ; Mode setting (unsigned division mode & lower 16-bit output mode)                            |
|----------------|-----------------------------------------------------------------------------------------------|
| ld.ca %r0,%r1  | ; Executes "res = $\%r0 + \%r1$ " and loads the lower 16 bits (quotient) of the result to the |
|                | %r0 register.                                                                                 |
| ld.cw %r0,0x13 | ; Mode setting (arithmetic result reading mode & upper 16-bit output mode)                    |
| ld.ca %r1,%r0  | ; Loads the upper 16 bits (remainder) of the result to the %r1 register.                      |

# 25.5 Product-sum Operation

The product-sum operation function executes "A (32 bits) = B (16 bits)  $\times$  C (16 bits) + A (32 bits)."

The initial value (A) must be set to the arithmetic result register before performing product-sum operations.

To clear the arithmetic result register (A = 0), set the operating mode to 0x0. There is no need to send 0x0 to the multiplier/divider using separate instructions.

To load 16-bit or 32-bit values to the arithmetic result register, set the operating mode to 0x1 (16 bits) or 0x2 (32 bits). Next, transfer the initial value to the multiplier/divider using the "ld.cf" instruction.



Figure 25.5.1: Initialization mode data paths

| Table 25.5.1: Arithmetic result register initialization |  |
|---------------------------------------------------------|--|
|---------------------------------------------------------|--|

| Mode<br>setting | Ins   | struction         | Operation                  | Remarks                                                 |
|-----------------|-------|-------------------|----------------------------|---------------------------------------------------------|
| 0x0             | -     |                   | res[31:0] ← 0x0            | Initializes using operating mode settings only (no data |
|                 |       |                   |                            | transfer).                                              |
| 0x1             | ld.cf | %rd,%rs           | res[31:16] ← 0x0           |                                                         |
|                 |       |                   | res[15:0] ← %rs            |                                                         |
|                 | (ext  | imm9)             | res[31:16] ← 0x0           |                                                         |
|                 | ld.cf | %rd, <i>im</i> m7 | res[15:0] <i>← imm7/16</i> |                                                         |
| 0x2             | ld.cf | %rd,%rs           | res[31:16] ← %rd           |                                                         |
|                 |       |                   | res[15:0] ← %rs            |                                                         |
|                 | (ext  | imm9)             | res[31:16] ← %rd           |                                                         |
|                 | ld.cf | %rd, <i>im</i> m7 | res[15:0] <i>← imm7/16</i> |                                                         |

res: Arithmetic result register

To perform product-sum operations, set the operating mode to 0x7 (signed product-sum). Next, transfer the 16-bit multiplicand (B) and 16-bit multiplier (C) to the multiplier/divider using the "ld.ca" instruction. Half of the arithmetic result (16 bits, A [15:0] or A[31:16], depending on output mode) is returned to the CPU register together with the flag status. The remaining half of the arithmetic result is read out by setting the multiplier/divider to arithmetic result reading mode.

The PSR overflow flag (V) is set to 1 by the arithmetic results. Other flags are cleared to 0.

Transfer the required number of multiplicands and multipliers to continue product-sum operations without switching to arithmetic result reading mode. In this case, there is no need to set to product-sum operation mode each time data is sent.





| Mode<br>setting | Instruction   |   | Operation                                                                           | Flag                                              | Remarks                                |
|-----------------|---------------|---|-------------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------------|
| 0x07            | ld.ca         |   |                                                                                     | If overflow occurs psr (CVZN) $\leftarrow$ 0b0100 | The arithmetic result register retains |
|                 | (ext<br>ld.ca | , | $res[31:0] \leftarrow \%rd \times imm7/16 + res[31:0] \\ \%rd \leftarrow res[15:0]$ | Other cases                                       | arithmetic results until the results   |
| 0x17            | ld.ca         |   | $res[31:0] \leftarrow \%rd \times \%rs + res[31:0] \\ \%rd \leftarrow res[31:16]$   | P ( )                                             | are overwritten by another operation.  |
|                 | (ext<br>ld.ca |   | res[31:0] ← %rd × <i>imm7/16</i> + res[31:0]<br>%rd ← res[31:16]                    |                                                   |                                        |

res: Arithmetic result register

#### Examples:

ld.cw %r0,0x7 ; Mode setting (signed product-sum operation mode & last 16 bit output mode) ld.ca %r0,%r1 ; Executes "res = %r0 × %r1 + res" and loads the last 16 bits of the result to %r0 register. ld.cw %r0,0x13; Mode setting (arithmetic result reading mode & first 16 bit output mode) ld.ca %r1,%r0 ; Loads first 16 bits of the result to %r1 register.

#### Overflow flag (V) setting conditions

If the multiplication result sign, arithmetic result register sign, and arithmetic result sign satisfy the following conditions in product-sum operations, an overflow occurs, and the overflow flag (V) is set to 1.

| Mode setting | Multiplication result sign | Arithmetic result register sign | Arithmetic result sign |  |  |
|--------------|----------------------------|---------------------------------|------------------------|--|--|
| 0x07         | 0 (Positive)               | 0 (Positive)                    | 1 (Negative)           |  |  |
| 0x07         | 1 (Negative)               | 1 (Negative)                    | 0 (Positive)           |  |  |

An overflow occurs if positive values are summed giving a negative result in product-sum operations or if negative values are summed giving a positive result. The result is retained in the coprocessor until the overflow flag (V) is cleared.

### Overflow flag (V) clear conditions

The overflow flag (V) set is cleared if the "ld.ca" instruction is executed for product-sum operation without causing an overflow or if the "ld.ca" or "ld.cf" instruction is executed in other than arithmetic result reading mode.

# 25.6 Arithmetic Results Reading

Since the "ld.ca" instruction cannot load 32-bit arithmetic results to the CPU register, multiplication and product-sum operation return half of the arithmetic result (16 bits, A[15:0] or A[31:16], depending on output mode) together with the flag status to the CPU register. The remaining half of the arithmetic result is read by setting the multiplier to arithmetic result reading mode. The arithmetic result register retains arithmetic results until the results are overwritten by another operation.



#### Figure 25.6.1: Arithmetic result reading mode data paths

| Mode<br>setting | Instruction             | Operation        | Flag                          | Remarks                          |
|-----------------|-------------------------|------------------|-------------------------------|----------------------------------|
| 0x03            | ld.ca %rd,%rs           | %rd ← res[15:0]  | $psr(CVZN) \leftarrow 0b0000$ | This operating mode does         |
|                 | ld.ca %rd, <i>imm7</i>  | %rd ← res[15:0]  |                               | not affect the arithmetic result |
| 0x13            | ld.ca %rd,%rs           | %rd ← res[31:16] |                               | register.                        |
|                 | ld.ca %rd, <i>imm</i> 7 | %rd ← res[31:16] |                               |                                  |

res: Arithmetic result register

# 26 Basic External Connection Diagram



#### Recommended values for external components

| Symbol  | Name                 | Recommended value           |
|---------|----------------------|-----------------------------|
| X'tal1  | Crystal oscillator   | 32.768 kHz                  |
| CG1     | Trimmer capacitor    | 0 to 25 pF                  |
| X'tal3  | Crystal oscillator   | 0.2 to 8 MHz                |
| Ceramic | Ceramic oscillator   | 0.2 to 8 MHz                |
| Rf      | Drain resistor       | 1 MΩ                        |
| CG3     | Gate capacitor       | 15 pF (Crystal oscillation) |
|         |                      | 30 pF (Ceramic oscillation) |
| Срз     | Drain capacitor      | 15 pF (Crystal oscillation) |
|         |                      | 30 pF (Ceramic oscillation) |
| Cres    | #RESET pin capacitor | 0.47 μF                     |

| Symbol   | Name                          | Recommended value |
|----------|-------------------------------|-------------------|
| C1       | Capacitor between Vss and VD1 | 0.1 μF            |
| C2       | Capacitor between Vss and Vc1 | 0.1 μF            |
| Сз       | Capacitor between Vss and Vc2 | 0.1 μF            |
| C4       | Capacitor between Vss and Vc3 | 0.1 μF            |
| C5       | Capacitor between Vss and Vc4 | 0.1 μF            |
| C6       | Capacitor between Vss and Vc5 | 0.1 μF            |
| C7 to C9 | Booster capacitor             | 0.1 μF            |
| C10      | Capacitor between Vss and VD2 | 0.1 μF            |
| C11      | Booster capacitor             | 0.1 μF            |
| Ср       | Inter-power supply capacitor  | 3.3 μF            |

# **27** Electrical Characteristics

# 27.1 Absolute Maximum Ratings

|                            |      |                    |                     | (Vss = 0V) |
|----------------------------|------|--------------------|---------------------|------------|
| Item                       | Code | Condition          | Rating              | Units      |
| Power supply voltage       | Vdd  |                    | -0.3 to 4.0         | V          |
| LCD power supply voltage   | Vc5  |                    | -0.3 to 6.0         | V          |
| Input voltage              | Vı   |                    | -0.3 to VDD + 0.3   | V          |
| Output voltage             | Vo   |                    | -0.3 to VDD + 0.3   | V          |
| High-level output current  | Іон  | 1 pin              | -5                  | mA         |
|                            |      | Total for all pins | -20                 | mA         |
| Low-level output current   | lo∟  | 1 pin              | 5                   | mA         |
|                            |      | Total for all pins | 20                  | mA         |
| Permissible losses*1       | Vo   |                    | 200                 | mW         |
| Operating temperature      | Та   |                    | -25 to 70           | °C         |
| Storage temperature        | Tstg |                    | -65 to 150          | °C         |
| Soldering temperature/time | Tsol |                    | 260°C, 10 s (leads) | -          |

\*1: For plastic package

# 27.2 Recommended Operating Conditions

|                                 |                |                               |      | (Т     | a = -25 to | o 70°C) |
|---------------------------------|----------------|-------------------------------|------|--------|------------|---------|
| Item                            | Code           | Condition                     | Min. | Тур.   | Max.       | Units   |
| Operating power supply          | Vdd            | Normal operating mode         | 1.8  |        | 3.6        | V       |
| voltage                         |                | Flash memory programming mode | 2.7  |        | 3.6        | V       |
| Operating frequency             | fiosc          |                               |      | 2.5    |            | MHz     |
|                                 | fosc3          | Crystal/ceramic oscillation   | 0.2  |        | 8.2        | MHz     |
|                                 | fosc1          | Crystal oscillation           |      | 32.768 | 100        | kHz     |
| Capacitor between Vss and VD1*1 | C1             |                               |      | 0.1    |            | μF      |
| Capacitor between Vss and Vc1*1 | C2             |                               |      | 0.1    |            | μF      |
| Capacitor between Vss and Vc2*1 | Cз             |                               |      | 0.1    |            | μF      |
| Capacitor between Vss and Vc3*1 | C4             |                               |      | 0.1    |            | μF      |
| Capacitor between Vss and Vc4*1 | <b>C</b> 5     |                               |      | 0.1    |            | μF      |
| Capacitor between Vss and Vc5*1 | C <sub>6</sub> |                               |      | 0.1    |            | μF      |
| Capacitor between CA and CB*1   | C7             |                               |      | 0.1    |            | μF      |
| Capacitor between CA and CC*1   | C8             |                               |      | 0.1    |            | μF      |
| Capacitor between CD and CE*1   | C9             |                               |      | 0.1    |            | μF      |
| Capacitor between Vss and VD2*1 | C10            |                               |      | 0.1    |            | μF      |
| Capacitor between CF and CG*1   | C11            |                               |      | 0.1    |            | μF      |

\*1: No capacitors are required if no LCD drive is used. Vc1 to Vc5 and CA to CG should be left open.

# 27.3 DC Characteristics

| Item                                    | Code  | Condition                                                 | Rating | Units | Max.   | Units |
|-----------------------------------------|-------|-----------------------------------------------------------|--------|-------|--------|-------|
| High level input voltage                | Viн   | Pxx                                                       | 0.8VDD |       | Vdd    | V     |
| Low level input voltage                 | VIL   | Pxx                                                       | 0      |       | 0.2VDD | V     |
| High level Schmitt input voltage (1)    | VT1+  | #RESET                                                    | 0.5VDD |       | 0.9Vdd | V     |
| Low level Schmitt input voltage (1)     | VT1-  | #RESET                                                    | 0.1VDD |       | 0.5Vdd | V     |
| High level Schmitt input voltage (2) *1 | VT2+  | Pxx                                                       | 0.5Vdd |       | 0.9Vdd | V     |
| Low level Schmitt input voltage (2) *1  | VT2-  | Pxx                                                       | 0.1Vdd |       | 0.5Vdd | V     |
| High level output current               | Іон   | Pxx, Voh = 0.9Vdd                                         |        |       | -0.5   | mA    |
| Low level output current                | lo∟   | Pxx, Vol = 0.1VDD                                         | 0.5    |       |        | mA    |
| Input leakage current                   | lu    | Pxx, #RESET                                               | -1     |       | 1      | μA    |
| Output leakage current                  | Ilo   | Pxx                                                       | -1     |       | 1      | μA    |
| Input pull-up resistance                | RIN   | Pxx, #RESET                                               | 100    |       | 500    | kΩ    |
| Input pin capacitance                   | CIN   | $Pxx$ , $V_{IN} = 0 V$ , $f = 1 MHz$ , $Ta = 25^{\circ}C$ |        |       | 15     | pF    |
| Segment, common output current          | ISEGH | SEG <i>xx</i> , COM <i>xx</i> , Vsegh = Vc5 - 0.1 V       |        |       | -5     | μA    |
| -                                       | ISEGL | SEGxx, COMxx, Vsegl = 0.1 V                               | 5      |       |        | μA    |

Unless otherwise specified:  $V_{DD} = 1.8$  to 3.6 V,  $V_{SS} = 0$  V, Ta = -25 to  $70^{\circ}C$ 

\*1: When Schmitt input is enabled



# 27.4 Analog Circuit Characteristics

## LCD driver

Since Typ values for the LCD driver will vary depending on panel load (e.g., panel size, drive duty, display pixel illumination number, display patterns), they should be evaluated by connecting the actual panel to be used. See "27.8 Characteristics Graph" for more information on load characteristics.

Unless otherwise stated,  $V_{DD} = 1.8$  V to 3.6 V,  $V_{SS} = 0$  V,  $Ta = 25^{\circ}C$ , C1 to C11 = 0.1  $\mu$ F, output is checkerboard pattern, no panel load.

| Item              | Symbol          | Conditior                              | I                   | Min.    | Тур. | Max.               | Units |
|-------------------|-----------------|----------------------------------------|---------------------|---------|------|--------------------|-------|
| LCD drive voltage | Vc1             | 1 M $\Omega$ load resistor connected b | etween Vss and Vc1  | 0.18Vc5 |      | 0.22Vc5            | V     |
|                   | V <sub>C2</sub> | 1 M $\Omega$ load resistor connected b | between Vss and Vc2 | 0.39Vc5 |      | 0.43Vc5            | V     |
|                   | Vсз             | 1 M $\Omega$ load resistor connected b | etween Vss and Vc3  | 0.59Vc5 |      | 0.63Vc5            | V     |
|                   | VC4             | 1 M $\Omega$ load resistor connected b | between Vss and Vc4 | 0.79Vc5 |      | 0.83Vc5            | V     |
|                   | Vc5             | 1 M $\Omega$ load resistor connected   | LC[3:0] = 0x0       |         | 4.20 |                    | V     |
|                   |                 | between Vss and Vc5                    | LC[3:0] = 0x1       |         | 4.30 | ]                  | V     |
|                   |                 |                                        | LC[3:0] = 0x2       |         | 4.40 | ]                  | V     |
|                   |                 |                                        | LC[3:0] = 0x3       | Тур. ×  | 4.50 | <br>Typ. ×<br>1.06 | V     |
|                   |                 |                                        | LC[3:0] = 0x4       |         | 4.60 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0x5       |         | 4.70 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0x6       |         | 4.80 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0x7       |         | 4.90 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0x8       | 0.94    | 5.00 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0x9       |         | 5.10 | ]                  | V     |
|                   |                 |                                        | LC[3:0] = 0xa       |         | 5.20 | ]                  | V     |
|                   |                 |                                        | LC[3:0] = 0xb       |         | 5.30 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0xc       |         | 5.40 |                    | V     |
|                   |                 |                                        | LC[3:0] = 0xd       |         | 5.50 | ]                  | V     |
|                   |                 |                                        | LC[3:0] = 0xe       |         | 5.60 | ]                  | V     |
|                   |                 |                                        | LC[3:0] = 0xf       |         | 5.70 | ]                  | V     |

### **SVD** circuit

Unless otherwise stated,  $V_{DD} = 1.8 V$  to 3.6 V,  $V_{SS} = 0 V$ ,  $Ta = 25^{\circ}C$ .

| Item                      | Symbol | Condition       | Min.           | Тур. | Max.           | Units |
|---------------------------|--------|-----------------|----------------|------|----------------|-------|
| SVD voltage               | Vsvd   | SVDC[3:0] = 0x0 | -              | -    | -              | V     |
|                           |        | SVDC[3:0] = 0x1 |                | 1.8  |                | V     |
|                           |        | SVDC[3:0] = 0x2 |                | 1.9  |                | V     |
|                           |        | SVDC[3:0] = 0x3 |                | 2.0  |                | V     |
|                           |        | SVDC[3:0] = 0x4 |                | 2.1  |                | V     |
|                           |        | SVDC[3:0] = 0x5 |                | 2.2  |                | V     |
|                           |        | SVDC[3:0] = 0x6 | 1              | 2.3  |                | V     |
|                           |        | SVDC[3:0] = 0x7 | <b>T</b>       | 2.4  | <b>T</b>       | V     |
|                           |        | SVDC[3:0] = 0x8 | Typ. ×<br>0.91 | 2.5  | Typ. ×<br>1.09 | V     |
|                           |        | SVDC[3:0] = 0x9 | - 0.91         | 2.6  | - 1.09         | V     |
|                           |        | SVDC[3:0] = 0xa |                | 2.7  |                | V     |
|                           |        | SVDC[3:0] = 0xb |                | 2.8  |                | V     |
|                           |        | SVDC[3:0] = 0xc |                | 2.9  |                | V     |
|                           |        | SVDC[3:0] = 0xd |                | 3.0  |                | V     |
|                           |        | SVDC[3:0] = 0xe |                | 3.1  |                | V     |
|                           |        | SVDC[3:0] = 0xf |                | 3.2  |                | V     |
| SVD circuit response time | tsvD   |                 |                |      | 500            | μs    |

#### 27 ELECTRICAL CHARACTERISTICS

## Flash memory

Unless otherwise stated,  $V_{DD} = 1.8 \text{ V}$  to 3.6 V,  $V_{SS} = 0 \text{ V}$ ,  $Ta = 25^{\circ}C$ .

| Item                             | Symbol | Condition                          | Min. | Тур. | Max. | Units  |
|----------------------------------|--------|------------------------------------|------|------|------|--------|
| Erase time*1                     | tse    | 4 Kbyte erase                      |      |      | 25   | ms     |
| Program time*1                   | tвр    | 16 byte writing                    |      |      | 20   | μs     |
| Overwriting cycles <sup>*2</sup> | CFEP   | Data retention guaranteed 10 years | 1000 |      |      | Cycles |

\*1: Including data transfer and verification but excluding erase/program start control times.

\*2: Treating erasing + writing or writing only as a single cycle.

# 27.5 Current Consumption

| Unless otherwise stated, VDD = 1.8 V to 3.6 V, Vss = 0 V, Ta = 25°C, C1 to C11 = 0.1 µF, no LCD panel load |
|------------------------------------------------------------------------------------------------------------|
| PCKEN[1:0] = 0x3 (ON), VD1MD = 0x0, FLCYC[2:0] = 0x4 (1cycle), CCKGR[1:0] = 0x1 (gear ratio 1/1)           |

| Item                                                                                         | Symbol | Condition                                                                                                  | Min. | Тур. | Max. | Units |
|----------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------|------|------|------|-------|
| SLEEP current consumption                                                                    | ISLP   | OSC1 = OFF, IOSC = OFF, OSC3 = OFF                                                                         |      | 1.2  | 3.0  | μA    |
| HALT current<br>consumption                                                                  | IHALT1 | OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF,<br>PCKEN[1:0] = 0x0 (OFF)                                           |      | 2.7  | 5.0  | μA    |
|                                                                                              | HALT2  | OSC1 = 32 kHz, IOSC = OFF, OSC3 = 8 MHz (ceramic)                                                          |      | 580  | 800  | μA    |
|                                                                                              | IHALT3 | OSC1 = 32  kHz, IOSC = ON, OSC3 = OFF                                                                      |      | 220  | 300  | μA    |
| Current consumption when operating *1                                                        | IEXE1  | OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF,<br>CPU = OSC1                                                       |      | 16   | 25   | μA    |
|                                                                                              |        | OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF,<br>CCKGR[1:0] = 0x2 (gear ratio 1/4), CPU = OSC1                    |      | 9    | 14   | μA    |
|                                                                                              | IEXE2  | OSC1 = 32 kHz, IOSC = OFF, OSC3 = 1 MHz (ceramic),<br>CPU = OSC3                                           |      | 450  | 650  | μA    |
|                                                                                              |        | OSC1 = 32 kHz, IOSC = OFF, OSC3 = 8 MHz (ceramic),<br>CPU = OSC3                                           |      | 3300 | 4700 | μA    |
|                                                                                              |        | OSC1 = 32 kHz, IOSC = OFF, OSC3 = 8 MHz (ceramic),<br>CCKGR[1:0] = 0x2 (gear ratio 1/4), CPU = OSC3        |      | 1600 | 2400 | μA    |
|                                                                                              | Iexe3  | OSC1 = 32 kHz, IOSC = ON, OSC3 = OFF, VD1MD = 1,<br>CPU = IOSC                                             |      | 1100 | 1600 | μA    |
|                                                                                              | IEXE11 | OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF, VD1MD = 1,<br>CPU = OSC1                                            |      | 35   | 50   | μA    |
|                                                                                              | IEXE21 | OSC1 = 32 kHz, IOSC = OFF, OSC3 = 1 MHz (ceramic),<br>VD1MD = 1, CPU = OSC3                                |      | 780  | 1100 | μA    |
|                                                                                              |        | OSC1 = 32 kHz, IOSC = OFF, OSC3 = 8 MHz (ceramic),<br>VD1MD = 1, CPU = OSC3                                |      | 5600 | 8000 | μA    |
|                                                                                              | IEXE31 | OSC1 = 32 kHz, IOSC = ON, OSC3 = OFF,<br>VD1MD = 1, CPU = IOSC                                             |      | 1900 | 2700 | μA    |
| Current consumption when<br>operating in heavy load<br>protection mode *1                    | Iexe1h | OSC1 = 32 kHz, IOSC = OFF, OSC3 = OFF,<br>CPU = OSC1, HVLD = 1                                             |      | 22   | 33   | μA    |
| LCD circuit current *2                                                                       | ILCD1  | DSPC[1:0] = 0x3 (all on), LC[3:0] = 0xf,<br>fosc1 = 32.768 kHz, Vpd = 2.5 to 3.6 V                         |      | 7    | 14   | μA    |
| LCD circuit current for boosting<br>power supply voltage *3                                  | ILCD2  | DSPC[1:0] = 0x3 (all on), LC[3:0] = 0xf,<br>fosc1 = 32.768 kHz, PBON = 1, Vpd = 1.8 to 2.5 V               |      | 20   | 40   | μA    |
| LCD circuit current in heavy load protection mode *4                                         | ILCD1H | DSPC[1:0] = 0x3 (all on), LC[3:0] = 0xf,<br>fosc1 = 32.768 kHz, V <sub>DD</sub> = 2.5 to 3.6 V, LHVLD = 1  |      | 10   | 20   | μA    |
| LCD circuit current for boosting<br>power supply voltage in heavy<br>load protection mode *5 | ILCD2H | DSPC[1:0] = 0x3 (all on), LC[3:0] = 0xf,<br>fosc1 = 32.768 kHz, PBON = 1, VDD = 2.5 to 3.6 V,<br>LHVLD = 1 |      | 38   | 75   | μA    |
| SVD circuit current *6                                                                       | Isvo   | VDD = 3.6 V                                                                                                |      | 5    | 10   | μA    |
| Flash EEPROM<br>erasure current *7                                                           | IFERS  | 8 MHz CPU operations, VD1MD = 1                                                                            |      | 7    | 14   | mA    |
| Flash EEPROM<br>programming current *8                                                       | IFPRG  | 8 MHz CPU operations, VD1MD = 1                                                                            |      | 7    | 14   | mA    |

\*1: Value for continuous operation while fetching "ALU commands 60.5%, branching commands 17%, memory reading 12%, memory writing 10.5%" program from Flash memory.

\*2: Added to HALT/operation current consumption for LCD circuit operation.

Current consumption may be higher, depending on display patterns and panel loads.

\*3: Added to operation current consumption in heavy load protection mode for LCD circuit operation.

Current consumption may be higher, depending on display patterns and panel loads.

\*4: Added to HALT/operation current consumption for power supply voltage booster circuit + LCD circuit operation. Current consumption may be higher, depending on display patterns and panel loads.

\*5: Added to operation current consumption in heavy load protection mode for power supply voltage booster circuit + LCD circuit operation.

Current consumption may be higher, depending on display patterns and panel loads.

\*6: Added to operation current consumption/operation current consumption in heavy load protection mode for SVD circuit operation.

\*7: Added to operation current consumption for self programming erasing.

\*8: Added to operation current consumption for self programming operation.

## 27.6 AC Characteristics

## 27.6.1 SPI AC Characteristics



#### Master mode

Unless otherwise specified:  $V_{DD} = 1.8$  to 3.6 V,  $V_{SS} = 0$  V, Ta = -25 to  $70^{\circ}C$ 

| Item                  | Code  | Min. | Тур. | Max. | Units |
|-----------------------|-------|------|------|------|-------|
| SPICLK cycle time     | tspck | 500  |      |      | ns    |
| SDI setup time        | tsps  | 70   |      |      | ns    |
| SDI hold time         | tsdh  | 10   |      |      | ns    |
| SDO output delay time | tspo  |      |      | 20   | ns    |

#### Slave mode

Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, Ta = -25 to 70°C

| Item                  | Code          | Min. | Тур. | Max. | Units |
|-----------------------|---------------|------|------|------|-------|
| SPICLK cycle time     | <b>t</b> SPCK | 500  |      |      | ns    |
| SDI setup time        | tsps          | 10   |      |      | ns    |
| SDI hold time         | tsdн          | 10   |      |      | ns    |
| SDO output delay time | tspo          |      |      | 80   | ns    |

## 27.6.2 I<sup>2</sup>C AC Characteristics



Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, Ta = -25 to  $70^{\circ}$ C

| Item                      | Code | Min.   | Тур. | Max. | Units |
|---------------------------|------|--------|------|------|-------|
| SCL cycle time            | tscL | 2500   |      |      | ns    |
| Start condition hold time | tsтн | 1/fsys |      |      | ns    |
| Data output delay time    | tsdd | 1/fsys |      |      | ns    |
| Stop condition hold time  | tspн | 1/fsys |      |      | ns    |

\* fsys: System operation clock frequency

## 27.6.3 External Clock Input AC Characteristics



Unless otherwise specified:  $V_{DD} = 1.8$  to 3.6 V,  $V_{SS} = 0$  V,  $V_{IH} = 0.8$ VDD,  $V_{IL} = 0.2$ VDD, Ta = -25 to  $70^{\circ}$ C

| Item                           | Code        | Min.   | Тур. | Max.    | Units |
|--------------------------------|-------------|--------|------|---------|-------|
| EXCLx input High pulse width   | tech        | 1/fsys |      |         | S     |
| EXCLx input Low pulse width    | tecl        | 1/fsys |      |         | S     |
| UART transfer rate             | Rυ          |        |      | 460,800 | bps   |
| UART transfer rate (IrDA mode) | Ruirda      |        |      | 115,200 | bps   |
| Input rising edge time         | tcr         |        |      | 80      | ns    |
| Input drop-off time            | <b>t</b> CF |        |      | 80      | ns    |
| OSC3 clock cycle time          | tosc3       | 125    |      |         | ns    |
| OSC3 clock input duty          | tosc3D      | 46     |      | 54      | %     |

\*fsys: System operation clock frequency

## 27.6.4 System AC Characteristics



Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, VIH = 0.8VDD, VIL = 0.2VDD, Ta = -25 to 70°C

| Item                  | Code | Min. | Тур. | Max. | Units |
|-----------------------|------|------|------|------|-------|
| Reset Low pulse width | tsr  | 100  |      |      | μs    |

## 27.7 Oscillation Characteristics

Oscillation characteristics depend on various parameters, including circuit board patterns and the components used. Use the values given for the following characteristics as reference values. In particular, if ceramic or crystal oscillators are used for OSC3, parameters such as capacitance and resistance should have the values recommended by the oscillator manufacturer. Oscillation start time is an important factor, since it establishes the wait time when using the OSC3 clock.

#### **OSC1** crystal oscillator

Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, Ta = 25°C,

crystal oscillator = FC-255X (R1 = 30 k $\Omega$  to 70 k $\Omega$  Typ., CL = 12.5 pF)\*1,

| Item                                     | Symbol          | Condition                       | Min. | Тур. | Max. | Units |
|------------------------------------------|-----------------|---------------------------------|------|------|------|-------|
| Oscillation start time                   | tsta            |                                 |      |      | 3    | s     |
| External gate capacitance                | C <sub>G1</sub> | Including board capacitance     | 0    |      | 25   | pF    |
| Internal drain capacitance               | CD1             | For chip                        |      | 10   |      | pF    |
| Frequency IC deviation                   | ∂f/∂IC          | VDD = Constant                  | -10  |      | 10   | ppm   |
| Frequency power supply voltage deviation | ∂f/∂V           |                                 |      |      | 1    | ppm/V |
| Frequency adjustment range               | ∂f/∂Cg          | VDD = Constant, CG = 0 to 25 pF | 25   |      |      | ppm   |
|                                          |                 |                                 |      |      |      |       |

CG1 = 25 pF external, CD1 = internal.

\*1: FC-255X: Epson Toyocom

#### **OSC3 crystal oscillator**

Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, Ta = 25°C,

crystal oscillator = CA-301<sup>\*1</sup>, Rf = 1 M $\Omega$ , CG3 = CD3 = 15 pF

| Item                     | Symbol | Condition | Min. | Тур. | Max. | Units |
|--------------------------|--------|-----------|------|------|------|-------|
| Oscillation start time*2 | tsta   |           |      |      | 10   | ms    |

\*1: CA-301: Seiko Epson

\*2: The crystal oscillator oscillation start time varies with the crystal oscillator used and CG3 and CD3.

#### **OSC3** ceramic oscillator

Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, Ta = 25°C,

ceramic oscillator = KBR-4.0MSB/KBR-8.0MSB<sup>\*1</sup>,  $R_f = 1 M\Omega$ ,  $C_{C_2} = C_{D_2} = 30 \text{ pE}$ 

| 063 -                    | -003 = 30    | þi        |      |      |      |       |
|--------------------------|--------------|-----------|------|------|------|-------|
| Item                     | Symbol       | Condition | Min. | Тур. | Max. | Units |
| Oscillation start time*2 | <b>t</b> sta |           |      |      | 1    | ms    |

\*1: KBR-4.0MSB/KBR-8.0MSB: Kyocera

\*2: Ceramic oscillator oscillation start time varies depending on the ceramic oscillator used and CG3 and CD3.

#### **IOSC CR oscillator**

Unless otherwise specified: VDD = 1.8 to 3.6 V, Vss = 0 V, Ta = 25°C

| Item                   | Symbol | Condition   | Min. | Typ. | Max. | Units |
|------------------------|--------|-------------|------|------|------|-------|
| Oscillation start time | tsta   |             |      | 190. | 5    | μs    |
| Oscillation frequency  | fiosc  | VD1 = 1.8 V | 2.16 | 2.70 | 3.24 | MHz   |

## 27.8 Characteristics Graphs (Reference Values)



## High-level output current characteristics

#### Low-level output current characteristics

Ta = 70°C, Min. value



# LCD drive voltage power supply voltage characteristics (Not using power supply voltage booster circuit)



With 1 M $\Omega$  load resistance connected between Vss and Vcs (no panel load)

# LCD drive voltage power supply voltage characteristics (Using power supply voltage booster circuit)

With 1 M $\Omega$  load resistance connected between Vss and Vcs (no panel load)



#### LCD drive voltage temperature characteristics



## LCD drive voltage load characteristics



With load connected to Vc5 only

LC[3:0] = 0xf, Ta = 25°C, Typ. value

#### SVD voltage temperature characteristics





HALT current consumption temperature characteristics (OSC1 operation) (Crystal oscillation, fosc1 = 32.768 kHz)



# Execution current consumption temperature characteristics (OSC1 operation) (Crystal oscillation, fosc1 = 32.768 kHz)



Execution current consumption frequency characteristics (OSC3 operation) (Crystal oscillation/ceramic oscillation)

VDD = 3.6 V, Ta = 25°C, Typ.value



(Units: mm)

# 28 Package

## QFP21-176 pin package

.7max

26<sup>±0.4</sup> 24<sup>±0.1</sup> 132 89 133 88 **24**±0.1 **26**±0.4 INDEX 45 0.2<sup>+0.1</sup> 0.5 1**.4**±0.1 +0.05 0.125 0° 10 0.1 <u>0.5±0.2</u> 1

## VFBGA8H-181 package

## **Top View**





1 2 3 4 5 6 7 8 9 10 11 12 13 14

D

C B A

A1 Corner

| Symbol | Dimen | sion in Milli | meters |
|--------|-------|---------------|--------|
| Symbol | Min.  | Nom.          | Max.   |
| D      | -     | 8             | -      |
| E      | -     | 8             | -      |
| A      | -     | -             | 1.0    |
| A1     | -     | 0.23          | -      |
| е      | -     | 0.5           | -      |
| b      | 0.26  | -             | 0.36   |
| х      | -     | -             | 0.08   |
| у      | -     | -             | 0.1    |
| SD     | -     | 0.25          | -      |
| SE     | _     | 0.25          | -      |

θ

S

₩×φ⊕

ģ

#### VFBGA10H-180 package







| Symbol | Dimen | sion in Milli | meters |
|--------|-------|---------------|--------|
| Symbol | Min.  | Nom.          | Max.   |
| D      | -     | 10            | -      |
| E      | -     | 10            | Ι      |
| Α      | -     | -             | 1.0    |
| A1     | -     | 0.22          | Ι      |
| е      | -     | 0.65          | Ι      |
| b      | 0.27  | -             | 0.37   |
| х      | -     | -             | 0.08   |
| у      | -     | -             | 0.1    |
| SD     | -     | 0.325         | _      |
| SE     | _     | 0.325         | -      |

# Appendix A I/O Register List

## Internal Peripheral Circuit Area 1 (0x4000 onward)

| Peripheral circuit   | Address          |                    | Register name                                                        | Function                                                                               |
|----------------------|------------------|--------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| Prescaler            | 0x4020           | PSC CTL            | Prescaler Control Register                                           | Prescaler start/stop control                                                           |
| (8-bit device)       | 0x4021-0x403f    | _                  | _                                                                    | Reserved                                                                               |
| UART (with IrDA)     | 0x4100           | UART_ST0           | UART Ch.0 Status Register                                            | Transfer, buffer, error status display                                                 |
| Ch.0 `               | 0x4101           | UART_TXD0          | UART Ch.0 Transmit Data Register                                     | Transmission data                                                                      |
| (8-bit device)       | 0x4102           | UART_RXD0          | UART Ch.0 Receive Data Register                                      | Receiving data                                                                         |
|                      | 0x4103           | UART_MOD0          | UART Ch.0 Mode Register                                              | Transfer data format setting                                                           |
|                      | 0x4104           | UART_CTL0          | UART Ch.0 Control Register                                           | Data transfer control                                                                  |
|                      | 0x4105           | UART_EXP0          | UART Ch.0 Expansion Register                                         | IrDA mode setting                                                                      |
|                      | 0x4106-0x411f    | _                  | _                                                                    | Reserved                                                                               |
| UART (with IrDA)     | 0x4120           | UART_ST1           | UART Ch.1 Status Register                                            | Transfer, buffer, error status display                                                 |
| Ch.1                 | 0x4121           | UART_TXD1          | UART Ch.1 Transmit Data Register                                     | Transmission data                                                                      |
| (8-bit device)       | 0x4122           | UART_RXD1          | UART Ch.1 Receive Data Register                                      | Receiving data                                                                         |
|                      | 0x4123           | UART_MOD1          | UART Ch.1 Mode Register                                              | Transfer data format setting                                                           |
|                      | 0x4124           | UART_CTL1          | UART Ch.1 Control Register                                           | Data transfer control                                                                  |
|                      | 0x4125           | UART_EXP1          | UART Ch.1 Expansion Register                                         | IrDA mode setting                                                                      |
|                      | 0x4126-0x413f    | _                  | -                                                                    | Reserved                                                                               |
| 8-bit timer (with    | 0x4200           | T8F_CLK0           | 8-bit Timer Ch.0 Input Clock Select Register                         | Prescaler output clock selection                                                       |
| F mode) Ch.0         | 0x4202           | T8F_TR0            | 8-bit Timer Ch.0 Reload Data Register                                | Reload data setting                                                                    |
| (16-bit device)      | 0x4204           | T8F_TC0            | 8-bit Timer Ch.0 Counter Data Register                               | Counter data                                                                           |
|                      | 0x4206           | T8F_CTL0           | 8-bit Timer Ch.0 Control Register                                    | Timer mode setting and timer RUN/STOP                                                  |
|                      | 0x4208           | T8F_INT0           | 8-bit Timer Ch.0 Interrupt Control Register                          | Interrupt control                                                                      |
|                      | 0x420a-0x421f    | _                  | -                                                                    | Reserved                                                                               |
| 16-bit timer Ch.0    | 0x4220           | T16_CLK0           | 16-bit Timer Ch.0 Input Clock Select Register                        | Prescaler output clock selection                                                       |
| (16-bit device)      | 0x4222           |                    | 16-bit Timer Ch.0 Reload Data Register                               | Reload data setting                                                                    |
|                      | 0x4224           |                    | 16-bit Timer Ch.0 Counter Data Register                              | Counter data                                                                           |
|                      | 0x4226           | T16_CTL0           | 16-bit Timer Ch.0 Control Register                                   | Timer mode setting and timer RUN/STOP                                                  |
|                      | 0x4228           | T16_INT0           | 16-bit Timer Ch.0 Interrupt Control Register                         | Interrupt control                                                                      |
|                      | 0x422a-0x423f    | _                  | _                                                                    | Reserved                                                                               |
| 16-bit timer Ch.1    | 0x4240           | T16_CLK1           | 16-bit Timer Ch.1 Input Clock Select Register                        | Prescaler output clock selection                                                       |
| (16-bit device)      | 0x4242           | T16_TR1            | 16-bit Timer Ch.1 Reload Data Register                               | Reload data setting                                                                    |
|                      | 0x4244           | T16_TC1            | 16-bit Timer Ch.1 Counter Data Register                              | Counter data                                                                           |
|                      | 0x4246           | T16_CTL1           | 16-bit Timer Ch.1 Control Register                                   | Timer mode setting and timer RUN/STOP                                                  |
|                      | 0x4248           | T16_INT1           | 16-bit Timer Ch.1 Interrupt Control Register                         | Interrupt control                                                                      |
|                      | 0x424a-0x425f    | _                  | _                                                                    | Reserved                                                                               |
| 16-bit timer Ch.2    | 0x4260           | T16_CLK2           | 16-bit Timer Ch.2 Input Clock Select Register                        | Prescaler output clock selection                                                       |
| (16-bit device)      | 0x4262           | T16_TR2            | 16-bit Timer Ch.2 Reload Data Register                               | Reload data setting                                                                    |
|                      | 0x4264           | T16_TC2            | 16-bit Timer Ch.2 Counter Data Register                              | Counter data                                                                           |
|                      | 0x4266           | T16_CTL2           | 16-bit Timer Ch.2 Control Register                                   | Timer mode setting and timer RUN/STOP                                                  |
|                      | 0x4268           |                    | 16-bit Timer Ch.2 Interrupt Control Register                         | Interrupt control                                                                      |
|                      | 0x426a-0x427f    | _                  | _                                                                    | Reserved                                                                               |
| 8-bit timer          | 0x4280           | T8F_CLK1           | 8-bit Timer Ch.1 Input Clock Select Register                         | Prescaler output clock selection                                                       |
| (with F mode)        | 0x4282           | T8F TR1            | 8-bit Timer Ch.1 Reload Data Register                                | Reload data setting                                                                    |
| Ch.1                 | 0x4284           | T8F_TC1            | 8-bit Timer Ch.1 Counter Data Register                               | Counter data                                                                           |
| (16-bit device)      | 0x4286           | T8F_CTL1           | 8-bit Timer Ch.1 Control Register                                    | Timer mode setting and timer RUN/STOP                                                  |
|                      | 0x4288           | T8F_INT1           | 8-bit Timer Ch.1 Interrupt Control Register                          | Interrupt control                                                                      |
|                      | 0x428a-0x429f    | _                  | _                                                                    | Reserved                                                                               |
| Interrupt controller |                  | _                  | _                                                                    | Reserved                                                                               |
| (16-bit device)      | 0x4306           | ITC_LV0            | Interrupt Level Setup Register 0                                     | P0/P1 interrupt level setting                                                          |
|                      | 0x4308           | ITC_LV1            | Interrupt Level Setup Register 1                                     | SWT/CT interrupt level setting                                                         |
|                      | 0x430a           | ITC LV2            | Interrupt Level Setup Register 2                                     | T8OSC1/SVD interrupt level setting                                                     |
|                      | 0x430c           | ITC_LV3            | Interrupt Level Setup Register 3                                     | LCD/T16E Ch.0 interrupt level setting                                                  |
|                      | 0x430e           | ITC_LV4            | Interrupt Level Setup Register 4                                     | T8F/T16 Ch.0 interrupt level setting                                                   |
|                      | 0x4310           | ITC_LV5            | Interrupt Level Setup Register 5                                     | T16 Ch.1/Ch.2 interrupt level setting                                                  |
|                      | 0x4312           | ITC_LV6            | Interrupt Level Setup Register 6                                     | UART Ch.0/Ch.1 interrupt level setting                                                 |
|                      |                  |                    |                                                                      |                                                                                        |
|                      |                  |                    | Interrupt Level Setup Register 7                                     | SPI/I <sup>2</sup> C interrupt level setting                                           |
|                      | 0x4314<br>0x4316 | ITC_LV7<br>ITC_LV8 | Interrupt Level Setup Register 7<br>Interrupt Level Setup Register 8 | SPI/I <sup>2</sup> C interrupt level setting<br>REMC/T16E Ch.1 interrupt level setting |

| Peripheral circuit | Address       |          | Register name                               | Function                                             |
|--------------------|---------------|----------|---------------------------------------------|------------------------------------------------------|
| SPI                | 0x4320        | SPI_ST   | SPI Status Register                         | Transfer and buffer status display                   |
| (16-bit device)    | 0x4322        | SPI_TXD  | SPI Transmit Data Register                  | Transmission data                                    |
|                    | 0x4324        | SPI_RXD  | SPI Receive Data Register                   | Receiving data                                       |
|                    | 0x4326        | SPI_CTL  | SPI Control Register                        | SPI mode and data transfer permission setting        |
|                    | 0x4328–0x433f | -        | -                                           | Reserved                                             |
| I <sup>2</sup> C   | 0x4340        | I2C_EN   | I <sup>2</sup> C Enable Register            | I <sup>2</sup> C module enable                       |
| (16-bit device)    | 0x4342        | I2C_CTL  | I <sup>2</sup> C Control Register           | I <sup>2</sup> C control and transfer status display |
|                    | 0x4344        | I2C_DAT  | I <sup>2</sup> C Data Register              | Transfer data                                        |
|                    | 0x4346        | I2C_ICTL | I <sup>2</sup> C Interrupt Control Register | I <sup>2</sup> C interrupt control                   |
|                    | 0x4348–0x435f | -        | _                                           | Reserved                                             |

## Internal Peripheral Circuit Area 2 (0x5000 onward)

| Peripheral circuit                      | Address                 |             | Register name                              | Function                                         |
|-----------------------------------------|-------------------------|-------------|--------------------------------------------|--------------------------------------------------|
| Clock timer                             | 0x5000                  | CT_CTL      | Clock Timer Control Register               | Timer reset and RUN/STOP control                 |
| (8-bit device)                          | 0x5001                  | CT_CNT      | Clock Timer Counter Register               | Counter data                                     |
|                                         | 0x5002                  | CT_IMSK     | Clock Timer Interrupt Mask Register        | Interrupt mask setting                           |
|                                         | 0x5003                  | CT_IFLG     | Clock Timer Interrupt Flag Register        | Interrupt occurrence status display/reset        |
|                                         | 0x5004-0x501f           | _           | _                                          | Reserved                                         |
| Stopwatch timer                         | 0x5020                  | SWT CTL     | Stopwatch Timer Control Register           | Timer reset and RUN/STOP control                 |
| (8-bit device)                          | 0x5021                  | SWT_BCNT    | Stopwatch Timer BCD Counter Register       | BCD counter data                                 |
| , ,                                     | 0x5022                  | SWT IMSK    | Stopwatch Timer Interrupt Mask Register    | Interrupt mask setting                           |
|                                         | 0x5023                  | SWT IFLG    | Stopwatch Timer Interrupt Flag Register    | Interrupt occurrence status display/reset        |
|                                         | 0x5024-0x503f           | _           |                                            | Reserved                                         |
| Watchdog timer                          | 0x5040                  | WDT_CTL     | Watchdog Timer Control Register            | Timer reset and RUN/STOP control                 |
| (8-bit device)                          | 0x5041                  | WDT ST      | Watchdog Timer Status Register             | Timer mode setting and NMI status display        |
| ,                                       | 0x5042-0x505f           | _           |                                            | Reserved                                         |
| Oscillator circuit                      | 0x5060                  | OSC_SRC     | Clock Source Select Register               | Clock source selection                           |
| (8-bit device)                          | 0x5061                  | OSC_CTL     | Oscillation Control Register               | Oscillation control                              |
| (,                                      | 0x5062                  | OSC NFEN    | Noise Filter Enable Register               | Noise filter ON/OFF                              |
|                                         | 0x5063                  | OSC LCLK    | LCD Clock Setup Register                   | Reserved                                         |
|                                         | 0x5064                  | OSC_FOUT    | FOUT Control Register                      | Clock external output control                    |
|                                         | 0x5065                  | OSC_T8OSC1  | T8OSC1 Clock Control Register              | 8-bit OSC1 timer clock setting                   |
|                                         | 0x5066-0x507f           | _           |                                            | Reserved                                         |
| Clock generator                         | 0x5080                  | CLG_PCLK    | PCLK Control Register                      | PCLK feed control                                |
| (8-bit device)                          | 0x5080                  | CLG CCLK    | CCLK Control Register                      | CCLK division ratio setting                      |
| (,                                      | 0x5081<br>0x5082-0x509f |             |                                            | Reserved                                         |
| LCD driver                              | 0x50a0                  | LCD_DCTL    | LCD Display Control Register               | LCD display control                              |
| (8-bit device)                          | 0x50a0                  | LCD CADJ    | LCD Contrast Adjust Register               | Contrast control                                 |
| (••••••)                                | 0x50a2                  | LCD_CCTL    | LCD Clock Control Register                 | LCD clock duty selection                         |
|                                         | 0x50a2                  | LCD VREG    | LCD Voltage Regulator Control Register     | LCD driver voltage regulator control             |
|                                         | 0x50a4                  | LCD_PWR     | LCD Power Voltage Booster Control Register | LCD power supply voltage booster circuit control |
|                                         | 0x50a5                  | LCD IMSK    | LCD Interrupt Mask Register                | Interrupt mask setting                           |
|                                         | 0x50a6                  | LCD IFLG    | LCD Interrupt Flag Register                | Interrupt occurrence status display/reset        |
|                                         | 0x50a7-0x50bf           | _           | _                                          | Reserved                                         |
| 8-bit OSC1 timer                        | 0x50c0                  | T8OSC1_CTL  | 8-bit OSC1 Timer Control Register          | Timer mode setting and timer RUN/STOP            |
| (8-bit device)                          | 0x50c1                  | T8OSC1_CNT  | 8-bit OSC1 Timer Counter Data Register     | Counter data                                     |
|                                         | 0x50c2                  | T8OSC1 CMP  | 8-bit OSC1 Timer Compare Data Register     | Compare data setting                             |
|                                         | 0x50c3                  |             | 8-bit OSC1 Timer Interrupt Mask Register   | Interrupt mask data                              |
|                                         | 0x50c4                  | T8OSC1_IFLG | 8-bit OSC1 Timer Interrupt Flag Register   | Interrupt occurrence status display/reset        |
|                                         | 0x50c5                  | T8OSC1 DUTY | 8-bit OSC1 Timer PWM Duty Data Register    | PWM output data setting                          |
|                                         | 0x50c6-0x50df           | _           | _                                          | Reserved                                         |
| SVD circuit                             | 0x5100                  | SVD_EN      | SVD Enable Register                        | SVD operation permitted/prevented                |
| (8-bit device)                          | 0x5101                  | SVD_LIV     | SVD Compare Voltage Register               | Comparison voltage setting                       |
|                                         | 0x5102                  | SVD_RSLT    | SVD Detection Result Register              | Voltage detection results                        |
|                                         | 0x5103                  | SVD IMSK    | SVD Interrupt Mask Register                | Interrupt mask setting                           |
|                                         | 0x5104                  | SVD IFLG    | SVD Interrupt Flag Register                | Interrupt occurrence status display/reset        |
|                                         | 0x5105-0x511f           |             |                                            | Reserved                                         |
| Power supply circuit                    | 0x5120                  | VD1 CTL     | VD1 Control Register                       | VD1 voltage and load protection control          |
| (8-bit device)                          | 0x5121-0x513f           |             |                                            | Reserved                                         |
| ( · · · · · · · · · · · · · · · · · · · | 072151-072131           | 1           |                                            |                                                  |

| Peripheral circuit | Address                 |               | Register name                                  | Function                                          |
|--------------------|-------------------------|---------------|------------------------------------------------|---------------------------------------------------|
| P port & port MUX  | 0x5200                  | P0_IN         | P0 Port Input Data Register                    | P0 port input data                                |
| (8-bit device)     | 0x5201                  | P0_OUT        | P0 Port Output Data Register                   | P0 port output data                               |
|                    | 0x5202                  | P0_OEN        | P0 Port Output Enable                          | P0 port output enable                             |
|                    | 0x5203                  | P0_PU         | P0 Port Pull-up Control Register               | P0 port pull-up control                           |
|                    | 0x5204                  | P0_SM         | P0 Port Schmitt Trigger Control Register       | P0 port Schmitt trigger control                   |
|                    | 0x5205                  | P0_IMSK       | P0 Port Interrupt Mask Register                | P0 port interrupt mask setting                    |
|                    | 0x5206                  | P0_EDGE       | P0 Port Interrupt Edge Select Register         | P0 port interrupt edge selection                  |
|                    | 0x5207                  | P0_IFLG       | P0 Port Interrupt Flag Register                | P0 port interrupt occurrence status display/reset |
|                    | 0x5208                  | P0_CHAT       | P0 Port Chattering Filter Control Register     | P0 port chattering filter control                 |
|                    | 0x5209                  | P0_KRST       | P0 Port Key-Entry Reset Configuration Register | P0 port key entry reset setting                   |
|                    | 0x520a                  | P0_IEN        | P0 Port Input Enable Register                  | P0 port input enable                              |
|                    | 0x520b-0x520f           | -             | -                                              | Reserved                                          |
|                    | 0x5210                  | P1_IN         | P1 Port Input Data Register                    | P1 port input data                                |
|                    | 0x5211                  | P1_OUT        | P1 Port Output Data Register                   | P1 port output data                               |
|                    | 0x5212                  | P1_OEN        | P1 Port Output Enable                          | P1 port output enable                             |
|                    | 0x5213                  | P1_PU         | P1 Port Pull-up Control Register               | P1 port pull-up control                           |
|                    | 0x5214                  | P1_SM         | P1 Port Schmitt Trigger Control Register       | P1 port Schmitt trigger control                   |
|                    | 0x5215                  | P1_IMSK       | P1 Port Interrupt Mask Register                | P1 port interrupt mask setting                    |
|                    | 0x5216                  | P1_EDGE       | P1 Port Interrupt Edge Select Register         | P1 port interrupt edge selection                  |
|                    | 0x5217                  | P1_IFLG       | P1 Port Interrupt Flag Register                | P1 port interrupt occurrence status display/reset |
|                    | 0x5218                  | P1_CHAT       | P1 Port Chattering Filter Control Register     | P1 port chattering filter control                 |
|                    | 0x5219                  | -             | _                                              | Reserved                                          |
|                    | 0x521a                  | P1_IEN        | P1 Port Input Enable Register                  | P1 port input enable                              |
|                    | 0x521b-0x521f           | -             | -                                              | Reserved                                          |
|                    | 0x5220                  | P2_IN         | P2 Port Input Data Register                    | P2 port input data                                |
|                    | 0x5221                  | P2_OUT        | P2 Port Output Data Register                   | P2 port output data                               |
|                    | 0x5222                  | P2_OEN        | P2 Port Output Enable                          | P2 port output enable                             |
|                    | 0x5223                  | P2_PU         | P2 Port Pull-up Control Register               | P2 port pull-up control                           |
|                    | 0x5224                  | P2_SM         | P2 Port Schmitt Trigger Control Register       | P2 port Schmitt trigger control                   |
|                    | 0x5225-0x5229           | _             | -                                              | Reserved                                          |
|                    | 0x522a                  | P2_IEN        | P2 Port Input Enable Register                  | P2 port input enable                              |
|                    | 0x522b-0x522f           | -             | -                                              | Reserved                                          |
|                    | 0x5230                  | P3_IN         | P3 Port Input Data Register                    | P3 port input data                                |
|                    | 0x5231                  | P3_OUT        | P3 Port Output Data Register                   | P3 port output data                               |
|                    | 0x5232                  | P3_OEN        | P3 Port Output Enable                          | P3 port output enable                             |
|                    | 0x5233                  | P3_PU         | P3 Port Pull-up Control Register               | P3 port pull-up control                           |
|                    | 0x5234                  | P3 SM         | P3 Port Schmitt Trigger Control Register       | P3 port Schmitt trigger control                   |
|                    | 0x5235-0x5239           | _             | -                                              | Reserved                                          |
|                    | 0x523a                  | P3 IEN        | P3 Port Input Enable Register                  | P3 port input enable                              |
|                    | 0x523b-0x527f           | -             | -                                              | Reserved                                          |
|                    | 0x52a0                  | P0_PMUX       | P0 Port Function Select Register               | P0 port function selection                        |
|                    | 0x52a1                  | P1_PMUX       | P1 Port Function Select Register               | P1 port function selection                        |
|                    | 0x52a2                  | P2_PMUX       | P2 Port Function Select Register               | P2 port function selection                        |
|                    | 0x52a3                  | P3_PMUX       | P3 Port Function Select Register               | P3 port function selection                        |
|                    | 0x52a4-0x52bf           | _             |                                                | Reserved                                          |
| PWM & capture      | 0x5300                  | T16E_CA0      | PWM Timer Ch.0 Compare Data A Register         | Compare data A setting                            |
| timer Ch.0         | 0x5302                  | T16E_CB0      | PWM Timer Ch.0 Compare Data B Register         | Compare data B setting                            |
| (16-bit device)    | 0x5304                  | T16E_TC0      | PWM Timer Ch.0 Counter Data Register           | Counter data                                      |
|                    | 0x5306                  | T16E_CTL0     | PWM Timer Ch.0 Control Register                | Timer mode setting and timer RUN/STOP             |
|                    | 0x5308                  | T16E_CLK0     | PWM Timer Ch.0 Input Clock Select Register     | Prescaler output clock selection                  |
|                    | 0x530a                  | T16E_IMSK0    | PWM Timer Ch.0 Interrupt Mask Register         | Interrupt mask setting                            |
|                    | 0x530c                  | T16E_IFLG0    | PWM Timer Ch.0 Interrupt Flag Register         | Interrupt occurrence status display/reset         |
|                    | 0x530e-0x531f           | _             |                                                | Reserved                                          |
| MISC register      | 0x5320                  | MISC_FL       | FLASHC/SRAMC Control Register                  | FLASHC/SRAMC access condition setting             |
| (16-bit device)    | 0x5322                  | MISC_OSC1     | OSC1 Peripheral Control Register               | OSC1 operation peripheral function setting        |
| (                  | 0,5522                  | 10100_0001    |                                                | for debugging                                     |
|                    | 0x5324                  | MISC_PROT     | MISC Protect Register                          | MISC register program protection                  |
|                    | 0x5326                  |               | IRAM Size Select Register                      | IRAM size selection                               |
|                    | 0x5328                  | MISC_TTBRL    | Vector Table Address Low Register              | Vector table address setting                      |
|                    | 0x532a                  | MISC_TTBRH    | Vector Table Address Low Register              |                                                   |
|                    | 0x532c                  | MISC_TIBRH    | PSR Register                                   | S1C17 core PSR readout                            |
|                    | 0x532e-0x533f           |               | _                                              | Reserved                                          |
| Remote control-    | 0x5320-0x5331           | -<br>REMC_CFG | REMC Configuration Register                    | Clock transfer control                            |
| ler                |                         |               |                                                | Carrier H/L section length setting                |
| (16-bit device)    | 0x5342                  | REMC_CAR      | REMC Carrier Length Setup Register             |                                                   |
|                    | 0x5344                  | REMC_LCNT     | REMC Length Counter Register                   | Transfer bit and transfer data length setting     |
|                    |                         |               | REMC Interrupt Control Degister                | Interrupt contro!                                 |
|                    | 0x5346<br>0x5348–0x535f | REMC_INT      | REMC Interrupt Control Register                | Interrupt control<br>Reserved                     |

| Peripheral circuit | Address       |            | Register name                              | Function                                  |
|--------------------|---------------|------------|--------------------------------------------|-------------------------------------------|
| PWM & capture      | 0x5360        | T16E_CA1   | PWM Timer Ch.1 Compare Data A Register     | Compare data A setting                    |
| timer Ch.1         | 0x5362        | T16E_CB1   | PWM Timer Ch.1 Compare Data B Register     | Compare data B setting                    |
| (16-bit device)    | 0x5364        | T16E_TC1   | PWM Timer Ch.1 Counter Data Register       | Counter data                              |
|                    | 0x5366        | T16E_CTL1  | PWM Timer Ch.1 Control Register            | Timer mode setting and timer RUN/STOP     |
|                    | 0x5368        | T16E_CLK1  | PWM Timer Ch.1 Input Clock Select Register | Prescaler output clock selection          |
|                    | 0x536a        | T16E_IMSK1 | PWM Timer Ch.1 Interrupt Mask Register     | Interrupt mask setting                    |
|                    | 0x536c        | T16E_IFLG1 | PWM Timer Ch.1 Interrupt Flag Register     | Interrupt occurrence status display/reset |
|                    | 0x536e-0x537f | -          | _                                          | Reserved                                  |

## Core I/O Reserved Area 2 (0xffff84 onward)

| Peripheral circuit | Address  |       | Register name                        | Function                             |
|--------------------|----------|-------|--------------------------------------|--------------------------------------|
| S1C17 Core I/O     | 0xffff84 | IDIR  | Processor ID Register                | Processor ID display                 |
|                    | 0xffff90 | DBRAM | Debug RAM Base Register              | Debugging RAM base address display   |
|                    | 0xffffa0 | DCR   | Debug Control Register               | Debug control                        |
|                    | 0xffffb8 | IBAR2 | Instruction Break Address Register 2 | Instruction break address #2 setting |
|                    | 0xfffbc  | IBAR3 | Instruction Break Address Register 3 | Instruction break address #3 setting |
|                    | 0xffffd0 | IBAR4 | Instruction Break Address Register 4 | Instruction break address #4 setting |

Note: Addresses marked as "Reserved" or unused peripheral circuit areas not marked in the table must not be accessed by application programs.

| 0x4020         |          |      |       |                                  |   |     |     |      |       |     | Prescaler          |
|----------------|----------|------|-------|----------------------------------|---|-----|-----|------|-------|-----|--------------------|
| Register name  | Address  | Bit  | Name  | Function                         |   | Set | tin | g    | Init. | R/W | Remarks            |
| Prescaler Con- | 0x4020   | D7–2 | -     | reserved                         |   | -   | -   |      | -     | -   | 0 when being read. |
| trol Register  | (8 bits) | D1   | PRUND | Prescaler run/stop in debug mode | 1 | Run | 0   | Stop | 0     | R/W |                    |
| (PSC_CTL)      |          | D0   | PRUN  | Prescaler run/stop control       | 1 | Run | 0   | Stop | 0     | R/W |                    |

### 0x4100-0x4124

## UART (with IrDA)

| Status Register<br>(UART_STO)         06         FER         Framing error flag         1         Error         0         Normal         0         RWP           D4         OER         Overun error flag         1         Error         0         Normal         0         RWP           D4         OER         Overun error flag         1         Eeror         0         Normal         0         RWP           D2         TRBS         Transmit busy flag         1         Basy         0         Ind         0         R           UART Ch.0         OX1010         D-0         TDBE         Transmit data         TXD7(9)         MSB         TXD7(9)         MSB         R         Ox00 to Oxff (0x77)         0x0         R         R         Ox10 for f (0x7)         R <th>Register name</th> <th>Address</th> <th>Bit</th> <th>Name</th> <th>Function</th> <th></th> <th>Set</th> <th>tin</th> <th>g</th> <th>Init.</th> <th>R/W</th> <th>Remarks</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Register name | Address  | Bit  | Name       | Function                            |          | Set                                   | tin      | g         | Init.    | R/W   | Remarks                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------|------|------------|-------------------------------------|----------|---------------------------------------|----------|-----------|----------|-------|------------------------|
| UART S.TO         D5         PER         Party error flag         1         Error         0         Normal         0         PAW           D4         D56         Over un error flag         1         Error         0         Normal         0         RW           D2         TRBS         Transmit busy flag         1         Busy         0         Ide         Normal         0         RV           D4         TDRP         Receive data         TABS         Tamsmit data         Normal         0         Normal         0         R         NV           UART Ch.0         0x4101         D7-0         TXD7(7)         Insemit data         DV         Normal         0x0 to 0x1 (0x7)         0x0         R         NV           UART Ch.0         0x4102         D7-0         TXD7(7)         MSB         Normal         0x0 to 0x1 (0x7)         0x0         R         Over other bain final f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | UART Ch.0     | 0x4100   | D7   | -          | reserved                            |          | -                                     | _        |           |          |       | 0 when being read.     |
| UA         DER         Overrum error flag         1         Error         0         Normal         0         P           D8         D28         Scond by for cook flag         1         Bauy         0         Im         D         R P           D1         RDPW         Receive data ready flag         1         Bauy         0         Ind         D         R           UART Ch.0         Oxf010         D2-0         TDRE         Transmit data         TXD (9)         Statistic system         D         Note ency         1         R           Register         Oxf010         D2-0         TXD (7)         Transmit data         TXD (7)         Oxf0         Oxf0         Oxf0         Oxf0         Oxf0         D         R         Oxf0         D         R         Oxf0         Oxf0         Oxf0         Oxf0         Oxf0         D         R         Oxf0         D         D         D         D         D         D         D         D         D         D         D         D         D         D         D         D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | (8 bits) | D6   | FER        | Framing error flag                  | 1        | Error                                 |          | Normal    | 0        | R/W   | Reset by writing 1.    |
| UART Ch.0         Do3 R028         Second byte neceve flag         T Ready         D Empty         D         R         Shift register           UART Ch.0         De4101         O         R         Shift register         0         No         R         Shift register           UART Ch.0         Oct00         TOO         TAD(7-0)         TAD(7-0)         TAD(7-0)         TAD(7-0)         TAD(7-0)         Shift register         0x0 to 0x1 (0x7)         0x0         R         W           UART Ch.0         0x4102         D <sup>-0</sup> TAD(7-0)         RAD(7-0)         RAD(7-0)         RAD(7-0)         RAD(7-0)         RAD(7-0)         Not so 0x1 (0x7)         0x0         0x0         0x0 to 0x1 (0x7)         0x0         R         W           UART Ch.0         0x4102         D <sup>-0</sup> RAD(7-0)         RAD(7-0)         RAD(7-0)         Not so 0x1 (0x7)         0x0         0x0         0x1 (0x7)         0x0         Not so 0x1 (0x7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (UART_ST0)    |          | D5   |            | Parity error flag                   | 1        | Error                                 | -        | Normal    | -        | R/W   | ]                      |
| Dot         THBS         Transmit bucy flag         1         Blusy         0         Description         0         R         Strittegite           JART Ch.0         0         Addition         0         Filter         Strittegite         0         Notempy         1         R         R           JART Ch.0         0         Addition         0         Notempy         1         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |          | D4   | OER        | Overrun error flag                  | 1        | Error                                 | 0        | Normal    | 0        | R/W   |                        |
| Dit         DRPW         Receive data resky lag, 1         Pleady 0         Dermy 0         Dit         The second data buffer empty flag, 1         Pleady 0         Note many 1         R           LIART Ch.0         (R4101)         (R4101)         Dr.0         TXD(7-0)         TXD(7-0)         MAT         CAU         Oxd to Oxf (0x77)         Oxd         R         R           Register         (R4101)         Dr.0         TXD(7-0)         RXD(7-0)         RXD(7-0)         RXD(7-0)         RXD(7-0)         RXD(7-0)         RXD(7-0)         RXD(7-0)         RXD(7-0)         S         R         Oxd to Oxf (0x77)         Oxd         R         Duffer ins ins fract.           Receive Cata         Dr0         RXD(7-0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               | [        |      |            | , , ,                               | <u> </u> |                                       |          |           |          |       |                        |
| UART Ch.0.         TODE         Transmit data source comply flag         1         1         R           UART Ch.0.         60:101         D-0         TXD[7:0]         TXD[7:0]         TXD[7:0]         TXD[7:0]         TXD[7:0]         Stable         Dx0 to Dxff (0x7f)         Dx0         Dx0         Dx0         Dx1         Dx0         Dx0         Dx1         Dx0         Dx0         Dx1         Dx0         Dx0         Dx1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |          | D2   | -          | Transmit busy flag                  | <u> </u> | Busy                                  |          | Idle      |          |       | Shift register status  |
| UART Ch.0         0.4010         D -0         TXD[7:0]         TXD[7:0]         TXD[7:0]         TXD[7:0]         D -0         D -0         D -0         RW           Register         (B bib)         D -0         RXD[7:0]         Rocewords         D -0         D -0         RVT         D -0         RVT         D -0         RVT         D -0         D -0         RVT         D -0         D -0         D -0         D -0         D -0         RVT         D -0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |          |      |            |                                     |          | ,                                     | <u> </u> |           | -        |       |                        |
| Transmit Data<br>Register<br>(UART_TX00)         (8) bits)         C         TXD ?         Receive data<br>buffer         0x0 to 0xf (0x7)         0x0 (0x7)         0x0 ?                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |          | D0   | TDBE       | Transmit data buffer empty flag     | 1        | Empty                                 | 0        | Not empty | 1        | R     |                        |
| Register<br>(UART T.X00         CM102         D7-0         RXD[7:0]<br>(P)         RxD(7:0]<br>(P)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | UART Ch.0     | 0x4101   | D7–0 | TXD[7:0]   | Transmit data                       |          | 0x0 to 0                              | xff      | (0x7f)    | 0x0      | R/W   |                        |
| UART Ch.0<br>Receive Data<br>Repeiver<br>(UART Kh.0<br>Receive Data<br>Repeiver<br>(UART Kh.00)         O v102<br>(B bits)         D-0<br>D         RXD[7:0]<br>RXD(76] = MSB<br>RXD(76] = MSB<br>RXD(76] = MSB         O v10 to Duff (0x.71)<br>(D f)         Dod<br>D         RXD<br>(20 = MSB<br>RXD(76] = MSB<br>RXD(76] = MSB           Mode Register<br>(UART Kh.00)         04:102<br>D2         D-0<br>PEEN         PRO(76) = MSB<br>RXD(76] = MSB         D * Dist<br>D         D * Dis         D * Dist<br>D         D * Dis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               | (8 bits) |      |            |                                     |          |                                       |          |           |          |       |                        |
| UART Ch.0.<br>Register<br>(UART, RXD0)         0.410         0.7-0         RXD[7:0]<br>RXD7(6) = MSB         0.00 to 0.4ff (0x7)         0.00         R<br>bit for the second<br>mode second sec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -             |          |      |            | TXD0 = LSB                          |          |                                       |          |           |          |       |                        |
| Beceive Date<br>Register<br>(UART PLOD)         (8 bits)         Image: Comparison of the second sec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |          |      | <br>       |                                     |          |                                       |          |           |          | _     |                        |
| Register<br>(UART P.XOD 0)         CMSB<br>(RXD7(6) = MSB<br>(RXD7(6) = MSB<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(6) = MSB<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(6) = MSB<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(7))<br>(RXD7(                                                                                                                                                                                                     |               |          | D7–0 | RXD[7:0]   |                                     |          | 0x0 to 0                              | xff      | (0x7f)    | 0x0      | R     | Older data in the      |
| UART Ch.0.<br>Mode Register<br>(UART Ch.0.<br>D3         PREN         PREN         PREN         I         Vith party         0         Note<br>PREN           103         PREN         Party orable         1         Vith party         0         Note<br>PREN         0         PREN           103         PREN         Party mode select         1         Oid         0         PRW           103         STPE         Stop bit select         1         Doid         0         PRW           103         STPE         Stop bit select         1         External         0         Ibit         0         RW           104         D1         STPE         Stop bit select         1         External         0         Disable         0         RW           104         D1         REIEN         Receive buffer full int.enable         1         Enable         0         Disable         0         RW           103         REIEN         Receive buffer full int.enable         1         Enable         0         Disable         0         RW           104         REXP         UART Ch.0.         RX         Vith reable         0         RW         Vith reable         0         Note         Note         N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               | (8 Dits) |      |            |                                     |          |                                       |          |           |          |       |                        |
| UART Ch.0.<br>(MART_MODO)         0.4103<br>(8 bits)         D7-5<br>(9 bits)         Image: model of the second o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |          |      |            |                                     |          |                                       |          |           |          |       | III'SL                 |
| Mode Register<br>(UART_MODO)         (6 bits)         D-4<br>Display         Character length<br>Display         1   8 bits<br>Display         0   7 bits         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | 0v4102   | D7 5 | 1          |                                     |          |                                       |          |           |          |       |                        |
| UART_NODO         03         PFEP         Party mode select         1         With party         0         No party         0         No party           0.1         STPB         Stop bit select         1         Odd         0         Even         0         PAW           0.0         SSCK         Input dock select         1         Ebits         0         Ibit         0         PAW           0.0         SSCK         Input dock select         1         Enable         0         Ibits         0         PAW           0.0         FREIR         Receive party init init enable         1         Enable         0         Disable         0         PAW           0.4         TIEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         RW           0.4         TIEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         RW         PAW           0.4         TIEN         Receive putfer full int. condition         1         2 bytes         0         1 byte         0         NoW         PCLK+1/12         PCLK+1/12         PCLK+1/12         PCLK+1/12         PCLK+1/12         PCLK+1/12 </td <td></td> <td>  </td> <td></td> <td></td> <td></td> <td>1</td> <td>-<br/>R hito</td> <td>-</td> <td>7 hito</td> <td></td> <td></td> <td>0 when being read.</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |          |      |            |                                     | 1        | -<br>R hito                           | -        | 7 hito    |          |       | 0 when being read.     |
| D2         PAID         Parity mode select         1         0 d         Even         0         PAV           D1         STPB         Stop bit select         1         2 bits         0         Even         0         RW           UART Ch.0         OSSCK         Input dook select         1         External         0         Internal         0         RW           UART Ch.0         DS         REIEN         Receive putfer full internale         1         Enable         0         Disable         0         RW           UART Ch.0         DS         RIEN         Receive putfer full int. condition         1         Enable         0         Disable         0         RW           D3         ZE         -         reserved         -         -         0         When bein           D4         REFIN         Receive putfer full int. condition         1         Enable         0         Disable         0         RW           D4         REV         Receive putfer full int. condition         1         Enable         0         Disable         0         RW           D4         DFCK         REV         Receive putfer full int. condition         1         Enable         0         RW<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -             | (0 010)  |      |            | -                                   |          |                                       |          |           |          |       |                        |
| Ori         STPB         Stop bit select         1         2 bits         0         1 bits         0         RWW           UART Ch.0<br>Control Register<br>(UART_CTLO)         04/104         D7         -         -         -         0         when bein<br>Control Register<br>(B bits)         05         REIE         Receive buffer full int. enable         1         Enable         0         Disable         0         RWV           D4         TEEN         Receive buffer full int. enable         1         Enable         0         Disable         0         RWV           D4         TEEN         Receive buffer full int. condition         1         Enable         0         Disable         0         RW           D3         RBFI         Receive buffer full int. condition         1         2         NW         0         RWW           UART Ch.0<br>Expansion<br>(G bits)         0X4105         D7         -         reserved         -         -         0         When bein<br>0X5         PCLK+1/16         V/X1/16         V/X         0         D/X         -         0         When bein<br>0X5         PCLK+1/16         V/X1/16         V/X         -         -         -         0         When bein<br>0X5         PCLK+1/16         V/X1/16         V/X1/16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               |          | -    |            |                                     | -        |                                       | -        |           | -        |       |                        |
| UART Ch.0<br>Control Register<br>(UART_CTLO)         Ox 4104         D7         -         reserved         -         -         0         Internal         0         R/W           UART Ch.0<br>Control Register<br>(UART_CTLO)         (8 bits)         D7         -         reserved         -         -         -         0         0         Nieth bein<br>Control Register           UART_CL0         (8 bits)         D6         RIEN         Receive buffer full int.condition         1         Enable         0         Disable         0         RW           D3-2         reserved         -         -         -         0         Mem bein<br>Control Register           UART Ch.0<br>(CRAT_EXPANSION         D7         -         reserved         -         -         -         0         Nehn bein<br>Control Register           UART Ch.1<br>(CRAT_EXPANSION         D6-4         IRCLK[2:0]         IrDA receive detection clock select         IRCLK[2:0]         Clock         0x0         RW         -         -         0         Nehn bein           UART Ch.1<br>(Stats Register<br>(UART_EST)         0x4120         D7         -         reserved         -         -         -         0         Nehn bein           D4         DE         FER         Framing error flag         1 </td <td></td> <td></td> <td></td> <td></td> <td></td> <td><u> </u></td> <td></td> <td></td> <td>-</td> <td>-</td> <td></td> <td>1</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |          |      |            |                                     | <u> </u> |                                       |          | -         | -        |       | 1                      |
| UART Ch.0<br>Control Register<br>((UART_CTLD)         0x4104<br>(6 bits)         D7<br>D6         -<br>reserved         -<br>rese                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |          |      |            | •                                   | <u> </u> |                                       |          |           | -        |       | 1                      |
| Control Register<br>(UART_CTL0)         (6 bits)         D6         REIEN         Receive buffer full int.enable         1         Enable         0         Disable         0         RW           D4         TIEN         Receive buffer full int.enable         1         Enable         0         Disable         0         RW           D3-2         -         reserved         -         -         -         0         Men bein           D3-2         -         reserved         1         Enable         0         1 byte         0         RW           D3         RBFI         Receive buffer full int.condition         1         2 bytes         0         1 byte         0         RW           VART Ch.0         0x4105         D6-4         IRCLK[2:0]         IrDA receive detection clock select         IRCLK[2:0]         PCLK+1/12         0x0         RW         RW           VIART_EXPO)         D3-1         -         reserved         -         -         -         0         when bein           D3-1         -         reserved         -         -         -         0         when bein           D4         D6         FER         Framing error flag         1         Error         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               | 0        | -    | 0000       |                                     |          | LAIGHIAI                              | 10       | micridi   |          | 11/11 | 0                      |
| UUART_CTL0)         D5         IEIN         Receive buffer full int_enable         1         Enable         0         Disable         0         RW           D4         TTEN         Transmit buffer empty int_enable         1         Enable         0         Disable         0         RW           D3-2         -         reserved         0         1         2 bytes         0         1 bytes         0         RW           DART Ch.0         RXEN         UART chable         1         Enable         0         Disable         0         RW           Register         (8 bits)         D6-4         IRCLK[2:0]         IrCLK[2:0]         Clock         0x0         RW           UART Ch.1         Roserved         -         -         -         -         -         0         when bein           UART Ch.1         Roserved         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         - <td< td=""><td></td><td></td><td></td><td>-</td><td></td><td>-</td><td>-<br/>Enchl-</td><td>-</td><td>Diaght</td><td>_</td><td>-</td><td>0 when being read.</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |          |      | -          |                                     | -        | -<br>Enchl-                           | -        | Diaght    | _        | -     | 0 when being read.     |
| D4         TEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         RW           D3-2         -         reserved         -         -         -         -         0         0 when bein           D1         RSF1         Receive buffer full int. condition         1         2 bytes         0         1 byte         0         RW           D4         TRSP         LUART Ch.0         0         RW         -         -         -         0         0 when bein           Register         (0 & bits)         D7         -         reserved         -         -         -         0         0 when bein           Register         (0 ART         D6-4         IRCLK[2:0]         FCLK-1/4         OX         PCLK-1/16         OX         PCLK-1/16<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | -             | (8 DITS) | -    |            |                                     |          |                                       |          |           | -        |       |                        |
| UART Ch.1<br>reserved         D3-2<br>D1         -<br>RBFi<br>Receive buffer full int. condition         1         2 bytes         -<br>D         -<br>L         -<br>D         D         -<br>D         -<br>D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |          |      |            |                                     | -        |                                       |          |           | -        |       |                        |
| UART Ch.0<br>Expansion<br>Register<br>(UART_EXPO)         Ox4105<br>(0 bits)         DF<br>Fermionic<br>PC-4<br>(0 bits)         BFIF<br>(0 bits)         Receive buffer full int. condition<br>(0 bits)         1 b byte<br>(0 bits)         0<br>(0 bits)         N/W           (0 bits)         D-4<br>(0 bits)         D-4<br>(0 bits)         IRCLK[2:0]<br>(0 bits)         ICD-4<br>(0 bits)         IRCLK[2:0]<br>(0 bits)         ICD-6<br>(0 bits)         IRCLK[2:0]<br>(0 bits)         ICD-7<br>(0 bits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |          |      |            | · · ·                               | 1        | i⊏na0ie                               | 0        | UISADIe   | -        |       |                        |
| UART Ch.0<br>Expansion         Do         RXEN         UART enable         1         Enable         0         Disable         0         RW           VART Ch.0<br>Expansion         (6 bits)         D6-4         IRCLK[2:0]         IrDA receive detection clock select         IRCLK[2:0]         Clock         0x4 no bein           Register<br>(UART_EXPO)         0         bits         D6-4         IRCLK[2:0]         IrDA receive detection clock select         IRCLK[2:0]         Clock         0x4         PCLK+1/128         0x4         PCLK+1/128         0x4         PCLK+1/164         PCLK+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |          | -    |            |                                     |          | -                                     | -        | 4 1       | -        |       | 0 when being read.     |
| UART Ch.0<br>Expansion<br>Register<br>(UART_EXPO)         0x4105<br>(6 bits)         D7<br>D6-4         ireserved<br>ireserved         -         -         -         -         0 when bein<br>over<br>the bein<br>the bein<br>the bein<br>over<br>the bein<br>over<br>the bein<br>the bein<br>the bein<br>over<br>the bein<br>the bei |               |          |      |            |                                     | -        |                                       |          |           | -        |       |                        |
| Expansion<br>Register<br>(UART_EXPO)         (8 bits)         D6-4         IRCLK[2:0]         IrDA receive detection clock select<br>0 x7         IRCLK[2:0]         Clock<br>0 x7         0 x0         R/W           Register<br>(UART_EXPO)         0.6         IRCLK[2:0]         Clock<br>0 x7         0 x0         R/W         0.4         R/W         0.4         R/W         0.4         R/W         0.4         R/W         0.4         PCLK+1/12         D.4         PCLK+1/12         PCLK+1/12         D.4         PCLK+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |          | -    |            |                                     |          | Enable                                | 0        | Disable   | <u> </u> | n/ w  |                        |
| Register<br>(UART_EXPO)         0x12<br>b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |          |      | -          |                                     |          | -                                     | -        |           |          | -     | 0 when being read.     |
| (UÅRT_EXPO)         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k         k <th< td=""><td></td><td>(8 Dits)</td><td>D6–4</td><td>IRCLK[2:0]</td><td>IrDA receive detection clock select</td><td></td><td></td><td>-</td><td></td><td>0x0</td><td>R/W</td><td></td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               | (8 Dits) | D6–4 | IRCLK[2:0] | IrDA receive detection clock select |          |                                       | -        |           | 0x0      | R/W   |                        |
| UART Ch.1<br>Register<br>(UART_KD.1)         0x4121<br>(B bits)<br>Boil         D7-0<br>(B bits)<br>D7-5         TXD[7:0]<br>PCL         Transmit data<br>buffer<br>RCD         0         Off         0         R           UART Ch.1<br>Status Register<br>(UART_ST)         0x4120<br>(B bits)         D7         -         reserved         -         -         -         0         when bein<br>0           UART Ch.1<br>Status Register<br>(UART_ST)         0x4120<br>(B bits)         D7         -         reserved         -         -         -         0         when bein<br>0         0         RW         Reset by wr           UART Ch.1<br>Status Register<br>(UART_ST)         0x4120<br>D6         FER         Paring error flag         1         Error         0         Normal         0         RW         Reset by wr           D3         RD2B         Second byte receive flag         1         Ready         0         Empty         0         R           D4         OER         Overrun error flag         1         Busy         0         Empty         0         R           D4         D8         Transmit data buffer enpty flag         1         Ready         0         Empty         0         R         -         -         0         when bein<br>first.           UART Ch.1<br>Register<br>(UART_TXD1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -             |          |      |            |                                     |          |                                       |          |           |          |       |                        |
| VART Ch.1<br>Status Register<br>(UART_ST)         Ox12<br>(B bits)         OX12<br>D7         -<br>reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | (UARI_EAFU)   |          |      |            |                                     |          |                                       |          |           |          |       |                        |
| VART Ch.1<br>Status Register<br>(UART_ST)1         0x121<br>PCL         PCL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |          |      |            |                                     |          |                                       |          |           |          |       |                        |
| UART Ch.1<br>Register<br>(UART_ST1)         0x112<br>PCL         PCL         PCL        <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |          |      |            |                                     |          |                                       |          |           |          |       |                        |
| Image: book with the section of the sectin of the section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |          |      |            |                                     |          |                                       |          |           |          |       |                        |
| D3-1         -         reserved         -         -         -         -         0         0 when bein           D0         IRMD         IrDA mode select         1         On         0         Off         0         RW           UART Ch.1         (8 bits)         D6         FER         Framing error flag         1         Error         0         Normal         0         RW         Reset by wr           (UART_ST1)         0         RV         PER         Parity error flag         1         Error         0         Normal         0         RW         Reset by wr           D3         RD28         Second byte receive flag         1         Ready         0         Empty         0         R           D2         TRBS         Transmit busy flag         1         Budy         0         Idle         0         R         Shift registe           D1         RDRY         Receive data ready flag         1         Ready         0         Empty         0         R           UART Ch.1         0x4121         D7-0         TXD[7:0]         Transmit data         D/A         O/A to 0x/f (0x7f)         Ox0         R         O/A         R/W         Receive data         D/A <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td>0x1</td> <td></td> <td>PCLK•1/2</td> <td></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |          |      |            |                                     |          | 0x1                                   |          | PCLK•1/2  |          |       |                        |
| D0         IRMD         IrDA mode select         1         On         0         Off         0         RW           UART Ch.1<br>Status Register<br>(UART_ST1)         0x4120         D7         -         reserved         -         -         -         0         when bein<br>Normal         0         R/W         Reset by wr           UART Ch.1<br>Status Register<br>(UART_ST1)         (8 bits)         D6         FER         Framing error flag         1         Error         0         Normal         0         R/W           D3         RD2B         Second byte receive flag         1         Ready         0         Empty         0         R           D2         TRBS         Transmit busy flag         1         Busy         0         Idle         0         R         Shift registe           D0         TDBE         Transmit data buffer empty flag         1         Empty         0         Not empty         1         R           Register<br>(UART_TXD1)         (8 bits)         D7-0         TXD[7:0]         Transmit data         0x0 to 0xff (0x7f)         0x0         R/W         Mode register           (UART_CA.1         Receive Data         Normal         D7-5         reserved         -         -         -         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |          |      |            |                                     |          | 0x0                                   |          | PCLK•1/1  |          |       |                        |
| UART Ch.1<br>Status Register<br>(UART_ST1)         Ox4120<br>(8 bits)         D7<br>D6<br>DF FR<br>PER         reserved<br>Framing error flag         1         Error         0         Normal         0         R/W<br>Reset by wr           UART_ST1)         D6<br>PER         FER         Framing error flag         1         Error         0         Normal         0         R/W<br>Reset by wr           D5<br>PER         PER         Parity error flag         1         Error         0         Normal         0         R/W<br>Pr           D4         OER         Overrun error flag         1         Error         0         Normal         0         R/W           D3         RD2B         Second byte receive flag         1         Ready         0         Empty         0         R           D1         RDRY         Receive data ready flag         1         Beady         0         Empty         0         R           UART Ch.1<br>register         0x4121         D7-0         TXD[7:0]         Transmit data         TXD7(6) = MSB         0x0 to 0xff (0x7f)         0x0         R         Older data is<br>buffer           Register         (UART_RXD1)         0x4122         D7-5         -         reserved         -         -         -         0         when bein                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |          | D3–1 | -          | reserved                            |          | -                                     | -        |           | -        | -     | 0 when being read.     |
| Status Register<br>(UART_ST1)         (8 bits)         D6         FER         Framing error flag         1         Error         0         Normal         0         R/W           D5         PER         Parity error flag         1         Error         0         Normal         0         R/W           D4         OER         Overrun error flag         1         Error         0         Normal         0         R/W           D3         R02B         Second byte receive flag         1         Ready         0         Empty         0         R           D2         TRBS         Transmit busy flag         1         Busy         0         Idle         0         R         Shift registe           D4         RCH1         To7-0         TXD(7:0)         Transmit data         1         Eedy         0         Not empty         1         R           UART Ch.1         Receive Data         0x4121         D7-0         TXD(7:0)         Transmit data         0x0 to 0xff (0x7f)         0x0         R         N/Her error error           UART Ch.1         Receive Data         0x4122         D7-5         -         reserved         -         -         -         0         when bein                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |          | D0   | IRMD       | IrDA mode select                    | 1        | On                                    | 0        | Off       | 0        | R/W   |                        |
| UART_ST1)         D5         PER         Parity error flag         1         Error         0         Normal         0         R/W           D4         OER         Overrun error flag         1         Error         0         Normal         0         R/W           D3         RD2B         Second byte receive flag         1         Redy         0         Empty         0         R           D2         TRBS         Transmit busy flag         1         Beady         0         Idel         0         R         Shift registe           D0         TDBE         Transmit data         buffer empty flag         1         Empty         0         Not empty         1         R           UART Ch.1         (8 bits)         Rx4121         D7-0         TXD[7:0]         Transmit data         0x0 to 0xff (0x7f)         0x0         R/W           UART Ch.1         (8 bits)         RxD[7:0]         Receive data in the receive data         0x0 to 0xff (0x7f)         0x0         R/W         0/def data in buffer motion for the mathemathemathemathemathemathemathemathe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | UART Ch.1     | 0x4120   | D7   | -          | reserved                            |          | -                                     | -        |           | -        | -     | 0 when being read.     |
| D4         DE         DER         Overrun error flag         1         Error         0         Normal         0         R/W           D3         RD2B         Second byte receive flag         1         Ready         0         Empty         0         R           D2         TRBS         Transmit busy flag         1         Busy         0         Idle         0         R           D1         RDRY         Receive data ready flag         1         Ready         0         Empty         0         R           D0         TDBE         Transmit data buffer empty flag         1         Empty         0         Not empty         1         R           UART Ch.1         (8 bits)         D7-0         TXD[7:0]         Transmit data         TXD7(6) = MSB         DX0 to 0xff (0x7f)         0x0         R         Older data in buffer           Receive Data         (8 bits)         D7-5         RXD[7:0]         Receive data in the receive data         0x0 to 0xff (0x7f)         0x0         R         Older data in buffer           Register         (UART_RXD1)         D7-5         -         reserved         -         -         0         when bein           (UART_MOD1)         0x4123         D7-5         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -             | (8 bits) | D6   | FER        | Framing error flag                  | 1        | Error                                 | 0        | Normal    | 0        | R/W   | Reset by writing 1.    |
| D3         RD2B         Second byte receive flag         1         Ready         0         Empty         0         R           D2         TRBS         Transmit busy flag         1         Busy         0         Idle         0         R           D1         RDRY         Receive data ready flag         1         Busy         0         Idle         0         R           D0         TDBE         Transmit data buffer empty flag         1         Empty         0         Not empty         1         R           UART Ch.1         0x4121         D7-0         TXD[7:0]         Transmit data         TXD7(6) = MSB         0x0 to 0xff (0x7f)         0x0         R/W           UART Ch.1         0x4122         D7-0         RXD[7:0]         Receive data in the receive data         0x0 to 0xff (0x7f)         0x0         R         Older data in buffer           Register         (B bits)         D7-5         RXD[7:0]         Receive data in the receive data         0x0 to 0xff (0x7f)         0x0         R         Older data in buffer is readifier.           Register         (UART Ch.1         0x4123         D7-5         r         reserved         -         -         0         0 when bein           Mode Register         (UART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | (UART_ST1)    |          | D5   | PER        | Parity error flag                   | 1        | Error                                 | 0        | Normal    | 0        | R/W   |                        |
| D2         TRBS         Transmit busy flag         1         Busy         0         Idle         0         R         Shift registe           D1         RDRY         Receive data ready flag         1         Ready         0         Empty         0         R         Shift registe           D0         TDBE         Transmit data buffer empty flag         1         Empty         0         Not empty         1         R           Transmit Data<br>Register<br>(UART_TXD1)         0x4121         D7-0         TXD[7:0]         Transmit data         0x0 to 0xff (0x7f)         0x0         R/W           UART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)         0x4122         D7-0         RXD[7:0]         Receive data in the receive data<br>buffer         0x0 to 0xff (0x7f)         0x0         R         N/W           UART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)         0x4122         D7-0         RXD[7:0]         Receive data in the receive data<br>buffer         0x0 to 0xff (0x7f)         0x0         R         N/W           UART Ch.1<br>Mode Register<br>(UART_MOD1)         0x4123         D7-5         -         reserved         -         -         -         0 when bein           UART Ch.1<br>Mode Register<br>(UART_MOD1)         0x4123         D7-5         -         reserved         1         1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |          | D4   | OER        | Overrun error flag                  | 1        | Error                                 | 0        | Normal    | 0        | R/W   |                        |
| D1         RDRY         Receive data ready flag         1         Ready         0         Empty         0         R           D0         TDBE         Transmit data buffer empty flag         1         Empty         0         Not empty         1         R           UART Ch.1<br>Transmit Data<br>Register<br>(UART_TXD1)         0x4121<br>(8 bits)         D7–0         TXD[7:0]         Transmit data<br>TXD7(6) = MSB<br>TXD0 = LSB         0x0 to 0xff (0x7f)         0x0         R         N/W           UART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)         0x4122<br>(8 bits)         D7–0         RXD[7:0]         Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD7(6) = MSB<br>RXD0 = LSB         0x0 to 0xff (0x7f)         0x0         R         Older data in<br>buffer is read<br>first.           UART Ch.1<br>Mode Register<br>(UART_RXD1)         0x4123         D7–5         –         reserved         –         –         –         0 when bein           Mode Register<br>(UART_MOD1)         0x4123         D7–5         –         reserved         –         –         –         0 when bein           D2         PMD         Parity enable         1         8 bits         0         7 bits         0         R/W           D2         PMD         Parity mode select         1         0 binthereinal         0         R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |               |          | D3   |            | Second byte receive flag            | 1        | Ready                                 | 0        | Empty     | 0        | R     |                        |
| D0         TDBE         Transmit data buffer empty flag         1         Empty         0         Not empty         1         R           UART Ch.1<br>Transmit Data<br>Register<br>(UART_TXD1)         Ox4121<br>(8 bits)         D7–0         TXD[7:0]         Transmit data<br>TXD7(6) = MSB<br>TXD0 = LSB         Ox0 to 0xff (0x7f)         0x0         R/W           UART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)         0x4122<br>(8 bits)         D7–0         RXD[7:0]         Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD7(6) = MSB<br>RXD7(6) = MSB         0x0 to 0xff (0x7f)         0x0         R         Older data in<br>buffer is real<br>first.           WART Ch.1<br>Mode Register<br>(UART_MOD1)         0x4122<br>0         D7–0         RXD[7:0]         Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD7(6) = MSB         0x0 to 0xff (0x7f)         0x0         R         Older data in<br>buffer is real<br>first.           WART Ch.1<br>Mode Register<br>(UART_MOD1)         0x4123<br>D4         D7–5         -         reserved         -         -         -         0 when bein           D2         PMD         Parity mode select         1         With parity         0         No parity         0         R/W           D2         PMD         Parity mode select         1         D/dd         0         Internal         0         R/W           UART Ch.1<br>Control Register<br>(UART_CTL1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |          | D2   | TRBS       | Transmit busy flag                  | _        | Busy                                  |          |           |          |       | Shift register status  |
| UART Ch.1<br>Transmit Data<br>Register<br>(UART_TXD1)       0x4121<br>(8 bits)       D7-0<br>(8 bits)       TXD[7:0]       Transmit data<br>TXD7(6) = MSB<br>TXD0 = LSB       0x0 to 0xff (0x7f)       0x0       R/W         UART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)       0x4122<br>(8 bits)       D7-0<br>(8 bits)       RXD[7:0]       Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD7(6) = MSB<br>RXD7(6) = MSB<br>RXD0 = LSB       0x0 to 0xff (0x7f)       0x0       R       Older data in<br>buffer is read<br>first.         UART Ch.1<br>Mode Register<br>(UART_MOD1)       0x4123<br>D7-5       D7-0       RXD[7:0]       Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD0 = LSB       0x0 to 0xff (0x7f)       0x0       R       Older data in<br>buffer is read<br>first.         UART Ch.1<br>Mode Register<br>(UART_MOD1)       0x4123<br>D7-5       D7-5       -       reserved       -       -       -       0 when bein         D2       PMD       Parity mode select       1       8 bits       0 7 bits       0 R/W         D2       PMD       Parity mode select       1       2 bits       0 1 bit       0 R/W         UART Ch.1<br>(UART_CL1)       0x4124<br>D7       D7       -       reserved       -       -       0 when bein         D4       TIEN       Transmit buffer empty int. enable       1       Enable       0       0 sable       0 R/W         UART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |          |      |            |                                     |          |                                       |          |           | -        |       |                        |
| Transmit Data<br>Register<br>(UART_TXD1)       (8 bits)       D7–0       RXD[7:0]       Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD7(6) = MSB<br>RXD7(6) = MSB<br>RXD7(6) = MSB       Ox0 to 0xff (0x7f)       0x0       R       Older data in<br>buffer is real<br>first.         WART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)       0x4122       D7–0       RXD[7:0]       Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD7(6) = MSB       0x0 to 0xff (0x7f)       0x0       R       Older data in<br>buffer is real<br>first.         UART Ch.1<br>Mode Register<br>(UART_MOD1)       0x4123       D7–5       –       reserved       –       –       0 when bein         D4       CHLN       Character length       1       8 bits       0 7 bits       0       R/W         D3       PREN       Parity mode select       1       Vith parity       0 No parity       0       R/W         D2       PMD       Parity mode select       1       2 bits       0       1 bit       0       R/W         UART Ch.1       0x4124       D7       –       reserved       –       –       0 when bein         D4       EHLN       Receive buffer full int. enable       1       External       0       Internal       0       R/W         UART Ch.1       0x4124       D7       –       reser                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |          | D0   | TDBE       | Transmit data buffer empty flag     | 1        | Empty                                 | 0        | Not empty | 1        |       |                        |
| Register<br>(UART_TXD1)       Ox4122<br>(8 bits)       D7-0<br>(8 bits)       RXD[7:0]<br>D7-0       Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD0 = LSB       Ox0 to 0xff (0x7f)       Ox0<br>DX       R<br>DX       Older data in<br>buffer is real<br>first.         UART Ch.1<br>Register<br>(UART_RXD1)       0x4122<br>(8 bits)       D7-5       -       reserved       -       -       0 when bein<br>first.         UART Ch.1<br>Mode Register<br>(UART_MOD1)       0x4123<br>(8 bits)       D7-5       -       reserved       -       -       0 when bein<br>first.         UART Ch.1<br>Mode Register<br>(UART_MOD1)       0x4123<br>(8 bits)       D7-5       -       reserved       1       8 bits       0       7 bits       0       R/W<br>0         D3       PREN       Parity enable       1       With parity       0 No parity       0       R/W<br>0       R/W         D1       STPB       Stop bit select       1       2 bits       0       1 bit       0       R/W         UART Ch.1<br>(UART_CTL1)       0x4124<br>(B bits)       D7       -       reserved       -       -       0 when bein         D4       EHEN       Receive buffer full int. enable       1       Enable       0       Internal       0       R/W         UART Ch.1<br>(UART_CTL1)       0x4124<br>(B bits)       D7       - </td <td>UART Ch.1</td> <td>0x4121</td> <td>D7–0</td> <td>TXD[7:0]</td> <td>Transmit data</td> <td></td> <td>0x0 to 0</td> <td>xff</td> <td>(0x7f)</td> <td>0x0</td> <td>R/W</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | UART Ch.1     | 0x4121   | D7–0 | TXD[7:0]   | Transmit data                       |          | 0x0 to 0                              | xff      | (0x7f)    | 0x0      | R/W   |                        |
| (UART_TXD1)       Image: Control Register (UART_RXD1)       Ox4122 (8 bits)       D7-0 (Mathematical stress of the stress of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               | (8 bits) |      |            |                                     |          |                                       |          |           |          |       |                        |
| UART Ch.1<br>Receive Data<br>Register<br>(UART_RXD1)       0x4122<br>(8 bits)       D7-0<br>(8 bits)       RXD[7:0]<br>PR       Receive data in the receive data<br>buffer<br>RXD7(6) = MSB<br>RXD0 = LSB       0x0 to 0xff (0x7f)       0x0       R       Older data in<br>buffer is real<br>first.         UART Ch.1<br>(UART_MOD1)       0x4123<br>(8 bits)       D7-5       -       reserved       -       -       -       0 when bein         Mode Register<br>(UART_MOD1)       0x4123<br>(8 bits)       D7-5       -       reserved       -       -       -       0 when bein         D3       PREN       Parity enable       1       With parity       0       No parity       0       R/W         D2       PMD       Parity enable       1       Vith parity       0       No parity       0       R/W         D1       STPB       Stop bit select       1       D litt       0       R/W         UART Ch.1       0x4124       D7       -       reserved       -       -       -       0 when bein         (UART_CTL1)       0x4124       D7       -       reserved       -       -       -       0 when bein         UART Ch.1       0x4124       D7       -       reserved       -       -       -       0 when bein         (UAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |          |      |            | TXD0 = LSB                          |          |                                       |          |           |          |       |                        |
| Receive Data<br>Register<br>(UART_RXD1)         (8 bits)         0         Image: buffer<br>RXD7(6) = MSB<br>RXD0 = LSB         Image: buffer<br>RXD0 = LSB         Image: buffer is real<br>first.         buffer is real<br>first.           UART Ch.1<br>Mode Register<br>(UART_MOD1)         0x4123<br>(8 bits)         D7-5         -         reserved         -         -         -         0         0 when bein<br>first.           D4         CHLN         Character length         1         8 bits         0         7 bits         0         R/W           D3         PREN         Parity enable         1         With parity         0         No parity         0         R/W           D2         PMD         Parity mode select         1         Odd         0         Even         0         R/W           D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1<br>Control Register<br>(UART_CTL1)         0         REIEN         Receive error int. enable         1         Enable         0         Disable         0         R/W           D5         RIEN         Receive buffer full int. enable         1         Enable         0         Disable         0         R/W           D4         TIEN </td <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td><u> </u></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |          |      |            |                                     |          |                                       |          |           | <u> </u> |       |                        |
| Register<br>(UART_RXD1)         Oxf123<br>D         D7-5<br>D         -         reserved<br>reserved         -         -         0         when bein<br>first.           Mode Register<br>(UART_MOD1)         (8 bits)         D7-5<br>D4         -         reserved         -         -         0         when bein<br>when bein<br>D3           D2         PMD         Parity mode select         1         With parity         0         No parity         0         R/W           D2         PMD         Parity mode select         1         Odd         0         Even         0         R/W           D1         STPB         Stop bit select         1         2 bits         0         1 bit         0         R/W           D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1<br>Control Register<br>(UART_CTL1)         0         R         P         -         reserved         -         -         0         when bein           Control Register<br>(UART_CTL1)         0         R         REIEN         Receive buffer full int. enable         1         Enable         0         Disable         0         R/W           D5         RIEN         Receive buffer ful                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |          | D7–0 | RXD[7:0]   |                                     |          | 0x0 to 0                              | xff      | (0x7f)    | 0x0      | R     | Older data in the      |
| ULART_RXD1)         Node         RXD0 = LSB         Image: Constraint of the second s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               | (8 bits) |      |            |                                     |          |                                       |          |           |          |       | buffer is read out     |
| UART Ch.1<br>Mode Register<br>(UART_MOD1)         0x4123<br>(8 bits)         D7-5<br>D4         -         reserved         -         -         0         when bein           UART _MOD1)         0         CHLN         Character length         1         8 bits         0         7 bits         0         R/W           D3         PREN         Parity enable         1         With parity         0         No parity         0         R/W           D2         PMD         Parity mode select         1         Odd         0         Even         0         R/W           D1         STPB         Stop bit select         1         2 bits         0         1 bit         0         R/W           D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1         CM124         D7         -         reserved         -         -         -         0         When bein           UART_CTL1)         Bitsis         0         REIEN         Receive error int. enable         1         Enable         0         Disable         0         R/W           UART_CTL1)         D5         RIEN         Receive buffer full int. enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |          |      |            |                                     |          |                                       |          |           |          |       | first.                 |
| Mode Register<br>(UART_MOD1)         (8 bits)         D4         CHLN         Character length         1         8 bits         0         7 bits         0         R/W           D3         PREN         Parity enable         1         With parity         0         No parity         0         R/W           D2         PMD         Parity mode select         1         Odd         0         Even         0         R/W           D1         STPB         Stop bit select         1         2 bits         0         1 bit         0         R/W           D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1         CM4124         D7         -         reserved         -         -         -         0         0 when bein           Control Register<br>(UART_CTL1)         06         REIEN         Receive error int. enable         1         Enable         0         Disable         0         R/W           D5         RIEN         Receive buffer full int. enable         1         Enable         0         Disable         0         R/W           D3-2         -         reserved         -         - </td <td></td> <td>04100</td> <td>D7 7</td> <td>1</td> <td></td> <td></td> <td>· · · · · · · · · · · · · · · · · · ·</td> <td></td> <td></td> <td></td> <td>l</td> <td>l<br/>O where h i i i i</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               | 04100    | D7 7 | 1          |                                     |          | · · · · · · · · · · · · · · · · · · · |          |           |          | l     | l<br>O where h i i i i |
| D3         PREN         Parity enable         1         With parity         0         No parity         0         R/W           D2         PMD         Parity mode select         1         Odd         0         Even         0         R/W           D1         STPB         Stop bit select         1         2 bits         0         1 bit         0         R/W           D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1         Control Register         (8 bits)         D6         REIEN         Receive error int. enable         1         Enable         0         Disable         0         R/W           UART_CTL1)         D5         RIEN         Receive buffer full int. enable         1         Enable         0         Disable         0         R/W           UART_CTL1         D4         TIEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         R/W           D4         TIEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         R/W           D3-2         -         rese                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               | , j      |      | -          |                                     |          | -                                     | -        | 7 6 4 .   | -        | -     | 0 when being read.     |
| D2         PMD         Parity mode select         1         Odd         0         Even         0         R/W           D1         STPB         Stop bit select         1         2 bits         0         1 bit         0         R/W           D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1         0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART_Ch.1         0         At124         D7         -         reserved         -         -         0         when bein           Control Register         (8 bits)         D6         REIEN         Receive error int. enable         1         Enable         0         Disable         0         R/W           UART_CTL1)         D5         RIEN         Receive buffer full int. enable         1         Enable         0         Disable         0         R/W           D4         TIEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         R/W           D3_2 -         reserved         -         - <td>-</td> <td>(8 Dits)</td> <td></td> <td></td> <td>*</td> <td></td> <td></td> <td>-</td> <td></td> <td>-</td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -             | (8 Dits) |      |            | *                                   |          |                                       | -        |           | -        |       |                        |
| D1     STPB     Stop bit select     1     2 bits     0     1 bit     0     R/W       D0     SSCK     Input clock select     1     External     0     Internal     0     R/W       UART Ch.1<br>Control Register<br>(UART_CTL1)     Ox4124     D7     -     reserved     -     -     0 when bein       D6     REIEN     Receive error int. enable     1     Enable     0     Disable     0     R/W       D5     RIEN     Receive buffer full int. enable     1     Enable     0     Disable     0     R/W       D4     TIEN     Transmit buffer empty int. enable     1     Enable     0     Disable     0     R/W       D3-2     -     reserved     -     -     0     when bein       D1     RBFI     Receive buffer full int. condition     1     2 bytes     0     1 byte     0     R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |          |      |            | ,                                   |          |                                       | -        |           | _        |       |                        |
| D0         SSCK         Input clock select         1         External         0         Internal         0         R/W           UART Ch.1<br>Control Register<br>(UART_CTL1)         0x4124         D7         -         reserved         -         -         0 when bein           D6         REIEN         Receive error int. enable         1         Enable         0         Disable         0         R/W           D5         RIEN         Receive buffer full int. enable         1         Enable         0         Disable         0         R/W           D4         TIEN         Transmit buffer empty int. enable         1         Enable         0         Disable         0         R/W           D3-2         -         reserved         -         -         0         when bein           D1         RBFI         Receive buffer full int. condition         1         2 bytes         0         1 byte         0         R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |          |      |            |                                     |          |                                       |          |           | _        |       |                        |
| UART Ch.1<br>Control Register<br>(UART_CTL1)       0x4124       D7       -       reserved       -       -       0 when bein         0b       REIEN       Receive error int. enable       1       Enable       0       Disable       0       R/W         0b       RIEN       Receive buffer full int. enable       1       Enable       0       Disable       0       R/W         0b       TIEN       Transmit buffer empty int. enable       1       Enable       0       Disable       0       R/W         03-2       -       reserved       -       -       0       when bein         01       RBFI       Receive buffer full int. condition       1       2 bytes       0       1 byte       0       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |          |      |            | · ·                                 | -        |                                       | _        |           |          |       | 4                      |
| D6       REIEN       Receive error int. enable       1       Enable       0       Disable       0       R/W         (UART_CTL1)       D5       RIEN       Receive buffer full int. enable       1       Enable       0       Disable       0       R/W         D4       TIEN       Transmit buffer empty int. enable       1       Enable       0       Disable       0       R/W         D3-2       -       reserved       -       -       0       When bein         D1       RBFI       Receive buffer full int. condition       1       2 bytes       0       1 byte       0       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |          |      | 330K       |                                     | 1        | ⊏xternal                              | υ        | Internal  | -        | H/W   |                        |
| (UART_CTL1)       D5       RIEN       Receive buffer full int. enable       1       Enable       0       Disable       0       R/W         D4       TIEN       Transmit buffer empty int. enable       1       Enable       0       Disable       0       R/W         D3-2       -       reserved       -       -       0       0 when bein         D1       RBFI       Receive buffer full int. condition       1       2 bytes       0       1 byte       0       R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |          |      | -          |                                     |          | -                                     | -        | 1         |          | -     | 0 when being read.     |
| D4     TIEN     Transmit buffer empty int. enable     1     Enable     0     Disable     0     R/W       D3-2     -     reserved     -     -     -     0 when bein       D1     RBFI     Receive buffer full int. condition     1     2 bytes     0     1 byte     0     R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | •             | (8 bits) |      |            |                                     |          |                                       | _        |           |          |       |                        |
| D3-2         -         reserved         -         -         0         0 when bein           D1         RBFI         Receive buffer full int. condition         1         2 bytes         0         1 byte         0         R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | (UART_CTL1)   | ļ        |      |            |                                     | _        |                                       | _        |           | -        |       |                        |
| D1 RBFI Receive buffer full int. condition 1 2 bytes 0 1 byte 0 R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               | ļ        |      | TIEN       |                                     | 1        | Enable                                | 0        | Disable   |          | R/W   |                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               | ļ        |      | -          |                                     |          | -                                     | -        |           |          | -     | 0 when being read.     |
| I DO IRXEN JUART enable I I IEnable I O IDisable I O I R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |          |      |            |                                     |          |                                       |          |           |          |       |                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |          | D0   | RXEN       | UART enable                         | 1        | Enable                                | 0        | Disable   | 0        | R/W   |                        |

## UART (with IrDA)

| Register name | Address  | Bit  | Name       | Function                            | Setting |           |            | Init. | R/W | Remarks            |
|---------------|----------|------|------------|-------------------------------------|---------|-----------|------------|-------|-----|--------------------|
| UART Ch.1     | 0x4125   | D7   | -          | reserved                            |         | -         | -          | -     | -   | 0 when being read. |
| Expansion     | (8 bits) | D6–4 | IRCLK[2:0] | IrDA receive detection clock select | IF      | RCLK[2:0] | Clock      | 0x0   | R/W |                    |
| Register      |          |      |            |                                     |         | 0x7       | PCLK-1/128 |       |     |                    |
| (UART_EXP1)   |          |      |            |                                     |         | 0x6       | PCLK-1/64  |       |     |                    |
|               |          |      |            |                                     |         | 0x5       | PCLK-1/32  |       |     |                    |
|               |          |      |            |                                     |         | 0x4       | PCLK-1/16  |       |     |                    |
|               |          |      |            |                                     |         | 0x3       | PCLK-1/8   |       |     |                    |
|               |          |      |            |                                     |         | 0x2       | PCLK-1/4   |       |     |                    |
|               |          |      |            |                                     |         | 0x1       | PCLK-1/2   |       |     |                    |
|               |          |      |            |                                     |         | 0x0       | PCLK-1/1   |       |     |                    |
|               |          | D3–1 | -          | reserved                            |         | -         | -          | -     | -   | 0 when being read. |
|               |          | D0   | IRMD       | IrDA mode select                    | 1 (     | On        | 0 Off      | 0     | R/W |                    |

0x4125

## 0x4200-0x4208

## 8-bit Timer (with Fine Mode) Ch.0

| Register name    | Address   | Bit    | Name      | Function                       |   | Se         | ettin | g                      | Init. | R/W | Remarks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|-----------|--------|-----------|--------------------------------|---|------------|-------|------------------------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8-bit Timer Ch.0 | 0x4200    | D15–4  | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Input Clock      | (16 bits) | D3–0   | DF[3:0]   | 8-bit timer input clock select |   | DF[3:0]    |       | Clock                  | 0x0   | R/W | , in the second se |
| Select Register  |           |        |           | (Prescaler output clock)       |   | 0xf        |       | reserved               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (T8F_CLK0)       |           |        |           |                                |   | 0xe        | PC    | LK-1/16384             |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0xd        |       | CLK-1/8192             |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0xc        |       | CLK-1/4096             |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0xb        |       | CLK-1/2048             |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0xa        |       | CLK-1/1024             |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x9<br>0x8 |       | CLK-1/512              |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x8<br>0x7 |       | CLK-1/256<br>CLK-1/128 |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x7<br>0x6 |       | CLK-1/128<br>CLK-1/64  |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x6<br>0x5 |       | CLK-1/04<br>CLK-1/32   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x3<br>0x4 |       | CLK-1/16               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x3        |       | PCLK-1/8               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x2        |       | PCLK-1/4               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x1        | 1     | PCLK-1/2               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | 0x0        | 1     | PCLK-1/1               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8-bit Timer Ch.0 | 0x4202    | D15-8  | _         | reserved                       | Τ |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reload Data      | (16 bits) | D7–0   | TR[7:0]   | 8-bit timer reload data        |   | 0x0        | to 0  | xff                    | 0x0   | R/W |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register         |           |        |           | TR7 = MSB                      |   |            |       |                        |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (T8F_TR0)        |           |        |           | TR0 = LSB                      |   |            |       |                        |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8-bit Timer Ch.0 |           | D15–8  | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Counter Data     | (16 bits) | D7–0   | TC[7:0]   | 8-bit timer counter data       |   | 0x0        | to 0  | xff                    | 0xff  | R   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register         |           |        |           | TC7 = MSB                      |   |            |       |                        |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (T8F_TC0)        |           |        |           | TC0 = LSB                      |   |            |       |                        |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8-bit Timer Ch.0 |           | D15–12 | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Control Register | (16 bits) | D11–8  | TFMD[3:0] | Fine mode setup                |   | 0x0        | to C  | )xf                    | 0x0   | R/W | Set a number of times                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| (T8F_CTL0)       |           |        |           |                                |   |            |       |                        |       |     | to insert delay into a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                  |           |        |           |                                |   |            |       |                        |       |     | 16-underflow period.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                  |           | D7–5   | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |           |        | TRMD      | Count mode select              | 1 | One shot   | 0     | Repeat                 | 0     | R/W |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           | D3–2   | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |           |        | PRESER    | Timer reset                    |   | Reset      |       | Ignored                | 0     | W   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        | PRUN      | Timer run/stop control         | 1 | Run        | 0     | Stop                   | 0     | R/W |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8-bit Timer Ch.0 |           | D15–9  | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Interrupt        | (16 bits) | D8     | T8IE      | 8-bit timer interrupt enable   | 1 | Enable     | 0     | Disable                | 0     | R/W |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Control Register |           | D7–1   | -         | reserved                       |   |            | -     |                        | -     | -   | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| (T8F_INT0)       |           | D0     | T8IF      | 8-bit timer interrupt flag     |   | Cause of   | 0     | Cause of               | 0     | R/W | Reset by writing 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                  |           |        |           |                                |   | interrupt  |       | interrupt not          |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  |           |        |           |                                |   | occurred   |       | occurred               |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 0x4220-0x4244

#### 16-bit Timer

| Register name                                              | Address             | Bit        | Name       | Function                                               | Setting                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                        | Init.  | R/W | Remarks                                   |
|------------------------------------------------------------|---------------------|------------|------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|-------------------------------------------|
| 16-bit Timer                                               | 0x4220              | D15–4      | -          | reserved                                               |                                                                                                                                                                                                                                  | _                                                                                                                                                                                                                                                                      | -      | -   | 0 when being read.                        |
| Ch.0 Input<br>Clock Select<br>Register                     | (16 bits)           |            | DF[3:0]    | Timer input clock select<br>(Prescaler output clock)   | DF[3:0]<br>Oxf<br>Oxe                                                                                                                                                                                                            | Clock<br>reserved<br>PCLK-1/16384                                                                                                                                                                                                                                      | 0x0    | R/W | a mon boing road.                         |
| (T16_CLK0)                                                 |                     |            |            |                                                        | 0xd<br>0xc<br>0xb<br>0xa<br>0x9<br>0x8<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2                                                                                                                                                 | PCLK-1/8192<br>PCLK-1/4096<br>PCLK-1/2048<br>PCLK-1/1024<br>PCLK-1/1024<br>PCLK-1/256<br>PCLK-1/256<br>PCLK-1/28<br>PCLK-1/28<br>PCLK-1/28<br>PCLK-1/32<br>PCLK-1/8<br>PCLK-1/8                                                                                        |        |     |                                           |
| 40 hitTimen                                                | 0 4000              | DIE        | TDI45-01   |                                                        | 0x1<br>0x0                                                                                                                                                                                                                       | PCLK-1/2<br>PCLK-1/1                                                                                                                                                                                                                                                   |        |     |                                           |
| 16-bit Timer<br>Ch.0 Reload<br>Data Register<br>(T16_TR0)  | 0x4222<br>(16 bits) | D15–0      | TR[15:0]   | 16-bit timer reload data<br>TR15 = MSB<br>TR0 = LSB    | UXU                                                                                                                                                                                                                              | to 0xffff                                                                                                                                                                                                                                                              | 0x0    | R/W |                                           |
| 16-bit Timer<br>Ch.0 Counter<br>Data Register<br>(T16_TC0) | 0x4224<br>(16 bits) |            | TC[15:0]   | 16-bit timer counter data<br>TC15 = MSB<br>TC0 = LSB   | 0x0                                                                                                                                                                                                                              | to 0xffff                                                                                                                                                                                                                                                              | Oxffff | R   |                                           |
| 16-bit Timer                                               | 0x4226              | D15–11     | -          | reserved                                               |                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                      | -      |     | 0 when being read.                        |
| Ch.0 Control                                               | (16 bits)           | D10        | CKACTV     | External clock active level select                     | 1 High                                                                                                                                                                                                                           | 0 Low                                                                                                                                                                                                                                                                  | 1      | R/W |                                           |
| Register<br>(T16_CTL0)                                     |                     | D9–8       | CKSL[1:0]  | Input clock and pulse width<br>measurement mode select | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0                                                                                                                                                                                            | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock                                                                                                                                                                                                    | 0x0    | R/W |                                           |
|                                                            |                     | D7–5       | -          | reserved                                               |                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                      | -      | -   | 0 when being read.                        |
|                                                            |                     | D4         | TRMD       | Count mode select                                      | 1 One shot                                                                                                                                                                                                                       | 0 Repeat                                                                                                                                                                                                                                                               | 0      | R/W |                                           |
|                                                            |                     | D3–2       | -          | reserved                                               |                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                      | -      | -   | 0 when being read.                        |
|                                                            |                     | D1         | PRESER     | Timer reset                                            | 1 Reset                                                                                                                                                                                                                          | 0 Ignored                                                                                                                                                                                                                                                              | 0      | W   |                                           |
|                                                            |                     | D0         | PRUN       | Timer run/stop control                                 | 1 Run                                                                                                                                                                                                                            | 0 Stop                                                                                                                                                                                                                                                                 | 0      | R/W |                                           |
| 16-bit Timer                                               | 0x4228              | D15–9      | -          | reserved                                               |                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                      | -      | -   | 0 when being read.                        |
| Ch.0 Interrupt                                             | (16 bits)           | D8         | T16IE      | 16-bit timer interrupt enable                          | 1 Enable                                                                                                                                                                                                                         | 0 Disable                                                                                                                                                                                                                                                              | 0      | R/W |                                           |
| Control Register<br>(T16_INT0)                             |                     | D7–1<br>D0 | –<br>T16IF | reserved<br>16-bit timer interrupt flag                | 1 Cause of<br>interrupt<br>occurred                                                                                                                                                                                              | O Cause of     interrupt not     occurred                                                                                                                                                                                                                              | 0      | R/W | 0 when being read.<br>Reset by writing 1. |
| 16-bit Timer                                               | 0x4240              | D15–4      | -          | reserved                                               |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                        | -      | -   | 0 when being read.                        |
| Ch.1 Input<br>Clock Select<br>Register<br>(T16_CLK1)       | (16 bits)           |            | DF[3:0]    | Timer input clock select<br>(Prescaler output clock)   | DF[3:0]<br>0xf<br>0xe<br>0xd<br>0xc<br>0xb<br>0xa<br>0x9<br>0x8<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0<br>0x0<br>0x2<br>0x1<br>0x6<br>0x7<br>0x6<br>0x7<br>0x6<br>0x6<br>0x6<br>0x6<br>0x6<br>0x6<br>0x6<br>0x6 | Clock<br>reserved<br>PCLK-1/16384<br>PCLK-1/8192<br>PCLK-1/8192<br>PCLK-1/2048<br>PCLK-1/2048<br>PCLK-1/1024<br>PCLK-1/254<br>PCLK-1/258<br>PCLK-1/128<br>PCLK-1/164<br>PCLK-1/28<br>PCLK-1/18<br>PCLK-1/2<br>PCLK-1/1<br>PCLK-1/2<br>PCLK-1/1<br>PCLK-1/2<br>PCLK-1/2 | 0x0    | R/W |                                           |
| 16-bit Timer<br>Ch.1 Reload<br>Data Register<br>(T16_TR1)  | 0x4242<br>(16 bits) | D15–0      | TR[15:0]   | 16-bit timer reload data<br>TR15 = MSB<br>TR0 = LSB    | 0x0                                                                                                                                                                                                                              | to 0xffff                                                                                                                                                                                                                                                              | 0x0    | R/W |                                           |
| 16-bit Timer<br>Ch.1 Counter<br>Data Register<br>(T16_TC1) | 0x4244<br>(16 bits) | D15–0      | TC[15:0]   | 16-bit timer counter data<br>TC15 = MSB<br>TC0 = LSB   | 0x0                                                                                                                                                                                                                              | to 0xffff                                                                                                                                                                                                                                                              | 0xffff | R   |                                           |

## 0x4246-0x4268

#### 16-bit Timer

| Register name                                                                                | Address             | Bit                                                                  | Name                                                                       | Function                                                                                                                                                                                                                                    | Se                                                                                  | etting                                                                                                                               | Init.                                  | R/W                                        | Remarks                                                        |
|----------------------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------|----------------------------------------------------------------|
| 16-bit Timer                                                                                 | 0x4246              | D15–11                                                               | ^                                                                          | reserved                                                                                                                                                                                                                                    |                                                                                     | _                                                                                                                                    | _                                      | -                                          | 0 when being read.                                             |
| Ch.1 Control                                                                                 | (16 bits)           | D10 11                                                               | СКАСТУ                                                                     | External clock active level select                                                                                                                                                                                                          | 1 High                                                                              | 0 Low                                                                                                                                | 1                                      | R/W                                        | o whom boing road.                                             |
| Register                                                                                     | (10 5.00)           | D9-8                                                                 | CKSL[1:0]                                                                  | Input clock and pulse width                                                                                                                                                                                                                 | CKSL[1:0]                                                                           | Mode                                                                                                                                 | 0x0                                    | R/W                                        |                                                                |
| (T16_CTL1)                                                                                   |                     | D9-0                                                                 | CKSE[1.0]                                                                  | measurement mode select                                                                                                                                                                                                                     | 0x3                                                                                 | reserved                                                                                                                             | 0.00                                   | 10/00                                      |                                                                |
| (                                                                                            |                     |                                                                      |                                                                            | measurement mode select                                                                                                                                                                                                                     | 0x3<br>0x2                                                                          | Pulse width                                                                                                                          |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             |                                                                                     | External clock                                                                                                                       |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x1                                                                                 |                                                                                                                                      |                                        |                                            |                                                                |
|                                                                                              |                     | D7–5                                                                 |                                                                            | reserved                                                                                                                                                                                                                                    | 0x0                                                                                 | Internal clock                                                                                                                       | _                                      | _                                          | O when being read                                              |
|                                                                                              |                     |                                                                      | -<br>TRMD                                                                  |                                                                                                                                                                                                                                             | 1 0                                                                                 |                                                                                                                                      | 0                                      | _<br>R/W                                   | 0 when being read.                                             |
|                                                                                              |                     | D4                                                                   | TRIND                                                                      | Count mode select                                                                                                                                                                                                                           | 1 One shot                                                                          | 0 Repeat                                                                                                                             | -                                      | R/W                                        |                                                                |
|                                                                                              |                     | D3–2                                                                 | -                                                                          | reserved                                                                                                                                                                                                                                    |                                                                                     | -                                                                                                                                    | -                                      | -                                          | 0 when being read.                                             |
|                                                                                              |                     | D1                                                                   | PRESER                                                                     | Timer reset                                                                                                                                                                                                                                 | 1 Reset                                                                             | 0 Ignored                                                                                                                            | 0                                      | W                                          |                                                                |
|                                                                                              |                     | D0                                                                   | PRUN                                                                       | Timer run/stop control                                                                                                                                                                                                                      | 1 Run                                                                               | 0 Stop                                                                                                                               | 0                                      | R/W                                        |                                                                |
| 16-bit Timer                                                                                 | 0x4248              | D15–9                                                                | -                                                                          | reserved                                                                                                                                                                                                                                    |                                                                                     | -                                                                                                                                    | -                                      | -                                          | 0 when being read.                                             |
| Ch.1 Interrupt                                                                               | (16 bits)           | D8                                                                   | T16IE                                                                      | 16-bit timer interrupt enable                                                                                                                                                                                                               | 1 Enable                                                                            | 0 Disable                                                                                                                            | 0                                      | R/W                                        | , , , , , , , , , , , , , , , , , , ,                          |
| Control Register                                                                             | ` '                 | D7-1                                                                 | _                                                                          | reserved                                                                                                                                                                                                                                    |                                                                                     | _                                                                                                                                    | _                                      | _                                          | 0 when being read.                                             |
| (T16_INT1)                                                                                   |                     | <br>D0                                                               | T16IF                                                                      | 16-bit timer interrupt flag                                                                                                                                                                                                                 | 1 Cause of                                                                          | 0 Cause of                                                                                                                           | 0                                      | R/W                                        | Reset by writing 1.                                            |
| ,                                                                                            |                     | 00                                                                   |                                                                            | 10-bit timer interrupt hag                                                                                                                                                                                                                  | interrupt                                                                           | interrupt not                                                                                                                        | 0                                      | 10.44                                      | rieser by writing 1.                                           |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | occurred                                                                            | occurred                                                                                                                             |                                        |                                            |                                                                |
| 10 hitTim                                                                                    | 0.4000              |                                                                      | 1                                                                          | l                                                                                                                                                                                                                                           |                                                                                     |                                                                                                                                      |                                        |                                            | 0 when heirs and t                                             |
| 16-bit Timer                                                                                 | 0x4260              | D15-4                                                                | -                                                                          |                                                                                                                                                                                                                                             |                                                                                     | -                                                                                                                                    | -                                      | -                                          | 0 when being read.                                             |
| Ch.2 Input                                                                                   | (16 bits)           | D3–0                                                                 | DF[3:0]                                                                    | Timer input clock select                                                                                                                                                                                                                    | DF[3:0]                                                                             | Clock                                                                                                                                | 0x0                                    | R/W                                        |                                                                |
| Clock Select                                                                                 |                     |                                                                      |                                                                            | (Prescaler output clock)                                                                                                                                                                                                                    | 0xf                                                                                 | reserved                                                                                                                             |                                        |                                            |                                                                |
| Register                                                                                     |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0xe                                                                                 | PCLK-1/16384                                                                                                                         |                                        |                                            |                                                                |
| (T16_CLK2)                                                                                   |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0xd                                                                                 | PCLK-1/8192                                                                                                                          |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0xc                                                                                 | PCLK-1/4096                                                                                                                          |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0xb                                                                                 | PCLK-1/2048                                                                                                                          |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0xa                                                                                 | PCLK-1/1024                                                                                                                          |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x9                                                                                 | PCLK-1/512                                                                                                                           |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x8                                                                                 | PCLK-1/256                                                                                                                           |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x7                                                                                 | PCLK-1/128                                                                                                                           |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x6                                                                                 | PCLK-1/64                                                                                                                            |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x5                                                                                 | PCLK-1/32                                                                                                                            |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x4                                                                                 | PCLK-1/16                                                                                                                            |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x3                                                                                 | PCLK-1/8                                                                                                                             |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x2                                                                                 | PCLK-1/4                                                                                                                             |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x1                                                                                 | PCLK-1/2                                                                                                                             |                                        |                                            |                                                                |
|                                                                                              |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 0x0                                                                                 | PCLK-1/1                                                                                                                             |                                        |                                            |                                                                |
| 16-bit Timer                                                                                 | 0x4262              | D15-0                                                                | TR[15:0]                                                                   | 16-bit timer reload data                                                                                                                                                                                                                    | 0x0                                                                                 | to 0xffff                                                                                                                            | 0x0                                    | R/W                                        |                                                                |
| Ch.2 Reload                                                                                  | (16 bits)           |                                                                      |                                                                            | TR15 = MSB                                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                      |                                        |                                            |                                                                |
| Data Register                                                                                | (,                  |                                                                      |                                                                            | TR0 = LSB                                                                                                                                                                                                                                   |                                                                                     |                                                                                                                                      |                                        |                                            |                                                                |
| (T16_TR2)                                                                                    |                     |                                                                      |                                                                            | 1110 - 200                                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                      |                                        |                                            |                                                                |
| 16-bit Timer                                                                                 | 0x4264              | D15–0                                                                | TC[15:0]                                                                   | 16-bit timer counter data                                                                                                                                                                                                                   |                                                                                     | to 0xffff                                                                                                                            | 0xffff                                 | R                                          |                                                                |
| Ch.2 Counter                                                                                 | (16 bits)           | 0-010                                                                |                                                                            | TC15 = MSB                                                                                                                                                                                                                                  | 0.00                                                                                | U UAIIII                                                                                                                             | JAIIII                                 | רי                                         |                                                                |
|                                                                                              | (16 bits)           |                                                                      |                                                                            |                                                                                                                                                                                                                                             |                                                                                     |                                                                                                                                      |                                        |                                            |                                                                |
| Data Register                                                                                |                     |                                                                      |                                                                            | TC0 = LSB                                                                                                                                                                                                                                   |                                                                                     |                                                                                                                                      |                                        |                                            |                                                                |
| (T16_TC2)                                                                                    |                     |                                                                      | L                                                                          | ļ                                                                                                                                                                                                                                           |                                                                                     |                                                                                                                                      |                                        |                                            |                                                                |
| 16-bit Timer                                                                                 |                     | D4E 44                                                               | 1                                                                          | reserved                                                                                                                                                                                                                                    |                                                                                     |                                                                                                                                      | _                                      | - 1                                        | 0 when being read.                                             |
|                                                                                              | 0x4266              | D15–11                                                               |                                                                            |                                                                                                                                                                                                                                             |                                                                                     | -                                                                                                                                    |                                        |                                            | 1                                                              |
| Ch.2 Control                                                                                 | 0x4266<br>(16 bits) | D15-11<br>D10                                                        | -<br>CKACTV                                                                | External clock active level select                                                                                                                                                                                                          | 1 High                                                                              | 0 Low                                                                                                                                | 1                                      | R/W                                        |                                                                |
| Ch.2 Control<br>Register                                                                     |                     |                                                                      |                                                                            |                                                                                                                                                                                                                                             | 1 High<br>CKSL[1:0]                                                                 | 0 Low<br>Mode                                                                                                                        |                                        | R/W<br>R/W                                 |                                                                |
|                                                                                              |                     | D10                                                                  | CKACTV                                                                     | External clock active level select                                                                                                                                                                                                          |                                                                                     |                                                                                                                                      | 1                                      |                                            |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10                                                                  | CKACTV                                                                     | External clock active level select<br>Input clock and pulse width                                                                                                                                                                           | CKSL[1:0]<br>0x3                                                                    | Mode<br>reserved                                                                                                                     | 1                                      |                                            |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10                                                                  | CKACTV                                                                     | External clock active level select<br>Input clock and pulse width                                                                                                                                                                           | CKSL[1:0]<br>0x3<br>0x2                                                             | Mode<br>reserved<br>Pulse width                                                                                                      | 1                                      |                                            |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10                                                                  | CKACTV                                                                     | External clock active level select<br>Input clock and pulse width                                                                                                                                                                           | CKSL[1:0]<br>0x3<br>0x2<br>0x1                                                      | Mode<br>reserved<br>Pulse width<br>External clock                                                                                    | 1                                      |                                            |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9–8                                                          | CKACTV                                                                     | External clock active level select<br>Input clock and pulse width<br>measurement mode select                                                                                                                                                | CKSL[1:0]<br>0x3<br>0x2                                                             | Mode<br>reserved<br>Pulse width                                                                                                      | 1                                      |                                            | 0 when being rood                                              |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9–8<br>D7–5                                                  | CKACTV<br>CKSL[1:0]                                                        | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved                                                                                                                                    | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0                                               | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock                                                                  | 1<br>0x0                               | R/W                                        | 0 when being read.                                             |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9-8<br>D7-5<br>D4                                            | CKACTV                                                                     | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select                                                                                                               | CKSL[1:0]<br>0x3<br>0x2<br>0x1                                                      | Mode<br>reserved<br>Pulse width<br>External clock                                                                                    | 1<br>0x0<br>0                          | R/W<br>–<br>R/W                            |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9–8<br>D7–5<br>D4<br>D3–2                                    | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-                                      | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved                                                                                                   | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot                                 | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock                                                                  | 1<br>0x0<br>-<br>0<br>-                | R/W<br>_<br>_<br>_                         | 0 when being read.<br>0 when being read.                       |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9–8<br>D7–5<br>D4<br>D3–2<br>D1                              | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-<br>PRESER                            | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved<br>Timer reset                                                                                    | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot<br>1 Reset                      | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock<br>0 Repeat<br>-<br>0 Repeat                                     | 1<br>0x0<br>-<br>0<br>-                | R/W<br>-<br>R/W<br>-<br>W                  |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9–8<br>D7–5<br>D4<br>D3–2                                    | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-                                      | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved                                                                                                   | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot                                 | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock                                                                  | 1<br>0x0<br>-<br>0<br>-                | R/W<br>_<br>_<br>_                         |                                                                |
| Ch.2 Control<br>Register                                                                     |                     | D10<br>D9–8<br>D7–5<br>D4<br>D3–2<br>D1                              | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-<br>PRESER                            | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved<br>Timer reset                                                                                    | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot<br>1 Reset                      | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock<br>0 Repeat<br>-<br>0 Repeat                                     | 1<br>0x0<br>-<br>0<br>-                | R/W<br>-<br>R/W<br>-<br>W                  |                                                                |
| Ch.2 Control<br>Register<br>(T16_CTL2)                                                       | (16 bits)           | D10<br>D9-8<br>D7-5<br>D4<br>D3-2<br>D1<br>D0                        | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-<br>PRESER                            | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved<br>Timer reset<br>Timer run/stop control                                                          | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot<br>1 Reset                      | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock<br>0 Repeat<br>-<br>0 Repeat                                     | 1<br>0x0<br>-<br>0<br>-                | R/W<br>-<br>R/W<br>-<br>W                  | 0 when being read.                                             |
| Ch.2 Control<br>Register<br>(T16_CTL2)<br>16-bit Timer                                       | (16 bits)           | D10<br>D9-8<br>D7-5<br>D4<br>D3-2<br>D1<br>D0<br>D15-9<br>D8         | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-<br>PRESER<br>PRUN<br>-               | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved<br>Timer reset<br>Timer run/stop control<br>reserved<br>16-bit timer interrupt enable             | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot<br>1 Reset<br>1 Run             | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock<br>0 Repeat<br>0 Repeat<br>0 Ignored<br>0 Stop                   | 1<br>0x0<br>-<br>0<br>0<br>0<br>0<br>0 | -<br>R/W<br>-<br>W<br>R/W<br>-<br>R/W      | 0 when being read.<br>0 when being read.                       |
| Ch.2 Control<br>Register<br>(T16_CTL2)<br>16-bit Timer<br>Ch.2 Interrupt<br>Control Register | (16 bits)           | D10<br>D9-8<br>D7-5<br>D4<br>D3-2<br>D1<br>D0<br>D15-9<br>D8<br>D7-1 | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-<br>PRESER<br>PRUN<br>-<br>T16IE<br>- | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved<br>Timer reset<br>Timer run/stop control<br>reserved<br>16-bit timer interrupt enable<br>reserved | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot<br>1 Reset<br>1 Run<br>1 Enable | Mode reserved Pulse width External clock Internal clock - 0 Repeat 0 Stop - 0 Disable                                                | 1<br>0x0<br>-<br>0<br>0<br>0<br>0<br>- | -<br>R/W<br>-<br>W<br>R/W<br>-<br>R/W<br>- | 0 when being read.<br>0 when being read.<br>0 when being read. |
| Ch.2 Control<br>Register<br>(T16_CTL2)<br>16-bit Timer<br>Ch.2 Interrupt                     | (16 bits)           | D10<br>D9-8<br>D7-5<br>D4<br>D3-2<br>D1<br>D0<br>D15-9<br>D8         | CKACTV<br>CKSL[1:0]<br>-<br>TRMD<br>-<br>PRESER<br>PRUN<br>-               | External clock active level select<br>Input clock and pulse width<br>measurement mode select<br>reserved<br>Count mode select<br>reserved<br>Timer reset<br>Timer run/stop control<br>reserved<br>16-bit timer interrupt enable             | CKSL[1:0]<br>0x3<br>0x2<br>0x1<br>0x0<br>1 One shot<br>1 Reset<br>1 Run             | Mode<br>reserved<br>Pulse width<br>External clock<br>Internal clock<br>0 Repeat<br>0 Repeat<br>0 Ignored<br>0 Stop<br>-<br>0 Disable | 1<br>0x0<br>-<br>0<br>0<br>0<br>0<br>0 | -<br>R/W<br>-<br>W<br>R/W<br>-<br>R/W<br>- | 0 when being read.<br>0 when being read.                       |

#### 0x4280-0x4288

## 8-bit Timer (with Fine Mode) Ch.1

| Register name           | Address   | Bit    | Name      | Function                       |            | Setting                | Init.    | R/W | Remarks                |
|-------------------------|-----------|--------|-----------|--------------------------------|------------|------------------------|----------|-----|------------------------|
| 8-bit Timer Ch.1        | 0x4280    | D15–4  | -         | reserved                       |            | -                      | -        | -   | 0 when being read.     |
| Input Clock             | (16 bits) | D3–0   | DF[3:0]   | 8-bit timer input clock select | DF[3:0]    | Clock                  | 0x0      | R/W |                        |
| Select Register         |           |        |           | (Prescaler output clock)       | 0xf        | reserved               | 1        | 1   |                        |
| (T8F_CLK1)              |           |        |           |                                | 0xe        | PCLK-1/16384           |          |     |                        |
|                         |           |        |           |                                | 0xd        | PCLK-1/8192            |          |     |                        |
|                         |           |        |           |                                | 0xc        | PCLK-1/4096            |          |     |                        |
|                         |           |        |           |                                | 0xb        | PCLK-1/2048            |          |     |                        |
|                         |           |        |           |                                | 0xa        | PCLK-1/1024            |          |     |                        |
|                         |           |        |           |                                | 0x9        | PCLK-1/512             |          |     |                        |
|                         |           |        |           |                                | 0x8        | PCLK-1/256             |          |     |                        |
|                         |           |        |           |                                | 0x7        | PCLK-1/128             |          |     |                        |
|                         |           |        |           |                                | 0x6        | PCLK-1/64              |          |     |                        |
|                         |           |        |           |                                | 0x5<br>0x4 | PCLK-1/32<br>PCLK-1/16 |          |     |                        |
|                         |           |        |           |                                | 0x4<br>0x3 | PCLK-1/16<br>PCLK-1/8  |          |     |                        |
|                         |           |        |           |                                | 0x3<br>0x2 | PCLK-1/8<br>PCLK-1/4   |          |     |                        |
|                         |           |        |           |                                | 0x2        | PCLK-1/2               |          |     |                        |
|                         |           |        |           |                                | 0x0        | PCLK-1/1               |          |     |                        |
| 8-bit Timer Ch.1        | 0x4282    | D15–8  | _         | reserved                       |            | _                      | <u> </u> |     | 0 when being read.     |
| Reload Data             | (16 bits) |        | TR[7:0]   | 8-bit timer reload data        | (          | x0 to 0xff             | 0x0      | R/W |                        |
| Register                | ( ,       | 5. 0   |           | TB7 = MSB                      |            |                        |          |     |                        |
| (T8F TR1)               |           |        |           | TR0 = LSB                      |            |                        |          |     |                        |
| 8-bit Timer Ch.1        | 0x4284    | D15-8  | _         | reserved                       |            | _                      | - 1      |     | 0 when being read.     |
| Counter Data            | (16 bits) |        | TC[7:0]   | 8-bit timer counter data       | (          | x0 to 0xff             | 0xff     | R   |                        |
| Register                | ( ,       | 5. 0   |           | TC7 = MSB                      |            |                        | 0,       |     |                        |
| (T8F TC1)               |           |        |           | TC0 = LSB                      |            |                        |          |     |                        |
| 8-bit Timer Ch.1        | 0x4286    | D15–12 | _         | reserved                       |            | _                      | -        | -   | 0 when being read.     |
| <b>Control Register</b> | (16 bits) | -      | TFMD[3:0] | Fine mode setup                |            | 0x0 to 0xf             | 0x0      | R/W | Set a number of times  |
| (T8F CTL1)              | ` '       |        |           |                                |            |                        |          |     | to insert delay into a |
| ,                       |           |        |           |                                |            |                        |          |     | 16-underflow period.   |
|                         |           | D7–5   | -         | reserved                       |            | _                      | -        | -   | 0 when being read.     |
|                         |           | D4     | TRMD      | Count mode select              | 1 One sho  | t 0 Repeat             | 0        | R/W |                        |
|                         |           | D3–2   | -         | reserved                       |            | _                      | -        | -   | 0 when being read.     |
|                         |           | D1     | PRESER    | Timer reset                    | 1 Reset    | 0 Ignored              | 0        | W   |                        |
|                         |           | D0     | PRUN      | Timer run/stop control         | 1 Run      | 0 Stop                 | 0        | R/W |                        |
| 8-bit Timer Ch.1        | 0x4288    | D15–9  | -         | reserved                       |            | -                      | -        | -   | 0 when being read.     |
| Interrupt               | (16 bits) | D8     | T8IE      | 8-bit timer interrupt enable   | 1 Enable   | 0 Disable              | 0        | R/W |                        |
| Control Register        |           | D7–1   | -         | reserved                       |            | -                      | -        | -   | 0 when being read.     |
| (T8F_INT1)              |           | D0     | T8IF      | 8-bit timer interrupt flag     | 1 Cause c  | f 0 Cause of           | 0        | R/W | Reset by writing 1.    |
|                         |           |        |           |                                | interrupt  | interrupt not          |          |     |                        |
|                         |           |        |           |                                | occurred   | d occurred             |          |     |                        |

## 0x4306-0x4316

### Interrupt Controller

| Register name    | Address   | Bit    | Name       | Function                         | Setting | Init. | R/W | Remarks            |
|------------------|-----------|--------|------------|----------------------------------|---------|-------|-----|--------------------|
| Interrupt Level  | 0x4306    | D15–11 | -          | reserved                         | _       | -     | _   | 0 when being read. |
| Setup Register 0 | (16 bits) | D10-8  | ILV1[2:0]  | P1 interrupt level               | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV0)        |           | D7–3   | -          | reserved                         | _       | -     | -   | 0 when being read. |
|                  |           | D2-0   | ILV0[2:0]  | P0 interrupt level               | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x4308    | D15-11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 1 | (16 bits) | D10-8  | ILV3[2:0]  | CT interrupt level               | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV1)        |           | D7–3   | -          | reserved                         | -       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV2[2:0]  | SWT interrupt level              | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x430a    | D15-11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 2 | (16 bits) | D10-8  | ILV5[2:0]  | SVD interrupt level              | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV2)        |           | D7–3   | -          | reserved                         | _       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV4[2:0]  | T8OSC1 interrupt level           | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x430c    | D15-11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 3 | (16 bits) | D10-8  | ILV7[2:0]  | T16E Ch.0 interrupt level        | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV3)        |           | D7–3   | -          | reserved                         | _       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV6[2:0]  | LCD interrupt level              | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x430e    | D15-11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 4 | (16 bits) | D10-8  | ILV9[2:0]  | T16 Ch.0 interrupt level         | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV4)        |           | D7–3   | -          | reserved                         | _       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV8[2:0]  | T8F interrupt level              | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x4310    | D15-11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 5 | (16 bits) | D10-8  | ILV11[2:0] | T16 Ch.2 interrupt level         | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV5)        |           | D7–3   | -          | reserved                         | _       | -     |     | 0 when being read. |
|                  |           | D2–0   | ILV10[2:0] | T16 Ch.1 interrupt level         | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x4312    | D15–11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 6 | (16 bits) | D10–8  | ILV13[2:0] | UART Ch.1 interrupt level        | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV6)        |           | D7–3   | -          | reserved                         | -       | -     | -   | 0 when being read. |
|                  |           | D2–0   | ILV12[2:0] | UART Ch.0 interrupt level        | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x4314    | D15–11 | -          | reserved                         | -       | -     | -   | 0 when being read. |
| Setup Register 7 | (16 bits) | D10–8  | ILV15[2:0] | I <sup>2</sup> C interrupt level | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV7)        |           | D7–3   | -          | reserved                         |         | -     |     | 0 when being read. |
|                  |           | D2-0   | ILV14[2:0] | SPI interrupt level              | 0 to 7  | 0x0   | R/W |                    |
| Interrupt Level  | 0x4316    | D15–11 | -          | reserved                         | _       | -     | -   | 0 when being read. |
| Setup Register 8 | (16 bits) |        | ILV17[2:0] | T16E Ch.1 interrupt level        | 0 to 7  | 0x0   | R/W |                    |
| (ITC_LV8)        |           | D7–3   | -          | reserved                         | _       | -     |     | 0 when being read. |
|                  |           | D2–0   | ILV16[2:0] | REMC interrupt level             | 0 to 7  | 0x0   | R/W |                    |

### 0x4320-0x4326

| Register name | Address   | Bit    | Name       | Function                               |   | Set      | ting | 9         | Init. | R/W | Remarks                               |
|---------------|-----------|--------|------------|----------------------------------------|---|----------|------|-----------|-------|-----|---------------------------------------|
| SPI Status    | 0x4320    | D15–3  | -          | reserved                               |   | -        | -    |           | -     | -   | 0 when being read.                    |
| Register      | (16 bits) | D2     | SPBSY      | Transfer busy flag (master)            | 1 | Busy     | 0    | Idle      | 0     | R   | , , , , , , , , , , , , , , , , , , , |
| (SPI_ST)      |           |        |            | ss signal low flag (slave)             | 1 | ss = L   | 0    | ss = H    | 1     |     |                                       |
|               |           | D1     | SPRBF      | Receive data buffer full flag          | 1 | Full     | 0    | Not full  | 0     | R   |                                       |
|               |           | D0     | SPTBE      | Transmit data buffer empty flag        | 1 | Empty    | 0    | Not empty | 1     | R   | 1                                     |
| SPI Transmit  | 0x4322    | D15–8  | -          | reserved                               |   | -        | -    |           | -     | -   | 0 when being read.                    |
| Data Register | (16 bits) | D7–0   | SPTDB[7:0] | SPI transmit data buffer               |   | 0x0 t    | o 0  | xff       | 0x0   | R/W | -                                     |
| (SPI_TXD)     |           |        |            | SPTDB7 = MSB                           |   |          |      |           |       |     |                                       |
|               |           |        |            | SPTDB0 = LSB                           |   |          |      |           |       |     |                                       |
| SPI Receive   | 0x4324    | D15–8  | -          | reserved                               |   | -        | -    |           | -     | -   | 0 when being read.                    |
| Data Register | (16 bits) | D7–0   | SPRDB[7:0] | SPI receive data buffer                |   | 0x0 t    | o 0  | xff       | 0x0   | R   |                                       |
| (SPI_RXD)     |           |        |            | SPRDB7 = MSB                           |   |          |      |           |       |     |                                       |
|               |           |        |            | SPRDB0 = LSB                           |   |          |      |           |       |     |                                       |
| SPI Control   | 0x4326    | D15–10 | -          | reserved                               |   | -        | -    |           | -     | -   | 0 when being read.                    |
| Register      | (16 bits) | D9     | MCLK       | SPI clock source select                | 1 | T16 Ch.1 | 0    | PCLK•1/4  | 0     | R/W |                                       |
| (SPI_CTL)     |           | D8     | MLSB       | LSB/MSB first mode select              | 1 | LSB      | 0    | MSB       | 0     | R/W |                                       |
|               |           | D7–6   | -          | reserved                               |   | -        |      |           | -     | -   | 0 when being read.                    |
|               |           | D5     | SPRIE      | Receive data buffer full int. enable   |   | Enable   | 0    | Disable   | 0     | R/W |                                       |
|               |           | D4     | SPTIE      | Transmit data buffer empty int. enable | 1 | Enable   | 0    | Disable   | 0     | R/W |                                       |
|               |           | D3     | СРНА       | Clock phase select                     | 1 | Data out | -    | Data in   | 0     |     | These bits must be                    |
|               |           | D2     | CPOL       | Clock polarity select                  | 1 | Active L | -    | Active H  | 0     |     | set before setting                    |
|               |           | D1     | MSSL       | Master/slave mode select               | 1 | Master   |      | Slave     | 0     | R/W | SPEN to 1.                            |
|               |           | D0     | SPEN       | SPI enable                             | 1 | Enable   | 0    | Disable   | 0     | R/W |                                       |

## 0x4340-0x4346

| Register name                       | Address                 | Bit    | Name      | Function                  |   | Set      | tin | g       | Init. | R/W | Remarks            |
|-------------------------------------|-------------------------|--------|-----------|---------------------------|---|----------|-----|---------|-------|-----|--------------------|
| I <sup>2</sup> C Enable<br>Register | <b>0x4340</b> (16 bits) | D15–1  | -         | reserved                  |   | -        | -   |         | -     | -   | 0 when being read. |
| (I2C_EN)                            |                         | D0     | I2CEN     | I <sup>2</sup> C enable   | 1 | Enable   | 0   | Disable | 0     | R/W |                    |
| I <sup>2</sup> C Control            | 0x4342                  | D15-10 | -         | reserved                  |   | -        | -   |         | -     | -   | 0 when being read. |
| Register                            | (16 bits)               | D9     | RBUSY     | Receive busy flag         | 1 | Busy     | 0   | Idle    | 0     | R   |                    |
| (I2C_CTL)                           |                         | D8     | TBUSY     | Transmit busy flag        | 1 | Busy     | 0   | Idle    | 0     | R   | 1                  |
|                                     |                         | D7–5   | -         | reserved                  |   | -        | -   |         | -     | -   | 0 when being read. |
|                                     |                         | D4     | NSERM     | Noise remove on/off       | 1 | On       | 0   | Off     | 0     | R/W |                    |
|                                     |                         | D3–2   | -         | reserved                  |   | -        | -   |         | -     | -   | 0 when being read. |
|                                     |                         | D1     | STP       | Stop control              | 1 | Stop     | 0   | Ignored | 0     | R/W |                    |
|                                     |                         | D0     | STRT      | Start control             | 1 | Start    | 0   | Ignored | 0     | R/W |                    |
| I <sup>2</sup> C Data               | 0x4344                  | D15–12 | -         | reserved                  |   |          | -   |         | -     | -   | 0 when being read. |
| Register                            | (16 bits)               | D11    | RBRDY     | Receive buffer ready      | 1 | Ready    | 0   | Empty   | 0     | R   |                    |
| (I2C_DAT)                           |                         | D10    | RXE       | Receive execution         | 1 | Receive  | 0   | Ignored | 0     | R/W |                    |
|                                     |                         | D9     | TXE       | Transmit execution        | 1 | Transmit | 0   | Ignored | 0     | R/W |                    |
|                                     |                         | D8     | RTACK     | Receive/transmit ACK      | 1 | Error    | 0   | ACK     | 0     | R/W |                    |
|                                     |                         | D7–0   | RTDT[7:0] | Receive/transmit data     |   | 0x0 t    | o 0 | xff     | 0x0   | R/W |                    |
|                                     |                         |        |           | RTDT7 = MSB               |   |          |     |         |       |     |                    |
|                                     |                         |        |           | RTDT0 = LSB               |   |          |     |         |       |     |                    |
| I <sup>2</sup> C Interrupt          | 0x4346                  | D15–2  | -         | reserved                  |   | -        | -   |         | -     | -   | 0 when being read. |
| Control Register                    | (16 bits)               | D1     | RINTE     | Receive interrupt enable  | 1 | Enable   | 0   | Disable | 0     | R/W |                    |
| (I2C_ICTL)                          |                         | D0     | TINTE     | Transmit interrupt enable | 1 | Enable   | 0   | Disable | 0     | R/W |                    |

## 0x5000-0x5003

#### **Clock Timer**

| Register name           | Address  | Bit  | Name       | Function                     |   | Set       | tin | g             | Init. | R/W | Remarks             |
|-------------------------|----------|------|------------|------------------------------|---|-----------|-----|---------------|-------|-----|---------------------|
| Clock Timer             | 0x5000   | D7–5 | –          | reserved                     |   | -         | -   |               | -     | -   | 0 when being read.  |
| <b>Control Register</b> | (8 bits) | D4   | CTRST      | Clock timer reset            | 1 | Reset     | 0   | Ignored       | 0     | W   | -                   |
| (CT_CTL)                |          | D3–1 | -          | reserved                     |   | -         | _   |               | -     | -   | 1                   |
|                         |          | D0   | CTRUN      | Clock timer run/stop control | 1 | Run       | 0   | Stop          | 0     | R/W |                     |
| Clock Timer             | 0x5001   | D7–0 | CTCNT[7:0] | Clock timer counter value    | Γ | 0x0 t     | o 0 | xff           | 0     | R   |                     |
| Counter Register        | (8 bits) |      |            |                              |   |           |     |               |       |     |                     |
| (CT_CNT)                | · ,      |      |            |                              |   |           |     |               |       |     |                     |
| Clock Timer             | 0x5002   | D7–4 | -          | reserved                     |   | -         | _   |               | -     | -   | 0 when being read.  |
| Interrupt Mask          | (8 bits) | D3   | CTIE32     | 32 Hz interrupt enable       | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| Register                |          | D2   | CTIE8      | 8 Hz interrupt enable        | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| (CT_IMSK)               |          | D1   | CTIE2      | 2 Hz interrupt enable        | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
|                         |          | D0   | CTIE1      | 1 Hz interrupt enable        | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| Clock Timer             | 0x5003   | D7–4 | -          | reserved                     |   | -         | -   |               | -     | -   | 0 when being read.  |
| Interrupt Flag          | (8 bits) | D3   | CTIF32     | 32 Hz interrupt flag         | 1 | Cause of  | 0   | Cause of      | 0     | R/W | Reset by writing 1. |
| Register                |          | D2   | CTIF8      | 8 Hz interrupt flag          | 1 | interrupt |     | interrupt not | 0     | R/W |                     |
| (CT_IFLG)               |          | D1   | CTIF2      | 2 Hz interrupt flag          | 1 | occurred  |     | occurred      | 0     | R/W |                     |
|                         |          | D0   | CTIF1      | 1 Hz interrupt flag          | 1 |           |     |               | 0     | R/W |                     |

## 0x5020-0x5023

### Stopwatch Timer

| Register name    | Address  | Bit  | Name        | Function                         |   | Set       | tin | g             | Init. | R/W | Remarks             |
|------------------|----------|------|-------------|----------------------------------|---|-----------|-----|---------------|-------|-----|---------------------|
| Stopwatch        | 0x5020   | D7–5 | -           | reserved                         |   | -         | _   |               | -     | -   | 0 when being read.  |
| Timer Control    | (8 bits) | D4   | SWTRST      | Stopwatch timer reset            | 1 | Reset     | 0   | Ignored       | 0     | W   |                     |
| Register         |          | D3–1 | -           | reserved                         |   | -         | -   |               | -     | -   |                     |
| (SWT_CTL)        |          | D0   | SWTRUN      | Stopwatch timer run/stop control | 1 | Run       | 0   | Stop          | 0     | R/W |                     |
| Stopwatch        | 0x5021   | D7–4 | BCD10[3:0]  | 1/10 sec. BCD counter value      |   | 0 t       | o 9 |               | 0     | R   |                     |
| Timer BCD        | (8 bits) |      |             |                                  |   |           |     |               |       |     |                     |
| Counter Register |          | D3–0 | BCD100[3:0] | 1/100 sec. BCD counter value     |   | 0 t       | o 9 |               | 0     | R   |                     |
| (SWT_BCNT)       |          |      |             |                                  |   |           |     |               |       |     |                     |
| Stopwatch        | 0x5022   | D7–3 | -           | reserved                         |   | -         | -   |               | -     | -   | 0 when being read.  |
| Timer Interrupt  | (8 bits) | D2   | SIE1        | 1 Hz interrupt enable            | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| Mask Register    |          | D1   | SIE10       | 10 Hz interrupt enable           | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| (SWT_IMSK)       |          | D0   | SIE100      | 100 Hz interrupt enable          | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| Stopwatch        | 0x5023   | D7–3 | -           | reserved                         |   |           | _   |               | -     | -   | 0 when being read.  |
| Timer Interrupt  | (8 bits) | D2   | SIF1        | 1 Hz interrupt flag              | 1 | Cause of  | 0   | Cause of      | 0     | R/W | Reset by writing 1. |
| Flag Register    |          | D1   | SIF10       | 10 Hz interrupt flag             |   | interrupt |     | interrupt not | 0     | R/W |                     |
| (SWT_IFLG)       |          | D0   | SIF100      | 100 Hz interrupt flag            |   | occurred  |     | occurred      | 0     | R/W |                     |

### 0x5040-0x5041

## Watchdog Timer

| Register name | Address  | Bit  | Name        | Function                        | Set               | ting           | Init. | R/W | Remarks            |
|---------------|----------|------|-------------|---------------------------------|-------------------|----------------|-------|-----|--------------------|
| Watchdog      | 0x5040   | D7–5 | -           | reserved                        | -                 | _              | -     | -   | 0 when being read. |
| Timer Control | (8 bits) | D4   | WDTRST      | Watchdog timer reset            | 1 Reset 0 Ignored |                | 0     | W   | -                  |
| Register      |          | D3–0 | WDTRUN[3:0] | Watchdog timer run/stop control | Other than 1010   | 1010           | 1010  | R/W |                    |
| (WDT_CTL)     |          |      |             |                                 | Run               | Stop           |       |     |                    |
| Watchdog      | 0x5041   | D7–2 | -           | reserved                        | -                 | -              | -     | -   | 0 when being read. |
| Timer Status  | (8 bits) |      |             |                                 |                   |                |       |     |                    |
| Register      |          | D1   | WDTMD       | NMI/Reset mode select           | 1 Reset           | 0 NMI          | 0     | R/W |                    |
| (WDT_ST)      |          | D0   | WDTST       | NMI status                      | 1 NMI occurred    | 0 Not occurred | 0     | R   |                    |

#### APPENDIX A I/O REGISTER LIST

## 0x5060-0x5065

#### Oscillator

| Register name                    | Address  | Bit        | Name        | Function                           |            | Set                   | ting                       | Init. | R/W      | Remarks            |
|----------------------------------|----------|------------|-------------|------------------------------------|------------|-----------------------|----------------------------|-------|----------|--------------------|
| Clock Source                     | 0x5060   | D7–2       | -           | reserved                           | Γ          | -                     | _                          | -     | -        | 0 when being read. |
| Select Register                  | (8 bits) | D1         | HSCLKSEL    | High-speed clock select            | 1          | OSC3                  | 0 IOSC                     | 0     | R/W      |                    |
| (OSC_SRC)                        |          | D0         | CLKSRC      | System clock source select         | 1          | OSC1                  | 0 HSCLK                    | 0     | R/W      |                    |
| Oscillation                      | 0x5061   | D7–6       | IOSCWT[1:0] | IOSC wait cycle select             |            | DSCWT[1:0]            | Wait cycle                 | 0x0   | R/W      |                    |
| <b>Control Register</b>          | (8 bits) |            |             | -                                  |            | 0x3                   | 8 cycles                   |       |          |                    |
| (OSC_CTL)                        |          |            |             |                                    |            | 0x2                   | 16 cycles                  |       |          |                    |
|                                  |          |            |             |                                    |            | 0x1                   | 32 cycles                  |       |          |                    |
|                                  |          |            |             |                                    |            | 0x0                   | 64 cycles                  |       |          |                    |
|                                  |          | D5–4       | OSC3WT[1:0] | OSC3 wait cycle select             | 0          | SC3WT[1:0]            | Wait cycle                 | 0x0   | R/W      |                    |
|                                  |          |            |             |                                    |            | 0x3                   | 128 cycles                 |       |          |                    |
|                                  |          |            |             |                                    |            | 0x2                   | 256 cycles                 |       |          |                    |
|                                  |          |            |             |                                    |            | 0x1                   | 512 cycles                 |       |          |                    |
|                                  |          |            |             |                                    | <u> </u>   | 0x0                   | 1024 cycles                |       |          |                    |
|                                  |          | D3         | -<br>IOSCEN | reserved                           | 4          | -                     | -                          | -     | -        | 0 when being read. |
|                                  |          | D2         |             | IOSC enable                        | -          | Enable                | 0 Disable                  | 1     | R/W      |                    |
|                                  |          | D1         | OSC1EN      | OSC1 enable                        |            | Enable                | 0 Disable<br>0 Disable     | 0     | R/W      |                    |
|                                  |          | D0         | OSC3EN      | OSC3 enable                        | 11         | Enable                | 0 Disable                  | 0     | R/W      |                    |
| Noise Filter                     | 0x5062   | D7–2       | -           | reserved                           |            | -                     | -                          | -     | -        | 0 when being read. |
| Enable Register                  | (8 bits) | D1         | RSTFE       | Reset noise filter enable          | -          | Enable                | 0 Disable                  | 1     | R/W      |                    |
| (OSC_NFEN)                       |          | D0         | NMIFE       | NMI noise filter enable            | 1          | Enable                | 0 Disable                  | 0     | R/W      |                    |
| LCD Clock                        | 0x5063   | D7–5       | -           | reserved                           |            | -                     | -                          | -     | -        | 0 when being read. |
| Setup Register                   | (8 bits) | D4–2       | LCKDV[2:0]  | LCD clock division ratio select    | L          | _CKDV[2:0]            | Division ratio             | 0x0   | R/W      |                    |
| (OSC_LCLK)                       |          |            |             |                                    |            | 0x7–0x5               | reserved                   |       |          |                    |
|                                  |          |            |             |                                    |            | 0x4                   | HSCLK-1/512                |       |          |                    |
|                                  |          |            |             |                                    |            | 0x3                   | HSCLK-1/256                |       |          |                    |
|                                  |          |            |             |                                    |            | 0x2                   | HSCLK-1/128                |       |          |                    |
|                                  |          |            |             |                                    |            | 0x1                   | HSCLK-1/64                 |       |          |                    |
|                                  |          | <b>D</b> 4 |             |                                    | 4          | 0x0                   | HSCLK-1/32                 | 4     | DAA      |                    |
|                                  |          | D1         | LCKSRC      | LCD clock source select            | -          | OSC1                  | 0 HSCLK                    | 1     | R/W      |                    |
|                                  |          | D0         | LCKEN       | LCD clock enable                   | 11         | Enable                | 0 Disable                  | 0     | R/W      |                    |
| FOUT Control                     | 0x5064   | D7–4       | -           | reserved                           |            | -                     | -                          | -     | -        | 0 when being read. |
| Register                         | (8 bits) | D3–2       | FOUTHD      | FOUTH clock division ratio select  | F          | OUTHD[1:0]            | Division ratio             | 0x0   | R/W      |                    |
| (OSC_FOUT)                       |          |            | [1:0]       |                                    |            | 0x3                   | reserved                   |       |          |                    |
|                                  |          |            |             |                                    |            | 0x2                   | HSCLK-1/4                  |       |          |                    |
|                                  |          |            |             |                                    |            | 0x1                   | HSCLK-1/2                  |       |          |                    |
|                                  |          | D1         | FOUTHE      | FOUTH output enable                | 1          | 0x0<br>Enable         | HSCLK-1/1<br>0 Disable     | 0     | R/W      |                    |
|                                  |          | D1         | FOUT1E      | FOUT1 output enable                | -          | Enable                | 0 Disable                  | 0     | R/W      |                    |
|                                  | 0 5005   |            |             | ,                                  | <u>   </u> | Enable                | 0 Disable                  | 0     |          |                    |
| T8OSC1 Clock                     | 0x5065   | D7-4       |             | reserved                           | +          | -                     | -<br>Division anti         | -     | -        | 0 when being read. |
| Control Register<br>(OSC_T8OSC1) | (8 bits) | D3–1       | 1801CK[2:0] | T8OSC1 clock division ratio select | $\vdash$   | 8O1CK[2:0]<br>0x7-0x6 | Division ratio<br>reserved | 0x0   | R/W      |                    |
| (030_100301)                     |          |            |             |                                    |            | 0x7–0x6<br>0x5        | OSC1-1/32                  |       |          |                    |
|                                  |          |            |             |                                    |            | 0x5<br>0x4            | OSC1-1/32<br>OSC1-1/16     |       |          |                    |
|                                  |          |            |             |                                    |            | 0x4<br>0x3            | OSC1-1/18                  |       |          |                    |
|                                  |          |            |             |                                    |            | 0x2                   | OSC1-1/8                   |       |          |                    |
|                                  |          |            |             |                                    |            | 0x2                   | OSC1-1/4                   |       |          |                    |
|                                  |          |            |             |                                    |            | 0x0                   | OSC1-1/1                   |       |          |                    |
|                                  |          | D0         | T8O1CE      | T8OSC1 clock output enable         | 1          | Enable                | 0 Disable                  | 0     | R/W      | 1                  |
|                                  |          | -          |             | a see the prove there              |            |                       |                            | -     | <u> </u> | l                  |

### 0x5080-0x5081

#### Clock Generator

| Register name | Address  | Bit  | Name        | Function                     | Set             | ting        | Init. | R/W | Remarks            |
|---------------|----------|------|-------------|------------------------------|-----------------|-------------|-------|-----|--------------------|
| PCLK Control  | 0x5080   | D7–2 | -           | reserved                     | -               | -           | -     | -   | 0 when being read. |
| Register      | (8 bits) | D1–0 | PCKEN[1:0]  | PCLK enable                  | PCKEN[1:0]      | PCLK supply | 0x3   | R/W |                    |
| (CLG_PCLK)    |          |      |             |                              | 0x3 Enable      |             | 1     |     |                    |
|               |          |      |             |                              | 0x2 Not allowed |             |       |     |                    |
|               |          |      |             |                              | 0x1             | Not allowed |       |     |                    |
|               |          |      |             |                              | 0x0             | Disable     |       |     |                    |
| CCLK Control  | 0x5081   | D7–2 | -           | reserved                     | -               | -           | -     | -   | 0 when being read. |
| Register      | (8 bits) | D1–0 | CCLKGR[1:0] | CCLK clock gear ratio select | CCLKGR[1:0]     | Gear ratio  | 0x0   | R/W | -                  |
| (CLG_CCLK)    |          |      |             |                              | 0x3             | 1/8         |       |     |                    |
|               |          |      |             |                              | 0x2             | 1/4         |       |     |                    |
|               |          |      |             |                              | 0x1             | 1/2         |       |     |                    |
|               |          |      |             |                              | 0x0             | 1/1         |       |     |                    |

#### APPENDIX A I/O REGISTER LIST

## 0x50a0-0x50a6

#### LCD Driver

| Register name                  | Address            | Bit  | Name       | Function                          |          | Set        | ting             | Init. | R/W | Remarks             |
|--------------------------------|--------------------|------|------------|-----------------------------------|----------|------------|------------------|-------|-----|---------------------|
| LCD Display                    | 0x50a0             | D7   | SEGREV     | Segment output assignment control | 1        | Normal     | 0 Reverse        | 1     | R/W |                     |
| Control Register               | (8 bits)           | D6   | COMREV     | Common output assignment control  |          | Normal     | 0 Reverse        | 1     | R/W |                     |
| (LCD_DCTL)                     |                    | D5   | DSPAR      | Display memory area control       | 1        | Area 1     | 0 Area 0         | 0     | R/W |                     |
|                                |                    | D4   | DSPREV     | Reverse display control           | 1        | Normal     | 0 Reverse        | 1     | R/W |                     |
|                                |                    | D3–2 | -          | reserved                          |          |            | -                | -     | -   | 0 when being read.  |
|                                |                    | D1–0 | DSPC[1:0]  | LCD display control               |          | DSPC[1:0]  | Display          | 0x0   | R/W |                     |
|                                |                    |      |            |                                   |          | 0x3        | All off          |       |     |                     |
|                                |                    |      |            |                                   |          | 0x2        | All on           |       |     |                     |
|                                |                    |      |            |                                   |          | 0x1        | Normal display   |       |     |                     |
|                                |                    |      |            |                                   |          | 0x0        | Display off      |       |     |                     |
| LCD Contrast                   | 0x50a1             | D7–4 | -          | reserved                          |          |            | -                | -     | -   | 0 when being read.  |
| Adjust Register                | (8 bits)           | D3–0 | LC[3:0]    | LCD contrast adjustment           |          | LC[3:0]    | Display          | 0x0   | R/W |                     |
| (LCD_CADJ)                     |                    |      |            |                                   |          | 0xf        | Dark             |       |     |                     |
|                                |                    |      |            |                                   |          | :          | :                |       |     |                     |
|                                |                    |      | 1          |                                   | <u> </u> | 0x0        | Light            |       |     |                     |
| LCD Clock                      | 0x50a2<br>(8 bits) | D7-2 | -          | reserved                          | <u>.</u> |            | -                | -     | -   | 0 when being read.  |
| Control Register<br>(LCD_CCTL) | (8 DItS)           | D1–0 | LDUTY[1:0] | LCD duty select                   | Ľ        | _DUTY[1:0] | Duty             | 0x2   | R/W |                     |
| (LOD_COTL)                     |                    |      |            |                                   |          | 0x3<br>0x2 | reserved<br>1/32 |       |     |                     |
|                                |                    |      |            |                                   |          | 0x2<br>0x1 | 1/32             |       |     |                     |
|                                |                    |      |            |                                   |          | 0x0        | reserved         |       |     |                     |
| LCD Voltage                    | 0x50a3             | D7–5 | -          | reserved                          | Ē        |            | _                | _     | _   | 0 when being read.  |
| Regulator                      | (8 bits)           | D4   | LHVLD      | LCD heavy load protection mode    | 1        | On         | 0 Off            | 0     | R/W | o mon boing road.   |
| Control Register               | , ,                | D3-0 | -          | reserved                          |          |            | -                | _     | -   | 0 when being read.  |
| (LCD_VREG)                     |                    |      |            |                                   |          |            |                  |       |     |                     |
| LCD Power                      | 0x50a4             | D7–2 | -          | reserved                          |          |            | -                | -     | -   | 0 when being read.  |
| Voltage Booster                | (8 bits)           |      |            |                                   |          |            |                  |       |     |                     |
| Control Register               |                    | D1   | VDSEL      | Regulator power source select     |          | Vd2        | 0 Vdd            | 0     | R/W |                     |
| (LCD_PWR)                      |                    | D0   | PBON       | Power voltage booster control     | 1        | On         | 0 Off            | 0     | R/W |                     |
| LCD Interrupt                  | 0x50a5             | D7–1 | -          | reserved                          |          |            | -                | -     | -   | 0 when being read.  |
| Mask Register                  | (8 bits)           |      |            |                                   |          |            |                  |       |     |                     |
| (LCD_IMSK)                     |                    | D0   | FRMIE      | Frame signal interrupt enable     | 1        | Enable     | 0 Disable        | 0     | R/W |                     |
| LCD Interrupt                  | 0x50a6             | D7–1 | -          | reserved                          |          |            | ]                | -     | -   | 0 when being read.  |
| Flag Register                  | (8 bits)           |      |            |                                   |          |            |                  |       |     |                     |
| (LCD_IFLG)                     |                    | D0   | FRMIF      | Frame signal interrupt flag       | 1        | Occurred   | 0 Not occurred   | 0     | R/W | Reset by writing 1. |

## 0x50c0-0x50c5

#### 8-bit OSC1 Timer

| Register name   | Address  | Bit  | Name        | Function                          |   | Set       | tin | g             | Init. | R/W | Remarks             |
|-----------------|----------|------|-------------|-----------------------------------|---|-----------|-----|---------------|-------|-----|---------------------|
| 8-bit OSC1      | 0x50c0   | D7–5 | -           | reserved                          | Ē | -         | _   |               | -     | -   | 0 when being read.  |
| Timer Control   | (8 bits) | D4   | T8ORST      | Timer reset                       | 1 | Reset     | 0   | Ignored       | 0     | W   | Ŭ                   |
| Register        |          | D3–2 | -           | reserved                          |   |           | -   |               | -     | -   |                     |
| (T8OSC1_CTL)    |          | D1   | T8ORMD      | Count mode select                 | 1 | One shot  | 0   | Repeat        | 0     | R/W |                     |
|                 |          | D0   | T8ORUN      | Timer run/stop control            | 1 | Run       | 0   | Stop          | 0     | R/W |                     |
| 8-bit OSC1      | 0x50c1   | D7–0 | T8OCNT[7:0] | Timer counter data                |   | 0x0 t     | 0 ( | Dxff          | 0x0   | R   |                     |
| Timer Counter   | (8 bits) |      |             | T8OCNT7 = MSB                     |   |           |     |               |       |     |                     |
| Data Register   |          |      |             | T8OCNT0 = LSB                     |   |           |     |               |       |     |                     |
| (T8OSC1_CNT)    |          |      |             |                                   |   |           |     |               |       |     |                     |
| 8-bit OSC1      | 0x50c2   | D7–0 | T8OCMP[7:0] | Compare data                      |   | 0x0 t     | o ( | Dxff          | 0x0   | R/W |                     |
| Timer Compare   | (8 bits) |      |             | T8OCMP7 = MSB                     |   |           |     |               |       |     |                     |
| Data Register   |          |      |             | T8OCMP0 = LSB                     |   |           |     |               |       |     |                     |
| (T8OSC1_CMP)    |          |      |             |                                   |   |           |     |               |       |     |                     |
| 8-bit OSC1      | 0x50c3   | D7–1 | -           | reserved                          |   | -         | _   |               | -     | -   | 0 when being read.  |
| Timer Interrupt | (8 bits) | D0   | T8OIE       | 8-bit OSC1 timer interrupt enable | 1 | Enable    | 0   | Disable       | 0     | R/W |                     |
| Mask Register   |          |      |             |                                   |   |           |     |               |       |     |                     |
| (T8OSC1_IMSK)   |          |      |             |                                   |   |           |     |               |       |     |                     |
| 8-bit OSC1      | 0x50c4   | D7–1 | -           | reserved                          |   | -         | -   |               | -     | -   | 0 when being read.  |
| Timer Interrupt | (8 bits) | D0   | T8OIF       | 8-bit OSC1 timer interrupt flag   | 1 | Cause of  | 0   | Cause of      | 0     | R/W | Reset by writing 1. |
| Flag Register   |          |      |             |                                   |   | interrupt |     | interrupt not |       |     |                     |
| (T8OSC1_IFLG)   |          |      |             |                                   |   | occurred  |     | occurred      |       |     |                     |
| 8-bit OSC1      | 0x50c5   | D7–0 | T8ODTY[7:0] | PWM output duty data              |   | 0x0 t     | o ( | Dxff          | 0x0   | R/W |                     |
| Timer PWM       | (8 bits) |      |             | T8ODTY7 = MSB                     |   |           |     |               |       |     |                     |
| Duty Data       |          |      |             | T8ODTY0 = LSB                     |   |           |     |               |       |     |                     |
| Register        |          |      |             |                                   |   |           |     |               |       |     |                     |
| (T8OSC1_DUTY)   |          |      |             |                                   |   |           |     |               |       |     |                     |

## 0x5100-0x5104

#### SVD Circuit

| Register name                 | Address  | Bit  | Name      | Function             |   | Set       | ting | 9             | Init. | R/W | Remarks             |
|-------------------------------|----------|------|-----------|----------------------|---|-----------|------|---------------|-------|-----|---------------------|
| SVD Enable                    | 0x5100   | D7–1 | -         | reserved             |   |           | _    |               | -     | -   | 0 when being read.  |
| Register<br>(SVD_EN)          | (8 bits) | D0   | SVDEN     | SVD enable           | 1 | Enable    | 0    | Disable       | 0     | R/W |                     |
| SVD Compare                   | 0x5101   | D7–4 | -         | reserved             | Τ |           | _    |               | -     | _   | 0 when being read.  |
| Voltage Register              | (8 bits) | D3–0 | SVDC[3:0] | SVD compare voltage  |   | SVDC[3:0] |      | Voltage       | 0x0   | R/W |                     |
| (SVD_CMP)                     |          |      |           |                      |   | 0xf       |      | 3.2 V         |       |     |                     |
|                               |          |      |           |                      |   | 0xe       |      | 3.1 V         |       |     |                     |
|                               |          |      |           |                      |   | 0xd       |      | 3.0 V         |       |     |                     |
|                               |          |      |           |                      |   | 0xc       |      | 2.9 V         |       |     |                     |
|                               |          |      |           |                      |   | 0xb       |      | 2.8 V         |       |     |                     |
|                               |          |      |           |                      |   | 0xa       |      | 2.7 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x9       |      | 2.6 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x8       |      | 2.5 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x7       |      | 2.4 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x6       |      | 2.3 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x5       |      | 2.2 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x4       |      | 2.1 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x3       |      | 2.0 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x2       |      | 1.9 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x1       |      | 1.8 V         |       |     |                     |
|                               |          |      |           |                      |   | 0x0       |      | reseved       |       |     |                     |
| SVD Detection                 | 0x5102   | D7–1 | -         | reserved             | Τ | -         | _    |               | -     | -   | 0 when being read.  |
| Result Register<br>(SVD_RSLT) | (8 bits) | D0   | SVDDT     | SVD detection result | 1 | Low       | 0    | Normal        | ×     | R   |                     |
| SVD Interrupt                 | 0x5103   | D7–1 | -         | reserved             | 1 |           | _    |               | _     | _   | 0 when being read.  |
| Mask Register<br>(SVD_IMSK)   | (8 bits) | D0   | SVDIE     | SVD interrupt enable | 1 | Enable    | 0    | Disable       | 0     | R/W |                     |
| SVD Interrupt                 | 0x5104   | D7–1 | -         | reserved             | T |           | _    |               | _     | -   | 0 when being read.  |
| Flag Register                 | (8 bits) | D0   | SVDIF     | SVD interrupt flag   | 1 | Cause of  | 0    | Cause of      | 0     |     | Reset by writing 1. |
| (SVD_IFLG)                    |          |      |           |                      |   | interrupt |      | interrupt not |       |     |                     |
|                               |          |      |           |                      |   | occurred  |      | occurred      |       |     |                     |

| 0x5120        |          |      |       |                                |   |                  |                | Po    | owe | r Generator        |
|---------------|----------|------|-------|--------------------------------|---|------------------|----------------|-------|-----|--------------------|
| Register name | Address  | Bit  | Name  | Function                       |   | Se               | tting          | Init. | R/W | Remarks            |
| VD1 Control   | 0x5120   | D7–6 | -     | reserved                       |   |                  | -              | -     | -   | 0 when being read. |
| Register      | (8 bits) | D5   | HVLD  | VD1 heavy load protection mode | 1 | On               | 0 Off          | 0     | R/W | -                  |
| (VD1_CTL)     |          | D4–1 | -     | reserved                       |   |                  | -              | -     | -   | 0 when being read. |
|               |          | D0   | VD1MD | Flash erase/program mode       | 1 | Flash (2.5<br>V) | 0 Norm.(1.8 V) | 0     | R/W |                    |

#### APPENDIX A I/O REGISTER LIST

## 0x5200-0x5213

#### P Port & Port MUX

| Register name                                             | Address                   | Bit        | Name            | Function                                     |   | Set                                                                     | tin | g                                                                                                     | Init.       | R/W      | Remarks             |
|-----------------------------------------------------------|---------------------------|------------|-----------------|----------------------------------------------|---|-------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------|-------------|----------|---------------------|
| P0 Port Input                                             | 0x5200                    | D7–0       | P0IN[7:0]       | P0[7:0] port input data                      | 1 | 1 (H)                                                                   | 0   | 0 (L)                                                                                                 | ×           | R        |                     |
| Data Register<br>(P0_IN)                                  | (8 bits)                  |            |                 |                                              |   |                                                                         |     |                                                                                                       |             |          |                     |
| P0 Port Output<br>Data Register<br>(P0_OUT)               | 0x5201<br>(8 bits)        | D7–0       | P0OUT[7:0]      | P0[7:0] port output data                     | 1 | 1 (H)                                                                   | 0   | 0 (L)                                                                                                 | 0           | R/W      |                     |
| P0 Port<br>Output Enable<br>Register<br>(P0_OEN)          | <b>0x5202</b><br>(8 bits) | D7–0       | P0OEN[7:0]      | P0[7:0] port output enable                   | 1 | Enable                                                                  | 0   | Disable                                                                                               | 0           | R/W      |                     |
| P0 Port Pull-up<br>Control Register<br>(P0_PU)            | 0x5203<br>(8 bits)        | D7–0       | P0PU[7:0]       | P0[7:0] port pull-up enable                  | 1 | Enable                                                                  | 0   | Disable                                                                                               | 1<br>(0xff) | R/W      |                     |
| P0 Port Schmitt<br>Trigger Control<br>Register<br>(P0_SM) | 0x5204<br>(8 bits)        | D7-0       | P0SM[7:0]       | P0[7:0] port Schmitt trigger input<br>enable | 1 | Enable<br>(Schmitt)                                                     | 0   | Disable<br>(CMOS)                                                                                     | 1<br>(0xff) | R/W      |                     |
| P0 Port<br>Interrupt Mask<br>Register<br>(P0_IMSK)        | 0x5205<br>(8 bits)        | D7–0       | P0IE[7:0]       | P0[7:0] port interrupt enable                | 1 | Enable                                                                  | 0   | Disable                                                                                               | 0           | R/W      |                     |
| P0 Port<br>Interrupt Edge<br>Select Register<br>(P0_EDGE) | 0x5206<br>(8 bits)        | D7–0       | P0EDGE[7:0]     | P0[7:0] port interrupt edge select           | 1 | Falling edge                                                            | 0   | Rising edge                                                                                           | 0           | R/W      |                     |
| P0 Port<br>Interrupt Flag<br>Register<br>(P0_IFLG)        | <b>0x5207</b><br>(8 bits) | D7–0       | P0IF[7:0]       | P0[7:0] port interrupt flag                  | 1 | Cause of<br>interrupt<br>occurred                                       | 0   | Cause of<br>interrupt not<br>occurred                                                                 | 0           | R/W      | Reset by writing 1. |
| P0 Port                                                   | 0x5208                    | D7         | -               | reserved                                     |   | -                                                                       | -   |                                                                                                       | -           | -        | 0 when being read.  |
| Filter Control<br>Register<br>(P0_CHAT)                   |                           |            |                 | P0[7:4] chattering filter time               |   | POCF2[2:0]<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0      |     | 6384/fpclk<br>8192/fpclk<br>4096/fpclk<br>2048/fpclk<br>1024/fpclk<br>512/fpclk<br>256/fpclk<br>None  | 0x0         | R/W      |                     |
|                                                           |                           | D3<br>D2–0 | –<br>P0CF1[2:0] | reserved<br>P0[3:0] chattering filter time   |   | -<br>POCF1[2:0]<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0 | 1   | Filter time<br>6384/fPCLK<br>8192/fPCLK<br>8192/fPCLK<br>2048/fPCLK<br>512/fPCLK<br>256/fPCLK<br>None | 0x0         | –<br>R/W | 0 when being read.  |
| P0 Port Key-                                              | 0x5209                    | D7–2       | -               | reserved                                     | Ē |                                                                         | -   |                                                                                                       | _           |          | 0 when being read.  |
| Entry Reset<br>Configuration<br>Register<br>(P0_KRST)     | (8 bits)                  | D1-0       |                 | P0 port key-entry reset<br>configuration     | P | 0KRST[1:0]<br>0x3<br>0x2<br>0x1<br>0x0                                  |     | onfiguration<br>P0[3:0] = 0<br>P0[2:0] = 0<br>P0[1:0] = 0<br>Disable                                  | 0x0         | R/W      |                     |
| P0 Port Input<br>Enable Register<br>(P0_IEN)              | <b>0x520a</b><br>(8 bits) | D7–0       | P0IEN[7:0]      | P0[7:0] port input enable                    | 1 | Enable                                                                  | 0   | Disable                                                                                               | 0xff        | R/W      |                     |
| P1 Port Input<br>Data Register<br>(P1_IN)                 | 0x5210<br>(8 bits)        | D7–0       | P1IN[7:0]       | P1[7:0] port input data                      | 1 | 1 (H)                                                                   | 0   | 0 (L)                                                                                                 | ×           | R        |                     |
| P1 Port Output<br>Data Register<br>(P1_OUT)               | 0x5211<br>(8 bits)        | D7–0       | P1OUT[7:0]      | P1[7:0] port output data                     | 1 | 1 (H)                                                                   | 0   | 0 (L)                                                                                                 | 0           | R/W      |                     |
| P1 Port<br>Output Enable<br>Register<br>(P1_OEN)          | 0x5212<br>(8 bits)        |            |                 | P1[7:0] port output enable                   |   | Enable                                                                  |     | Disable                                                                                               | 0           | R/W      |                     |
| P1 Port Pull-up<br>Control Register<br>(P1_PU)            | 0x5213<br>(8 bits)        | D7–0       | P1PU[7:0]       | P1[7:0] port pull-up enable                  | 1 | Enable                                                                  | 0   | Disable                                                                                               | 1<br>(0xff) | R/W      |                     |

#### 0x5214-0x5233

#### P Port & Port MUX

| Register name                                             | Address                   | Bit          | Name            | Function                                     | T  | Set                                                                | tin | 9                                                                                                                   | Init.       | R/W        | Remarks             |
|-----------------------------------------------------------|---------------------------|--------------|-----------------|----------------------------------------------|----|--------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------|-------------|------------|---------------------|
| P1 Port Schmitt                                           | 0x5214                    |              | P1SM[7:0]       | P1[7:0] port Schmitt trigger input           | 1  | Enable                                                             | _   | Disable                                                                                                             | 1           | R/W        |                     |
| Trigger Control<br>Register<br>(P1_SM)                    | (8 bits)                  |              |                 | enable                                       |    | (Schmitt)                                                          |     | (CMOS)                                                                                                              | (0xff)      |            |                     |
| P1 Port<br>Interrupt Mask<br>Register<br>(P1_IMSK)        | 0x5215<br>(8 bits)        |              | P1IE[7:0]       | P1[7:0] port interrupt enable                |    | Enable                                                             |     | Disable                                                                                                             | 0           | R/W        |                     |
| P1 Port<br>Interrupt Edge<br>Select Register<br>(P1_EDGE) | 0x5216<br>(8 bits)        | D7–0         | P1EDGE[7:0]     | P1[7:0] port interrupt edge select           | 1  | Falling edge                                                       | 0   | Rising edge                                                                                                         | 0           | R/W        |                     |
| P1 Port<br>Interrupt Flag<br>Register<br>(P1_IFLG)        | 0x5217<br>(8 bits)        | D7–0         | P1IF[7:0]       | P1[7:0] port interrupt flag                  | 1  | Cause of<br>interrupt<br>occurred                                  | 0   | Cause of<br>interrupt not<br>occurred                                                                               | 0           | R/W        | Reset by writing 1. |
| P1 Port                                                   | 0x5218                    | D7           | -               | reserved                                     | 1  | -                                                                  | -   |                                                                                                                     | -           | -          | 0 when being read.  |
| Chattering<br>Filter Control<br>Register<br>(P1_CHAT)     | (8 bits)                  | D6-4         | P1CF2[2:0]      | P1[7:4] chattering filter time               |    | P1CF2[2:0]<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0 | 1   | Filter time<br>6384/fPCLK<br>8192/fPCLK<br>4096/fPCLK<br>2048/fPCLK<br>1024/fPCLK<br>512/fPCLK<br>256/fPCLK<br>None | 0<br>0x0    | R/W<br>R/W |                     |
|                                                           |                           | D3           | -               | reserved                                     | +  | 0.00                                                               | _   | NULLE                                                                                                               | -           | _          | 0 when being read.  |
|                                                           |                           | D2-0         | P1CF1[2:0]      | P1[3:0] chattering filter time               |    | P1CF1[2:0]<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0 | 1   | Filter time<br>6384/fPCLK<br>8192/fPCLK<br>4096/fPCLK<br>2048/fPCLK<br>512/fPCLK<br>256/fPCLK<br>None               | 0x0         | R/W        |                     |
| D1 Devt Innut                                             | 0.5010                    | D7 0         | D11EN(7.0)      |                                              |    |                                                                    |     |                                                                                                                     | 0.4         | DAA        |                     |
| P1 Port Input<br>Enable Register<br>(P1_IEN)              | 0x521a<br>(8 bits)        | D7–0         | P1IEN[7:0]      | P1[7:0] port input enable                    | 1  | Enable                                                             | 0   | Disable                                                                                                             | Oxff        | R/W        |                     |
| P2 Port Input<br>Data Register<br>(P2_IN)                 | 0x5220<br>(8 bits)        | D7–0         | P2IN[7:0]       | P2[7:0] port input data                      | 1  | 1 (H)                                                              | 0   | 0 (L)                                                                                                               | ×           | R          |                     |
| P2 Port Output<br>Data Register<br>(P2_OUT)               | 0x5221<br>(8 bits)        | D7–0         | P2OUT[7:0]      | P2[7:0] port output data                     | 1  | 1 (H)                                                              | 0   | 0 (L)                                                                                                               | 0           | R/W        |                     |
| P2 Port<br>Output Enable<br>Register<br>(P2_OEN)          | 0x5222<br>(8 bits)        | D7–0         | P2OEN[7:0]      | P2[7:0] port output enable                   | 1  | Enable                                                             | 0   | Disable                                                                                                             | 0           | R/W        |                     |
| P2 Port Pull-up<br>Control Register<br>(P2_PU)            | 0x5223<br>(8 bits)        | D7–0         | P2PU[7:0]       | P2[7:0] port pull-up enable                  | 1  | Enable                                                             | 0   | Disable                                                                                                             | 1<br>(0xff) | R/W        |                     |
| P2 Port Schmitt<br>Trigger Control<br>Register<br>(P2_SM) | 0x5224<br>(8 bits)        | D7–0         | P2SM[7:0]       | P2[7:0] port Schmitt trigger input<br>enable | 1  | Enable<br>(Schmitt)                                                | 0   | Disable<br>(CMOS)                                                                                                   | 1<br>(0xff) | R/W        |                     |
| P2 Port Input<br>Enable Register<br>(P2_IEN)              | <b>0x522a</b><br>(8 bits) | D7–0         | P2IEN[7:0]      | P2[7:0] port input enable                    | 1  | Enable                                                             | 0   | Disable                                                                                                             | Oxff        | R/W        |                     |
| P3 Port Input<br>Data Register<br>(P3_IN)                 | 0x5230<br>(8 bits)        | D7–4<br>D3–0 | –<br>P3IN[3:0]  | reserved<br>P3[3:0] port input data          | 1  | 1 (H)                                                              | 0   | 0 (L)                                                                                                               | -<br>×      | –<br>R     | 0 when being read.  |
| P3 Port Output<br>Data Register<br>(P3_OUT)               | 0x5231<br>(8 bits)        | D7–4<br>D3–0 | –<br>P3OUT[3:0] | reserved<br>P3[3:0] port output data         | 1  | 1 (H)                                                              | 0   | 0 (L)                                                                                                               | _<br>0      | –<br>R/W   | 0 when being read.  |
| P3 Port<br>Output Enable                                  | 0x5232<br>(8 bits)        | D7–4<br>D3–0 |                 | reserved<br>P3[3:0] port output enable       | 1  | Enable                                                             | -   | Disable                                                                                                             | -<br>0      | –<br>R/W   | 0 when being read.  |
| Register<br>(P3_OEN)                                      |                           |              |                 |                                              | [  |                                                                    |     |                                                                                                                     |             | 1.7.7.4    |                     |
| P3 Port Pull-up                                           | 0x5233                    | D7-4         | -               | reserved                                     | -  | -                                                                  | -   | Disch!-                                                                                                             | -           | -          | 0 when being read.  |
| Control Register<br>(P3_PU)                               | (8 bits)                  | D3–0         | P3PU[3:0]       | P3[3:0] port pull-up enable                  | 11 | Enable                                                             | 0   | Disable                                                                                                             | 1<br>(0xff) | R/W        |                     |

# 0x5234-0x52a3

## P Port & Port MUX

| Register name   | Address  | Bit  | Name       | Function                           |   | Set       | tin      | g         | Init.  | R/W | Remarks            |
|-----------------|----------|------|------------|------------------------------------|---|-----------|----------|-----------|--------|-----|--------------------|
| P3 Port Schmitt | 0x5234   | D7–4 | -          | reserved                           | Γ |           | -        |           | -      | -   | 0 when being read. |
| Trigger Control | (8 bits) | D3–0 | P3SM[3:0]  | P3[3:0] port Schmitt trigger input | 1 | Enable    | 0        | Disable   | 1      | R/W | -                  |
| Register        |          |      |            | enable                             |   | (Schmitt) |          | (CMOS)    | (0xff) |     |                    |
| (P3_SM)         |          |      |            |                                    |   | · · ·     |          |           | · ·    |     |                    |
| P3 Port Input   | 0x523a   | D7–4 | -          | reserved                           |   |           | _        |           | -      | -   | 0 when being read. |
| Enable Register | (8 bits) | D3–0 | P3IEN[3:0] | P3[3:0] port input enable          | 1 | Enable    | 0        | Disable   | 0xff   | R/W |                    |
| (P3_IEN)        |          |      |            |                                    |   |           |          |           |        |     |                    |
| P0 Port         | 0x52a0   | D7–6 | -          | reserved                           |   |           | _        |           | -      | -   | 0 when being read. |
| Function Select | (8 bits) | D5   | P05MUX     | P05 port function select           | 1 | TOUTN4    | 0        | P05       | 0      | R/W |                    |
| Register        |          | D4   | P04MUX     | P04 port function select           | 1 | TOUT4     | 0        | P04       | 0      | R/W |                    |
| (P0_PMUX)       |          | D3   | P03MUX     | P03 port function select           | 1 | REMO      |          | P03       | 0      | R/W |                    |
|                 |          | D2   | P02MUX     | P02 port function select           | 1 | REMI      | 0        | P02       | 0      | R/W |                    |
|                 |          | D1–0 | -          | reserved                           |   |           | -        |           | -      | -   | 0 when being read. |
| P1 Port         | 0x52a1   | D7   | P17MUX     | P17 port function select           | 1 | #SPISS    | 0        | P17       | 0      | R/W |                    |
| Function Select | (8 bits) | D6   | P16MUX     | P16 port function select           | 1 | TOUT5     |          | P16/EXCL0 | 0      | R/W |                    |
| Register        |          | D5   |            | P15 port function select           | 1 | SCL       |          | P15       | 0      | R/W |                    |
| (P1_PMUX)       |          | D4   |            | P14 port function select           | 1 | SDA       |          | P14       | 0      | R/W |                    |
|                 |          | D3   |            | P13 port function select           | 1 | FOUT1     | -        | P13       | 0      | R/W |                    |
|                 |          | D2   | -          | P12 port function select           | 1 | SCLK1     |          | P12       | 0      | R/W |                    |
|                 |          | D1   |            | P11 port function select           | 1 | SOUT1     |          | P11       | 0      | R/W |                    |
|                 |          | D0   | P10MUX     | P10 port function select           | 1 | SIN1      | 0        | P10       | 0      | R/W |                    |
| P2 Port         | 0x52a2   | D7   | P27MUX     | P27 port function select           | 1 | TOUTN3    | 0        | P27       | 0      | R/W |                    |
| Function Select | (8 bits) | D6   | P26MUX     | P26 port function select           | 1 | TOUT3     | 0        | P26       | 0      | R/W | ]                  |
| Register        |          | D5   | P25MUX     | P25 port function select           | 1 | SCLK0     |          | P25       | 0      | R/W |                    |
| (P2_PMUX)       |          | D4   | P24MUX     | P24 port function select           | 1 | SOUT0     |          | P24       | 0      | R/W |                    |
|                 |          | D3   | P23MUX     | P23 port function select           | 1 | SIN0      |          | P23       | 0      | R/W |                    |
|                 |          | D2   | P22MUX     | P22 port function select           | 1 | SPICLK    |          | P22       | 0      | R/W |                    |
|                 |          | D1   | P21MUX     | P21 port function select           | 1 | SDO       |          | P21       | 0      | R/W |                    |
|                 |          | D0   | P20MUX     | P20 port function select           | 1 | SDI       | 0        | P20       | 0      | R/W |                    |
| P3 Port         | 0x52a3   | D7–4 | -          | reserved                           |   |           | -        |           | -      | -   | 0 when being read. |
| Function Select | (8 bits) | D3   | P33MUX     | P33 port function select           | 1 | P33       |          | DSIO      | 0      | R/W |                    |
| Register        |          | D2   |            | P32 port function select           | 1 | P32       |          | DST2      | 0      | R/W |                    |
| (P3_PMUX)       |          | D1   |            | P31 port function select           | 1 | P31       | <u> </u> | DCLK      | 0      | R/W |                    |
|                 |          | D0   | P30MUX     | P30 port function select           | 1 | FOUTH     | 0        | P30       | 0      | R/W |                    |

## 0x5300-0x530c

# PWM & Capture Timer Ch.0

| Register name    | Address   | Bit   | Name         | Function                   |    | Set        | ttin | g                                                    | Init. | R/W | Remarks             |
|------------------|-----------|-------|--------------|----------------------------|----|------------|------|------------------------------------------------------|-------|-----|---------------------|
| PWM Timer Ch.0   | 0x5300    | D15-0 | T16ECA[15:0] | Compare data A             | İ  | 0x0 t      | 0 0  | <fff< th=""><th>0x0</th><th>R/W</th><th></th></fff<> | 0x0   | R/W |                     |
| Compare Data     | (16 bits) |       |              | T16ECA15 = MSB             |    |            |      |                                                      |       |     |                     |
| A Register       | . ,       |       |              | T16ECA0 = LSB              |    |            |      |                                                      |       |     |                     |
| (T16E_CA0)       |           |       |              |                            |    |            |      |                                                      |       |     |                     |
| PWM Timer Ch.0   | 0x5302    | D15–0 | T16ECB[15:0] | Compare data B             |    | 0x0 t      | o 0; | dfff                                                 | 0x0   | R/W |                     |
| Compare Data     | (16 bits) |       |              | T16ECB15 = MSB             |    |            |      |                                                      |       |     |                     |
| B Register       | . ,       |       |              | T16ECB0 = LSB              |    |            |      |                                                      |       |     |                     |
| (T16E_CB0)       |           |       |              |                            |    |            |      |                                                      |       |     |                     |
| PWM Timer Ch.0   | 0x5304    | D15-0 | T16ETC[15:0] | Counter data               |    | 0x0 t      | 0 0  | dfff                                                 | 0x0   | R/W |                     |
| Counter Data     | (16 bits) |       |              | T16ETC15 = MSB             |    |            |      |                                                      |       |     |                     |
| Register         |           |       |              | T16ETC0 = LSB              |    |            |      |                                                      |       |     |                     |
| (T16E_TC0)       |           |       |              |                            |    |            |      |                                                      |       |     |                     |
| PWM Timer Ch.0   | 0x5306    | D15–9 | -            | reserved                   |    |            | -    |                                                      | -     | -   | 0 when being read.  |
| Control Register | (16 bits) | D8    | INITOL       | Initial output level       | 1  | High       | 0    | Low                                                  | 0     | R/W |                     |
| (T16E_CTL0)      | ŕ         | D7    | -            | reserved                   |    |            | _    |                                                      | _     | -   | 0 when being read.  |
|                  |           | D6    | SELFM        | Fine mode select           | 1  | Fine mode  |      | Normal mode                                          | 0     | R/W |                     |
|                  |           |       | CBUFEN       | Comparison buffer enable   | 1  | Enable     | -    | Disable                                              | 0     | R/W |                     |
|                  |           |       | INVOUT       | Inverse output             | 1  | Invert     |      | Normal                                               | 0     | R/W |                     |
|                  |           | -     |              | Input clock select         | 1  | External   |      | Internal                                             | 0     | R/W |                     |
|                  |           |       | OUTEN        | Clock output enable        | 1  | Enable     | 0    | Disable                                              | 0     | R/W |                     |
|                  |           |       | T16ERST      | Timer reset                | 1  | Reset      |      | Ignored                                              | 0     | W   | 0 when being read.  |
|                  |           |       | T16ERUN      | Timer run/stop control     | 1  | Run        | 0    | Stop                                                 | 0     | R/W |                     |
| PWM Timer Ch.0   | 0x5308    | D15–4 | -            | reserved                   |    |            | -    |                                                      | -     | -   | 0 when being read.  |
| Input Clock      | (16 bits) | D3–0  | T16EDF[3:0]  | Timer input clock select   | T1 | 6EDF[3:0]  |      | Clock                                                | 0x0   | R/W |                     |
| Select Register  |           |       |              | (Prescaler output clock)   |    | 0xf        |      | reserved                                             |       |     |                     |
| (T16E_CLK0)      |           |       |              |                            |    | 0xe        |      | LK-1/16384                                           |       |     |                     |
|                  |           |       |              |                            |    | 0xd<br>0xc |      | CLK-1/8192<br>CLK-1/4096                             |       |     |                     |
|                  |           |       |              |                            |    | 0xc<br>0xb |      | CLK-1/4096                                           |       |     |                     |
|                  |           |       |              |                            |    | 0xb<br>0xa |      | CLK-1/1024                                           |       |     |                     |
|                  |           |       |              |                            |    | 0x9        |      | CLK-1/512                                            |       |     |                     |
|                  |           |       |              |                            |    | 0x8        | Р    | CLK-1/256                                            |       |     |                     |
|                  |           |       |              |                            |    | 0x7        | Ρ    | CLK-1/128                                            |       |     |                     |
|                  |           |       |              |                            |    | 0x6        |      | PCLK-1/64                                            |       |     |                     |
|                  |           |       |              |                            |    | 0x5        |      | PCLK-1/32                                            |       |     |                     |
|                  |           |       |              |                            |    | 0x4        |      | PCLK-1/16                                            |       |     |                     |
|                  |           |       |              |                            |    | 0x3        |      | PCLK-1/8                                             |       |     |                     |
|                  |           |       |              |                            |    | 0x2<br>0x1 |      | PCLK-1/4<br>PCLK-1/2                                 |       |     |                     |
|                  |           |       |              |                            |    | 0x0        |      | PCLK-1/2                                             |       |     |                     |
| PWM Timer Ch.0   | 0x530a    | D15-2 |              | reserved                   | F  |            | _    |                                                      | _     |     | 0 when being read.  |
| Interrupt        | (16 bits) | 210 2 |              |                            |    |            |      |                                                      |       |     | s mon boing read.   |
| Mask Register    | ,)        | D1    | CBIE         | Compare B interrupt enable | 1  | Enable     | 0    | Disable                                              | 0     | R/W |                     |
| (T16E_IMSK0)     |           |       | CAIE         | Compare A interrupt enable |    | Enable     |      | Disable                                              | 0     | R/W |                     |
| PWM Timer Ch.0   | 0x530c    | D15-2 | _            | reserved                   | Ē  |            | _    | ·                                                    | _     | -   | 0 when being read.  |
| Interrupt        | (16 bits) | -     | CBIF         | Compare B interrupt flag   | 1  | Cause of   | 0    | Cause of                                             | 0     | R/W | Reset by writing 1. |
| Flag Register    | ,)        |       | -            |                            | 1. | interrupt  | 1    | interrupt not                                        | -     |     |                     |
| (T16E IFLG0)     |           | D0    | CAIF         | Compare A interrupt flag   |    | occurred   | 1    | occurred                                             | 0     | R/W |                     |

#### APPENDIX A I/O REGISTER LIST

# 0x5320-0x532c

# MISC Registers

| FLASHC/ 0x5320 D15-10 - reserved -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Init.                          | R/W                          | Remarks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -                              | -                            | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SRAMC Control (16 bits) D9-8 SRCYC[1:0] SRAMC access cycle SRCYC[1:0] Access cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x3                            | R/W                          | , in the second se |
| Register 0x3 5 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (MISC_FL) 0x2 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x1 3 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x0 2 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| D7–3 – reserved –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -                              | -                            | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| D2–0 FLCYC[2:0] FLASHC read access cycle FLCYC[2:0] Read cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x3                            | R/W                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x7–0x5 reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x4 1 cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x3 5 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x2 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x1 3 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x0 2 cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| OSC1 Peripheral 0x5322 D15-1 - reserved -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                              | -                            | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Control Register (16 bits) D0 O1DBG OSC1 peripheral control in debug 1 Run 0 Stop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0                              | R/W                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (MISC_OSC1) mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MISC Protect 0x5324 D15-0 PROT[15:0] MISC register write protect Writing 0x96 removes the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0                            | R/W                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register (16 bits) write protection of the MISC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (MISC_PROT) registers (0x5326–0x532a).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Writing another value set the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| write protection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| IRAM Size 0x5326 D15–9 – reserved –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -                              | -                            | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Select Register (16 bits) D8 DBADR Debug base address select 1 0x0 0 0xfffc00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                              | R/W                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (MISC_IRAMSZ) D7-2 - reserved -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -                              | -                            | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| D1-0 IRAMSZ[1:0] IRAM size select IRAMSZ[1:0] Read cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0                            | R/W                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x3 reseved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x2 reseved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x1 reseved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x0 reseved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x80                           | R/W                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Address Low (16 bits) D7–0 TTBR[7:0] Vector table base address A[7:0] 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0                            | R                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register (fixed at 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register     (fixed at 0)       (MISC_TTBRL)     (fixed at 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |                              | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Register<br>(MISC_TTBRL)         (fixed at 0)           Vector Table         0x532a         D15-8         -         reserved         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | -                              | -                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register<br>(MISC_TTBRL)         (fixed at 0)           Vector Table         0x532a         D15-8         -         reserved         -           Address High         (16 bits)         D7-0         TTBR[23:16]         Vector table base address         0x0-0xff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | _<br>0x0                       | –<br>R/W                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register<br>(MISC_TTBRL)       Ox532a       D15-8       -       reserved       -         Vector Table<br>Address High<br>Register       0x532a       D15-8       -       reserved       -         Address High<br>Register       (16 bits)       D7-0       TTBR[23:16]       Vector table base address       0x0-0xff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register<br>(MISC_TTBRL)       0x532a       D15-8       -       reserved       -         Address High<br>(MISC_TTBRH)       0x532a       D15-8       -       reserved       -         Address High<br>(MISC_TTBRH)       0.15-8       -       reserved       -       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register<br>(MISC_TTBRL)     0x532a     D15-8     -     reserved     -       Address High<br>Register<br>(MISC_TTBRH)     0x532a     D15-8     -     reserved     -       PSR Register     0x532c     D15-8     -     reserved     -       PSR Register     0x532c     D15-8     -     reserved     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0<br>_                       | R/W<br>_                     | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Register<br>(MISC_TTBRL)       0x532a       D15-8       -       reserved       -         Address High<br>Register<br>(MISC_TTBRH)       0x532a       D15-8       -       reserved       -         PSR Register<br>(MISC_PSR)       0x532c       D15-8       -       reserved       -         PSR Register<br>(MISC_PSR)       0x532c       D15-8       -       reserved       -         PSR Register<br>(MISC_PSR)       0x532c       D15-8       -       reserved       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0<br>-<br>0x0                | R/W<br>–<br>R                | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Register<br>(MISC_TTBRL)         0x532a         D15-8         -         reserved         -           Address High<br>Register<br>(MISC_TTBRH)         0x532a         D15-8         -         reserved         -         -           PSR Register<br>(MISC_PSR)         0x532c         D15-8         -         reserved         -         -           PSR Register<br>(MISC_PSR)         0x532c         D15-8         -         reserved         -         -           PSR Register<br>(MISC_PSR)         0x532c         D15-8         -         reserved         -         -           PSR Register<br>(MISC_PSR)         015-8         -         reserved         -         -         -           PSR Register<br>(MISC_PSR)         016 bits)         D15-8         -         reserved         -         -           PSR Register         016 bits)         D7-5         PSRIL[2:0]         PSR interrupt level (IL) bits         0x0 to 0x7           D4         PSRIE         PSR interrupt enable (IE) bit         1         1 (enable)         0         0 (disable) | 0x0<br>-<br>0x0<br>0           | R/W<br>–<br>R<br>R           | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Register<br>(MISC_TTBRL)         0x532a         D15-8         -         reserved         -           Address High<br>Register<br>(MISC_TTBRH)         (16 bits)         D7-0         TTBR[23:16]         Vector table base address<br>A[23:16]         0x0-0xff<br>Vector table base address<br>A[23:16]         0x0-0xff<br>Vector table base address<br>A[23:16]           PSR Register<br>(MISC_TTBRH)         0x532c<br>VECTTBRL)         D15-8         -         reserved         -           PSR Register<br>(MISC_PSR)         015-8         -         reserved         -         -           D7-5         PSRIL[2:0]         PSR interrupt level (IL) bits         0x0 to 0x7         -           D4         PSRIE         PSR interrupt enable (IE) bit         1         1 (enable)         0         0 (disable)           D3         PSRC         PSR carry (C) flag         1         1 (set)         0         0 (cleared)                                                                                                                                   | 0x0<br>-<br>0x0<br>0<br>0      | R/W<br>–<br>R<br>R<br>R      | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Register<br>(MISC_TTBRL)         Ox532a         D15-8         -         reserved         -           Address High<br>Register<br>(MISC_TTBRH)         (16 bits)         D15-8         -         reserved         -         -           PSR Register<br>(MISC_TTBRH)         0x532c         D15-8         -         reserved         -         -           PSR Register<br>(MISC_PSR)         0x532c         D15-8         -         reserved         -         -           D7-0         TTBR[23:16]         Vector table base address<br>A[23:16]         0x0-0xff         -         -           PSR Register<br>(MISC_PSR)         0x532c         D15-8         -         reserved         -         -           D7-5         PSRIL[2:0]         PSR interrupt level (IL) bits         0x0 to 0x7         -         -           D4         PSRIE         PSR carry (C) flag         1         1 (set)         0         0 (cleared)           D2         PSRV         PSR overflow (V) flag         1         1 (set)         0         0 (cleared)                       | 0x0<br>-<br>0x0<br>0<br>0<br>0 | R/W<br>–<br>R<br>R<br>R<br>R | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Register<br>(MISC_TTBRL)         0x532a         D15-8         -         reserved         -           Address High<br>Register<br>(MISC_TTBRH)         (16 bits)         D7-0         TTBR[23:16]         Vector table base address<br>A[23:16]         0x0-0xff<br>Vector table base address<br>A[23:16]         0x0-0xff<br>Vector table base address<br>A[23:16]           PSR Register<br>(MISC_TTBRH)         0x532c<br>VECTTBRL)         D15-8         -         reserved         -           PSR Register<br>(MISC_PSR)         015-8         -         reserved         -         -           D7-5         PSRIL[2:0]         PSR interrupt level (IL) bits         0x0 to 0x7         -           D4         PSRIE         PSR interrupt enable (IE) bit         1         1 (enable)         0         0 (disable)           D3         PSRC         PSR carry (C) flag         1         1 (set)         0         0 (cleared)                                                                                                                                   | 0x0<br>-<br>0x0<br>0<br>0      | R/W<br>–<br>R<br>R<br>R      | 0 when being read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# 0x5340-0x5346

## Remote Controller

| Register name    | Address   | Bit    | Name        | Function                           |   | Set        | ting | 9                      | Init. | R/W | Remarks             |
|------------------|-----------|--------|-------------|------------------------------------|---|------------|------|------------------------|-------|-----|---------------------|
| REMC             | 0x5340    | D15–12 | CGCLK[3:0]  | Carrier generator clock select     |   | CGCLK[3:0] |      |                        | 0x0   | R/W |                     |
| Configuration    | (16 bits) | -      |             | (Prescaler output clock)           |   | CCLK[3:0]  |      | Clock                  |       |     |                     |
| Register         | . ,       |        |             |                                    |   | Oxf        |      | reserved               |       |     |                     |
| (REMC_CFG)       |           |        |             |                                    |   | 0xe        | PC   | CLK-1/16384            |       |     |                     |
|                  |           |        |             |                                    |   | 0xd        |      | CLK-1/8192             |       |     |                     |
|                  |           |        |             |                                    |   | 0xc        |      | CLK-1/4096             |       |     |                     |
|                  |           |        |             |                                    |   | 0xb        |      | CLK-1/2048             |       |     |                     |
|                  |           |        |             |                                    |   | 0xa        |      | CLK-1/1024             |       |     |                     |
|                  |           |        |             |                                    |   | 0x9        |      | CLK-1/512              |       |     |                     |
|                  |           | D11-8  | LCCLK[3:0]  | Length counter clock select        | 1 | 0x8        |      | CLK-1/256              | 0x0   | R/W |                     |
|                  |           |        |             | (Prescaler output clock)           |   | 0x7        |      | PCLK-1/128             |       |     |                     |
|                  |           |        |             | , , , , ,                          |   | 0x6        |      | PCLK-1/64<br>PCLK-1/32 |       |     |                     |
|                  |           |        |             |                                    |   | 0x5<br>0x4 |      | PCLK-1/32<br>PCLK-1/16 |       |     |                     |
|                  |           |        |             |                                    |   | 0x4<br>0x3 |      | PCLK-1/18              |       |     |                     |
|                  |           |        |             |                                    |   | 0x2        |      | PCLK-1/4               |       |     |                     |
|                  |           |        |             |                                    |   | 0x1        |      | PCLK-1/2               |       |     |                     |
|                  |           |        |             |                                    |   | 0x0        |      | PCLK-1/1               |       |     |                     |
|                  |           | D7–2   | -           | reserved                           |   | -          | -    |                        | -     | -   | 0 when being read.  |
|                  |           | D1     | REMMD       | REMC mode select                   |   | Receive    |      | Transmit               | 0     | R/W |                     |
|                  |           | D0     | REMEN       | REMC enable                        | 1 | Enable     | 0    | Disable                | 0     | R/W |                     |
| REMC Carrier     | 0x5342    | D15–14 | -           | reserved                           |   | -          | -    |                        | -     | -   | 0 when being read.  |
| Length Setup     | (16 bits) | D13-8  | REMCL[5:0]  | L carrier length setup             |   | 0x0 to     | 0 0  | k3f                    | 0x0   | R/W |                     |
| Register         |           | D7–6   | -           | reserved                           |   | -          | -    |                        | -     | -   | 0 when being read.  |
| (REMC_CAR)       |           | D5–0   | REMCH[5:0]  | H carrier length setup             |   | 0x0 to     | o 0: | k3f                    | 0x0   | R/W |                     |
| REMC Length      | 0x5344    | D15-8  | REMLEN[7:0] | Transmit/receive data length count |   | 0x0 t      | o 0  | xff                    | 0x0   | R/W |                     |
| Counter Register | (16 bits) |        |             | (down counter)                     |   |            |      |                        |       |     |                     |
| (REMC_LCNT)      |           | D7–1   | -           | reserved                           |   | -          | -    |                        | -     | -   | 0 when being read.  |
|                  |           | D0     | REMDT       | Transmit/receive data              | 1 | 1 (H)      | 0    | 0 (L)                  | 0     | R/W |                     |
| REMC Interrupt   | 0x5346    | D15–11 | -           | reserved                           |   | -          | -    |                        | -     | -   | 0 when being read.  |
| Control Register | (16 bits) | D10    | REMFIF      | Falling edge interrupt flag        | 1 | Cause of   | 0    | Cause of               | 0     | R/W | Reset by writing 1. |
| (REMC_INT)       |           | D9     | REMRIF      | Rising edge interrupt flag         | 1 | interrupt  |      | interrupt not          | 0     | R/W |                     |
|                  |           | D8     | REMUIF      | Underflow interrupt flag           | 1 | occurred   |      | occurred               | 0     | R/W | 1                   |
|                  |           | D7–3   | -           | reserved                           |   | -          | -    |                        | -     | -   | 0 when being read.  |
|                  |           | D2     | REMFIE      | Falling edge interrupt enable      |   | Enable     | 0    | Disable                | 0     | R/W |                     |
|                  |           | D1     | REMRIE      | Rising edge interrupt enable       |   | Enable     | 0    | Disable                | 0     | R/W |                     |
|                  |           | D0     | REMUIE      | Underflow interrupt enable         | 1 | Enable     | 0    | Disable                | 0     | R/W |                     |

#### APPENDIX A I/O REGISTER LIST

# 0x5360-0x536c

# PWM & Capture Timer Ch.1

| Register name    | Address   | Bit   | Name         | Function                   |               | Setting    |      |                          | Init. | R/W      | Remarks                 |
|------------------|-----------|-------|--------------|----------------------------|---------------|------------|------|--------------------------|-------|----------|-------------------------|
| PWM Timer Ch.1   | 0x5360    | D15–0 | T16ECA[15:0] | Compare data A             |               | 0x0 to     | o 0: | kffff                    | 0x0   | R/W      |                         |
| Compare Data     | (16 bits) |       |              | T16ECA15 = MSB             |               |            |      |                          |       |          |                         |
| A Register       |           |       |              | T16ECA0 = LSB              |               |            |      |                          |       |          |                         |
| (T16E_CA1)       |           |       |              |                            |               |            |      |                          |       |          |                         |
| PWM Timer Ch.1   | 0x5362    | D15-0 | T16ECB[15:0] | Compare data B             | 0x0 to 0xffff |            | kfff | 0x0                      | R/W   |          |                         |
| Compare Data     | (16 bits) |       |              | T16ECB15 = MSB             |               |            |      |                          |       |          |                         |
| B Register       |           |       |              | T16ECB0 = LSB              |               |            |      |                          |       |          |                         |
| (T16E_CB1)       |           |       |              |                            |               |            |      |                          |       |          |                         |
| PWM Timer Ch.1   | 0x5364    | D15-0 | T16ETC[15:0] | Counter data               |               | 0x0 to     | o 0: | kffff                    | 0x0   | R/W      |                         |
| Counter Data     | (16 bits) |       |              | T16ETC15 = MSB             |               |            |      |                          |       |          |                         |
| Register         |           |       |              | T16ETC0 = LSB              |               |            |      |                          |       |          |                         |
| (T16E_TC1)       |           |       |              |                            |               |            |      |                          |       |          |                         |
| PWM Timer Ch.1   | 0x5366    | D15–9 | -            | reserved                   |               |            | _    |                          | -     | -        | 0 when being read.      |
| Control Register | (16 bits) | D8    |              | Initial output level       | 1             | High       | 0    | Low                      | 0     | R/W      |                         |
| (T16E_CTL1)      |           | D7    |              | reserved                   |               |            |      |                          | -     | -        | 0 when being read.      |
|                  |           | D6    |              | Fine mode select           |               | Fine mode  |      | Normal mode              | 0     | R/W      |                         |
|                  |           | D5    |              | Comparison buffer enable   | <u> </u>      | Enable     |      | Disable                  | 0     | R/W      |                         |
|                  |           | D4    |              | Inverse output             |               | Invert     | _    | Normal                   | 0     | R/W      |                         |
|                  |           | D3    |              | Input clock select         | _             | External   | _    | Internal                 | 0     | R/W      |                         |
|                  |           | D2    |              | Clock output enable        | _             | Enable     | 0    | Disable                  | 0     | R/W      | O uch an h air a na a d |
|                  |           | D1    |              | Timer reset                |               | Reset      | 0    | Ignored                  | 0     | W<br>R/W | 0 when being read.      |
|                  |           |       |              | Timer run/stop control     |               | Run        | 0    | Stop                     |       |          |                         |
| PWM Timer Ch.1   | 0x5368    | D15-4 |              | reserved                   |               |            | _    |                          | -     | -        | 0 when being read.      |
| Input Clock      | (16 bits) | D3–0  |              | Timer input clock select   | 11            | 6EDF[3:0]  |      | Clock                    | 0x0   | R/W      |                         |
| Select Register  |           |       |              | (Prescaler output clock)   |               | 0xf<br>0xe |      | reserved                 |       |          |                         |
| (T16E_CLK1)      |           |       |              |                            |               | 0xe<br>0xd |      | LK-1/16384<br>CLK-1/8192 |       |          |                         |
|                  |           |       |              |                            |               | 0xc        |      | CLK-1/4096               |       |          |                         |
|                  |           |       |              |                            |               | 0xb        |      | CLK-1/2048               |       |          |                         |
|                  |           |       |              |                            |               | 0xa        |      | CLK-1/1024               |       |          |                         |
|                  |           |       |              |                            |               | 0x9        | Р    | CLK-1/512                |       |          |                         |
|                  |           |       |              |                            |               | 0x8        | Р    | CLK-1/256                |       |          |                         |
|                  |           |       |              |                            |               | 0x7        |      | CLK-1/128                |       |          |                         |
|                  |           |       |              |                            |               | 0x6        |      | CLK-1/64                 |       |          |                         |
|                  |           |       |              |                            |               | 0x5        |      | PCLK-1/32                |       |          |                         |
|                  |           |       |              |                            |               | 0x4<br>0x3 |      | PCLK-1/16<br>PCLK-1/8    |       |          |                         |
|                  |           |       |              |                            |               | 0x3<br>0x2 |      | PCLK-1/6<br>PCLK-1/4     |       |          |                         |
|                  |           |       |              |                            |               | 0x1        |      | PCLK-1/2                 |       |          |                         |
|                  |           |       |              |                            |               | 0x0        |      | PCLK-1/1                 |       |          |                         |
| PWM Timer Ch.1   | 0x536a    | D15–2 | _            | reserved                   |               | ·          | _    |                          | _     | -        | 0 when being read.      |
| Interrupt        | (16 bits) |       |              |                            |               |            |      |                          |       |          |                         |
| Mask Register    | . ,       | D1    | CBIE         | Compare B interrupt enable | 1             | Enable     | 0    | Disable                  | 0     | R/W      |                         |
| (T16E_IMSK1)     |           | D0    | CAIE         | Compare A interrupt enable | 1             | Enable     | 0    | Disable                  | 0     | R/W      |                         |
| PWM Timer Ch.1   | 0x536c    | D15–2 | -            | reserved                   |               |            | -    |                          | -     | -        | 0 when being read.      |
| Interrupt        | (16 bits) | D1    | CBIF         | Compare B interrupt flag   | 1             | Cause of   | 0    | Cause of                 | 0     | R/W      | Reset by writing 1.     |
| Flag Register    |           | D0    | CAIF         | Compare A interrupt flag   |               | interrupt  |      | interrupt not            | 0     | R/W      |                         |
| (T16E_IFLG1)     |           | 20    |              | Compare A interrupt hay    |               | occurred   |      | occurred                 | 0     | 10,00    |                         |

# 0xffff84–0xffffd0

## S1C17 Core I/O

| Register name                      | Address              | Bit    | Name        | Function                                      | Setting  |                 |      | Init.        | R/W        | Remarks                  |                     |
|------------------------------------|----------------------|--------|-------------|-----------------------------------------------|----------|-----------------|------|--------------|------------|--------------------------|---------------------|
| Processor ID<br>Register<br>(IDIR) | 0xffff84<br>(8 bits) | D7–0   | IDIR[7:0]   | Processor ID<br>0x10: S1C17 Core              | 0x10     |                 |      | 0x10         | R          |                          |                     |
| Debug RAM                          | 0xffff90             | D31–24 |             | Unused (fixed at 0)                           |          | 0x0             |      |              | 0x0        | R                        |                     |
| Base Register<br>(DBRAM)           | (32 bits)            | D23–0  | DBRAM[23:0] | Debug RAM base address                        |          | 0x2             | 2fc0 | )            | 0x2f<br>c0 | R                        |                     |
| Debug Control                      | 0xffffa0             | D7     | IBE4        | Instruction break #4 enable                   | 1        | Enable          | 0    | Disable      | 0          | R/W                      |                     |
| Register                           | (8 bits)             |        | IBE3        | Instruction break #3 enable                   | _        | Enable          | -    | Disable      | 0          | R/W                      |                     |
| (DCR)                              |                      |        | IBE2        | Instruction break #2 enable                   | -        | Enable          | -    | Disable      | 0          | R/W                      |                     |
|                                    |                      |        | DR          | Debug request flag                            | · ·      | Occurred        | -    | Not occurred | -          |                          | Reset by writing 1. |
|                                    |                      |        | IBE1        | Instruction break #1 enable                   |          | Enable          |      | Disable      | 0          | R/W                      |                     |
|                                    |                      |        | IBE0        | Instruction break #0 enable                   | 1        | Enable          | 0    | Disable      | 0          | R/W                      |                     |
|                                    |                      | D1     | SE          | Single step enable                            | 1        | Enable          | 0    | Disable      | 0          | R/W                      |                     |
|                                    |                      | D0     | DM          | Debug mode                                    | 1        | Debug mode      | 0    | User mode    | 0          | R                        |                     |
| Instruction                        | 0xffffb8             | D31–24 | -           | reserved                                      |          | -               | -    |              | -          | -                        | 0 when being read.  |
| Break Address                      | (32 bits)            | D23–0  |             | Instruction break address #2                  |          | 0x0 to          | 0x   | ffffff       | 0x0        | R/W                      |                     |
| Register 2<br>(IBAR2)              |                      |        |             | IBAR223 = MSB<br>IBAR20 = LSB                 |          |                 |      |              |            |                          |                     |
| Instruction                        | 0xffffbc             | D31-24 | -           | reserved                                      | Γ        | -               | -    |              | -          | -                        | 0 when being read.  |
| Break Address                      | (32 bits)            | D23–0  | IBAR3[23:0] | Instruction break address #3                  |          | 0x0 to          | 0x   | ffffff       | 0x0        | R/W                      |                     |
| Register 3<br>(IBAR3)              |                      |        |             | IBAR323 = MSB<br>IBAR30 = LSB                 |          |                 |      |              |            |                          |                     |
| <u> </u>                           | 0xffffd0             | D31-24 |             |                                               | <u> </u> |                 |      |              |            | O with a set in a second |                     |
| Instruction<br>Break Address       | (32 bits)            |        |             | reserved                                      | -        | -               |      |              | -          | -                        | 0 when being read.  |
| Break Address<br>Register 4        | (32 DIIS)            | D23–0  |             | Instruction break address #4<br>IBAB423 = MSB |          | 0x0 to 0xffffff |      | mmf          | 0x0        | R/W                      |                     |
| (IBAR4)                            |                      |        |             | IBAR423 = MSB<br>IBAR40 = LSB                 |          |                 |      |              |            |                          |                     |

# **Appendix B Flash Memory Programming**

Flash memory programming consists of programming via a debugger using the flash programer function possessed by ICDs (in-circuit debuggers) such as the S5U1C17001H (ICD Mini) or self-programming via user programs.

# **B.1 Debugger Programming**

The debuggers included in the S1C17 Family C compiler packages provide functions that allow an ICD (e.g., S5U1C17001H) to be used as a flash programer.



Figure B.1.1: Flash memory programming system using debugger

To program S1C17702 flash memory using this function, you must install a 4-pin connector on the target board to connect the ICD (e.g., S5U1C17001H).

Connect a 4-pin connector using the S1C17702 DCLK (P31), DST2 (P32), and DSIO (P33) pins as debugging pins. (Note that this means P31 to P33 general input/output ports cannot be used.)

For more information on flash memory programming using this system, refer to the manual for the S1C17 Family C compiler package (e.g., S5U1C17001H). For more information on the 4-pin connector pin layout, refer to the ICD (e.g., S5U1C17001H) manual.

# **B.2 Self-programming via User Programs**

The S1C17702 includes self-programming functions for erasing and overwriting flash memory by user programs executed while operating on the target board. A separately provided self-programming package provides function routines as object files for self-programming. Self-programming functions are easily added by linking these objects to user application programs. For more information, see the self-programming package manual.

# **Appendix C Power Saving**

Current consumption will vary dramatically, depending on CPU operating mode, operation clock frequency, and the peripheral circuits being operated. Listed below are the control methods for saving power.

# C.1 Clock Control Power Saving

Figure C.1.1 illustrates the S1C17702 clock system.



Figure C.1.1 Clock system

#### APPENDIX C POWER SAVING

This section describes clock systems that can be controlled via software and power-saving control details. For more information on control registers and control methods, refer to the respective module sections.

### System SLEEP (All clocks stopped)

• Execute slp instruction

Execute the slp instruction when the entire system can be stopped. The CPU switches to SLEEP mode and the system clocks stop. This also stops all peripheral circuits using clocks. Starting up the CPU from SLEEP mode is therefore limited to startup using ports (described later).

### System clocks

• Clock source selection (OSC module)

Select between IOSC/OSC3 and OSC1 for the system clock source. Reduce current consumption by selecting the OSC1 clock when low-speed processing is possible.

• IOSC/OSC3 oscillator circuit stop (OSC module)

Operate the oscillator circuit comprising the system clock source. Where possible, stop the other circuit. You can reduce current consumption by using OSC1 as the system clock and stopping the IOSC/OSC3 oscillator circuit.

## **CPU clock (CCLK)**

• Execute the halt instruction

Execute the halt instruction when program execution by the CPU is not required—for example, when only the display is required or for interrupt standby. The CPU switches to HALT mode and suspends operations, but the peripheral circuits maintain the status in place at the time of the halt instruction, enabling use of peripheral circuits for timers and interrupts. You can reduce power consumption even further by suspending unnecessary peripheral circuits before executing the halt instruction. The CPU is started from HALT mode using the port or interrupts from the peripheral circuit operating in HALT mode.

• Low-speed clock gear selection (CLG module)

The CLG module can reduce CPU clock speeds to between 1/1 and 1/8 of the system clock via the clock gear settings. Reduce current consumption by operating the CPU at the minimum speed required for applications.

## Peripheral clock (PCLK)

• PCLK stop (CLG module)

Stop the PCLK clock feed from the CLG to peripheral circuits if none of the following peripheral circuits is required.

Peripheral circuits operating with PCLK

- Prescaler (PWM & capture timer, remote controller, P port)
- UART
- 8-bit time Ch.0 to Ch.1
- 16-bit timer Ch.0 to Ch.2
- SPI
- I<sup>2</sup>C
- SVD circuit
- Power supply control circuit
- P port and port MUX (control register, chattering filter)
- · PWM & capture timer
- MISC register
- · Remote controller

The peripheral modules listed below are operated by clocks other than PCLK. This means PCLK is not required.

- Clock timer
- Stopwatch timer
- Watchdog timer
- 8-bit OSC1 timer

The peripheral modules shown below require PCLK only when accessing the control register. PCLK is not required after the control register has been set and operations have begun.

• LCD driver

Table C.1.1 shows a list of methods for clock control and starting/stopping the CPU.

| Current consumption | OSC1                        | OSC3                        | CPU (CCLK)              | PCLK<br>peripheral | OSC1<br>peripheral | CPU stop<br>method                | CPU startup<br>method |  |  |  |  |
|---------------------|-----------------------------|-----------------------------|-------------------------|--------------------|--------------------|-----------------------------------|-----------------------|--|--|--|--|
| ↑<br>Low            | Stop                        | Stop                        | Stop                    | Stop               | Stop               | Execute <b>s1p</b><br>instruction | 1                     |  |  |  |  |
|                     | Oscillation<br>(system CLK) | Stop                        | Stop                    | Stop               | Operation          | Execute halt<br>instruction       | 1, 2                  |  |  |  |  |
|                     | Oscillation<br>(system CLK) | Stop                        | Stop                    | Operation          | Operation          | Execute halt<br>instruction       | 1, 2, 3               |  |  |  |  |
|                     | Oscillation                 | Stop                        | Operation(1/1)          | Operation          | Operation          |                                   |                       |  |  |  |  |
|                     | Oscillation                 | Oscillation<br>(system CLK) | Stop                    | Operation          | Operation          | Execute halt<br>instruction       | 1, 2, 3               |  |  |  |  |
|                     | Oscillation                 | Oscillation<br>(system CLK) | Operation<br>(Low gear) | Operation          | Operation          |                                   |                       |  |  |  |  |
| High<br>↓           | Oscillation                 | Oscillation<br>(system CLK) | Operation(1/1)          | Operation          | Operation          |                                   |                       |  |  |  |  |

Table C.1.1: Clock control list

HALT and SLEEP mode clearing methods (CPU startup method)

- Startup by port Started up by input/output port interrupt and debug interrupt (ICD forced break).
- Startup by OSC1 peripheral circuit Started up by clock timer, stopwatch timer, watchdog timer, 8-bit OSC1 timer, or LCD driver interrupts.
- 3. Startup by PCLK peripheral circuit Started up by PCLK peripheral circuit interrupt.

# C.2 Reducing Power Consumption via Power Supply Control

The available power supply controls are listed below.

#### Internal voltage regulator

- Setting the internal operating voltage VD1 to 2.5 V increases current consumption. For normal operations, set VD1 to 1.8 V, and switch to 2.5 V only for flash memory programming.
- Note that turning on internal voltage regulator heavy load protection will increase current consumption. Turn off heavy load protection for normal operations. Turn on only if operations are unstable.

### LCD voltage regulator

- Turning on the power supply voltage booster circuit will increase current consumption. Turn off the power supply voltage booster circuit if the power supply voltage VDD is 2.5 V or more. Use VDD to drive the LCD voltage regulator. Use the power supply voltage booster circuit only if VDD is less than 2.5 V.
- Turning on the LCD voltage regulator heavy load protection will increase current consumption. Turn off heavy load protection for normal operations. Turn on only if the display is unstable.
- If no LCD display is being used, turn off the LCD driver and the power supply voltage booster circuit.

### Power supply voltage detection (SVD) circuit

• Operating the SVD circuit will increase current consumption. Turn off power supply voltage detection unless it is required.

# **Appendix D** Mounting Precautions

This section describes various precautions for circuit board design and IC mounting.

#### **Oscillator circuit**

- Oscillation characteristics depend on factors such as components used (oscillator, Rf, CG, CD) and circuit board patterns. In particular, with ceramic or crystal oscillators, select the appropriate external resistors (Rf,) and capacitors (CG, CD) only after fully evaluating components actually mounted on the circuit board.
- Oscillator clock disturbances caused by noise may cause malfunctions. To prevent such disturbances, consider the following points. The latest devices, in particular, are manufactured by microscopic processes, making them especially susceptible to noise.

Areas in which noise countermeasures are especially important include the OSC2 pin and related circuit components and wiring. OSC1 pin handling is equally important. The noise precautions required for the OSC1 and OSC2 pins are described below.

We also recommend applying similar noise countermeasures to high-speed oscillator circuits, such as the OSC3 and OSC4 pins and wiring.

- (1) Components such as oscillators, resistors, and capacitors connected to the OSC1 (OSC3) and OSC2 (OSC4) pins should have the shortest connections possible.
- (2) Wherever possible, avoid locating digital signal lines within 3 mm of the OSC1 (OSC3) and OSC2 (OSC4) pins or related circuit components and wiring. Rapidly-switching signals, in particular, should be kept at a distance from these components. Since the spacing between layers of multi-layer printed circuit boards is a mere 0.1 mm to 0.2 mm, the above precautions also apply when positioning digital signal lines on other layers.

Never place digital signal lines alongside such components or wiring, even if more than 3 mm distance or located on other layers. Avoid crossing wires.

(3) Use Vss to shield OSC1 (OSC3) and OSC2 (OSC4) pins and related wiring (including wiring for adjacent circuit board layers).
Layers wired should be adequately shielded as shown to the right.
Fully ground adjacent layers, where possible. At minimum, shield the area at least 5 mm around the above pins and wiring.
Even after implementing these precautions, avoid configuring digital signal lines in parallel, as described in (2) above. Avoid crossing even on discrete layers, except for lines carrying signals with low switching frequencies.



(4) After implementing these precautions, check the output clock waveform by running the actual application program within the product.

Use an oscilloscope to check outputs from the FOUT1 and FOUTH pins.

You can check the quality of the OSC3 output waveform via the FOUTH output. Confirm that the frequency is as designed, is free of noise, and has minimal jitter.

You can check the quality of the OSC1 waveform via the FOUT1 output. In particular, enlarge the areas before and after the clock rising and falling edges and take special care to confirm that the regions approximately 100 ns to either side are free of clock or spiking noise.

Failure to observe precautions (1) to (3) adequately may lead to jitter in the OSC3 output and noise in the OSC1 output. Jitter in the OSC3 output will reduce operating frequencies, while noise in the OSC1 output will destabilize timers operated by the OSC1 clock as well as CPU core operations when the system clock switches to OSC1.

### **Reset circuit**

- The reset signal input to the #RESET pin when power is turned on will vary, depending on various factors, such as power supply start-up time, components used, and circuit board patterns. Constants such as capacitance and resistance should be determined through thorough testing with real-world products. Account for resistance fluctuations when setting the #RESET pin pull-up resistance for constants settings.
- Components such as capacitors and resistors connected to the #RESET pin should have the shortest connections possible to prevent noise-induced resets.

### Power supply circuit

Sudden power supply fluctuations due to noise will cause malfunctions. Consider the following issues.

- (1) Connections from the power supply to the VDD and VSS pins should be implemented via the shortest, thickest patterns possible.
- (2) If a bypass capacitor is connected between VDD and VSS, connections between the VDD and VSS pins should be as short as possible.



#### Signal line location

- To prevent electromagnetically-induced noise arising from mutual induction large-current signal lines should not be positioned close to circuits susceptible to noise, such as oscillators.
- Locating signal lines in parallel over significant distances or crossing signal lines operating at high speed will cause malfunctions due to noise generated by mutual interference.

Specifically, avoid positioning crossing signal lines operating at high speed close to circuits susceptible to noise, such as oscillators.



## Noise-induced malfunctions

Check the following three points if you suspect the presence of noise-induced IC malfunctions.

(1) DSIO pin

Low-level noise to this pin will cause a switch to Debug mode. The switch to Debug mode can be confirmed by the clock output from DCLK and a High signal from the DST2 pin.

For the product version, we recommend connecting the DSIO pin directly to HVDD or pulling up the DISO pin using a resistor not exceeding 10 k $\Omega$ .

The IC includes an internal pull-up resistor. The resistor has a relatively high impedance of 100 k $\Omega$  to 500 k $\Omega$  and is not noise-resistant.

(2) #RESET pin

Low-level noise to this pin will reset the IC. Depending on the input waveform, the reset may not proceed correctly.

This is more likely to occur if, due to circuit design choices, the impedance is high when the reset input is High.

(3) VDD and Vss power supply

The IC will malfunction the instant noise falling below the rated voltage is input.

Incorporate countermeasures on the circuit board, including close patterns for circuit board power supply circuits, noise-filtering decoupling capacitors, and surge/noise prevention components on the power supply line.

Perform the inspections described above using an oscilloscope capable of observing waveforms of at least 200 MHz. It may not be possible to observe high-speed noise events with a low-speed oscilloscope.

If you detect potential noise-induced malfunctions while observing the waveform with an oscilloscope, recheck with a low-impedance (less than 1 k $\Omega$ ) resistor connecting the relevant pin to GND or to the power supply. Malfunctions at that pin are likely if changes are visible, such as the malfunction disappearing, becoming less frequent, or the phenomena changing.

The DSIO and #RESET input circuits described above detect input signal edges and are susceptible to malfunctions induced by spike noise. This makes these digital signal pins the most susceptible to noise. To reduce potential noise, keep the following two points in mind when designing circuit boards:

- (A) It is important to use low impedance resistors when driving the signals, as described above. Avoid connecting impedance exceeding 1 k $\Omega$  (ideally, 0  $\Omega$ ) to the power supply or GND. The signal lines connected should be no longer than approximately 5 mm.
- (B) Signals switching from 1 to 0 or 0 to 1 may generate noise if signal lines run parallel to other digital lines on the circuit board.

The highest risk of noise occurs in configurations in which a line is sandwiched between multiple signal lines that vary in synchrony. You can minimize noise effects by reducing the length of parallel sections (limit to a few cm) or by increasing the separation (to at least 2 mm).

### Handling of light (for bare chip mounting)

The characteristics of semiconductor components can vary when exposed to light. ICs may malfunction or nonvolatile memory data may be corrupted if ICs are exposed to light.

Consider the following precautions for circuit boards and products in which this IC is mounted to prevent IC malfunctions attributable to light exposure.

- (1) Design and mount the product so that the IC is shielded from light during use.
- (2) Shield the IC from light during inspection processes.
- (3) Shield the IC on the upper, underside, and side faces of the IC chip.
- (4) Mount the IC chip within one week of opening the package. If the IC chip must be stored before mounting, take measures to ensure light shielding.
- (5) Adequate evaluations are required to assess nonvolatile memory data retention characteristics before product delivery if the product is subjected to heat stress exceeding regular reflow conditions during mounting processes.

#### **Miscellaneous**

This product series is manufactured using 0.25 µm microscopic processes.

Although it is designed to ensure basic IC reliability meeting EIAJ and MIL standards, consider the following points when mounting the product.

All oscillator circuit input/output pins use direct connections to internal 0.25 µm transistors. In addition to physical damage during mounting, minor variations over time may result in electrical damage arising from disturbances in the form of voltages exceeding the absolute maximum rating (2.5 V). The following factors can give rise to these variations:

- (1) electromagnetically-induced noise from industrial power supplies used in mounting reflow, reworking after mounting, and individual characteristic evaluation (testing) processes;
- (2) electromagnetically-induced noise from a solder iron when soldering.

In particular, during soldering, take care to ensure that the soldering iron GND (tip potential) has the same potential as the IC GND.

# **Appendix E** Initialization Routine

This section lists typical vector tables and initialization routines.

#### boot.s

```
.org
      0x8000
.section .rodata
                                                               ...(1)
Vector table
 ______
                    ; interrupt vector interrupt
                    ; number
                               offset source
                               0 \times 00
.long BOOT
                   ; 0x00
                                    reset
                                                               ...(2)
.long unalign_handler ; 0x01
                               0x04
                                    unalign
                  ; 0x02
.long nmi_handler
                                    NMI
                               0 \times 0 8
                  ; 0x03
.long int03_handler
                               0x0c
                   ; 0x04
.long p0_handler
                               0x10
                                      P0 port
                                    P1 port
                   ; 0x05
; 0x06
.long p1_handler
                               0x14
.long swt_handler
                                    SWT
                              0x18
.long ct_handler
                   ; 0x07
                              0x1c
                                    СТ
.long t8osc1_handler ; 0x08
                              0x20
                                    T8OSC1
                              0x24
                                    SVD
.long int09_handler ; 0x09
.iong lcd_handler ; 0x0a
.long t16e_0_handler ; 0x0b
.long t8f_handler ; 0x0c
.long t16_0_handler ; 0x0d
.long t16_1 handler ; 0x0d
                              0x28
                                      LCD
                               0x2c
                                      T16E ch0
                              0x30
                                    T8F
                              0x34
                                    T16 ch0
                   ; 0x0e
                              0x38 T16 ch1
.long t16_2_handler ; 0x0f
.long uart_0_handler ; 0x10
                              0x3c T16 ch2
                              0x40
                                     UART ch0
                                      UART ch1
.long uart_1_handler ; 0x11
                               0x44
                   ; 0x12
.long spi_handler
                               0x48
                                      SPT
                    ; 0x13
.long i2c_handler
                              0x4c
                                     T2C
                   ; 0x14
.long remc_handler
                              0x50 REMC
.long t16e_1_handler ; 0x15
                                   T16E ch1
                              0x54
.long int16_handler
                   ; 0x16
                              0x58
                   ; 0x17
.long int17_handler
                              0x5c
                                      _
                   ; 0x18
.long int18_handler
                               0x60
                  ; 0x19
; 0x1a
; 0x1b
.long int19_handler
                               0x64
                                      _
.long int1a_handler
                               0x68
.long int1b handler
                               0x6c
.long int1c_handler
                   ; 0x1c
                               0 \times 70
                                      _
.long int1d_handler
                   ; 0x1d
                               0x74
                                      _
                   ; 0x1e
.long int1e_handler
                               0x78
                                      _
.long intlf handler
                   ; 0x1f
                               0x7c
Program code
.text
                                                               ...(3)
.align 1
BOOT·
       ; ----- Stack pointer -----
       Xld.a %sp, 0x0f00
                                                               ...(4)
       ; ----- Memory controller ------
      Xld.a %r1, 0x5320 ; MISC register base address
       ; FLASHC
      Xld.a %r0, 0x04
                         ; 1 cycle access, under 6 MHz system clock
                                                               ...(5)
      ld.b
             [%r1], %r0
                           ; [0x5320] <= 0x04
       ; SRAMC
      Xld.a
             %r0, 0x00
                          ; 2 cycle access
             0 \times 01
       ext
                          ; [0x5321] <= 0x01
       ld.b
            [%r1], %r0
                                                               ...(6)
```

- (1) .rodata section is declared to position vector table in .vector section.
- (2) Interrupt handler routine address is defined as vector. IntXX\_handler can be used as software interrupt.
- (3) Program code is written in .text section.
- (4) Sets stack pointer.
- (5) Sets the number of flash memory controller access cycles. Can be set to 1-cycle access for C17702. (See "3 Memory Map and Bus Control.")
- (6) Sets the SRAM controller access conditions.(See "3 Memory Map and Bus Control.")

# **Revision History**

| Code No.  | Page        | Contents                                                                                                          |
|-----------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 411581700 | All         | New establishment                                                                                                 |
| 411581702 | 1-1         | Overview                                                                                                          |
|           |             | (Old) Based on an S1C17 CPU core, this product incorporates 128 KB of flash memory,                               |
|           |             | a serial interfaces supporting sensors such as UART, SPI, and I2C to support high-bit rate                        |
|           |             | 32 kHz and max. 8.2 MHz oscillator circuit, and internal 1.8 V voltage regulator.                                 |
|           |             | (New) Based on an S1C17 CPU core, this product incorporates a 128KB of flash memory,                              |
|           |             | serial interfaces such as UART supporting high-bit rate and IrDA1.0, SPI, and I <sup>2</sup> C to support various |
|           | 1-1, 1-2    | sensors, 32 kHz and max. 8.2 MHz oscillator circuits, and a 1.8 V voltage regulator.                              |
|           | 1-1, 1-2    | (Old) S5U1C17702H                                                                                                 |
|           |             | (New) S5U1C17001H                                                                                                 |
|           | 1-2         | Features: Power supply voltage detection (SVD) circuit                                                            |
|           |             | (Old) • 16-value programmable (1.7 V to 3.2 V)                                                                    |
|           |             | (New) • 15-value programmable (1.8 V to 3.2 V)                                                                    |
| -         | 1-2, 27-1,  | Features: Operating temperature                                                                                   |
|           | 27-2, 27-6, | (Old) • -20°C to 70°C                                                                                             |
|           | 27-7        | (New) • -25°C to 70°C                                                                                             |
|           | 1-3         | Features: Configuration as shipped                                                                                |
|           |             | (Old) No description                                                                                              |
|           |             | (New) • VFBGA10H-180 package (10 mm × 10 mm, ball pitch: 0.65 mm)                                                 |
|           | 1-6         | Pinout diagram: VFBGA8H-181                                                                                       |
|           |             | Modified Figure 1.3.1.2                                                                                           |
|           | 1-7         | Pinout diagram: VFBGA10H-180                                                                                      |
|           |             | Added Figure 1.3.1.3                                                                                              |
|           | 1-11        | Pin descriptions: *4: Vss ball numbers                                                                            |
|           |             | (Old) B14, F6, F M8, M14                                                                                          |
|           |             | (New) B14, F6 <sup>(note)</sup> , F M8, M14                                                                       |
|           | 2-5         | (note) The F6 pin does not exist in the VFBGA10H-180 package.                                                     |
|           | 2-5         | CPU: S1C17 core instruction list (Table 2.3.1)<br>(Old) ipa.d                                                     |
|           |             | (New) jpa.d                                                                                                       |
|           | 3-1         | S1C17702 memory map                                                                                               |
|           |             | Modified Figure 3.1                                                                                               |
|           | 3-5         | Internal RAM                                                                                                      |
|           |             | (Old) The S1C17702 enables the RAM size used to apply restrictions to 12 KB, 8 KB, 4 KB, or 2 KB                  |
|           |             | The RAM size is selected using IRAMSZ[1:0] (D[1:0]/MISC_IRAMSZ register).                                         |
|           |             | (New) Deleted                                                                                                     |
|           | 3-5, 24-6   | Internal RAM                                                                                                      |
|           |             | Modified the register table, Tables 3.3.1.1 and 24.4.2                                                            |
|           |             | Internal RAM                                                                                                      |
|           |             | (Old) Note: The IRAM Size Select Register is write-protected may result in system malfunctions.                   |
|           |             | (New) Note: • The IRAM Size Select Register is write-protected may result in system malfunctions.                 |
|           |             | Do not alter IRAMSZ[1:0] (D[1:0]/MISC_IRAMSZ register) from the default value.                                    |
|           | 4-1         | Power supply                                                                                                      |
|           |             | (Old) 4 Power Supply Voltage<br>(New) 4 Power Supply                                                              |
|           |             | Power supply: Power supply voltage                                                                                |
|           |             | (Old) Supply voltages within the respective ranges to LVDD and HVDD pins with the Vss pin as GND.                 |
|           |             | (New) Supply voltages within the range to VDD pins with the Vss pin as GND.                                       |
|           |             | Power supply: Power supply voltage                                                                                |
|           |             | (Old) The VFBGA8H-181 package has three Vod pins and nineteen Vss pins.                                           |
|           |             | (New) The VFBGA8H-181 package has three VDD pins and 19 Vss pins. The VFBGA10H-180 package has                    |
|           |             | three VDD pins and 18 Vss pins.                                                                                   |
|           | 4-5, 4-7    | Power supply: Heavy load protection function                                                                      |
|           |             | (Old) Make this setting before driving heavy loads such as lamps and buzzers using the port output.               |
|           |             | (New) VD1 may become unstable in the operations shown below and in other conditions                               |
|           |             | Note: Always cancel heavy load protection mode while it repeating the processing.                                 |
|           | 4-10        | Power supply: Precautions                                                                                         |
|           |             | (Old) No description                                                                                              |
|           |             | (New) • Always cancel heavy load protection mode while it repeating the processing.                               |
|           | 7-1         | OSC: OSC module configuration                                                                                     |
|           |             | Modified Figure 7.1.1                                                                                             |
|           | 7-2         | OSC: IOSC oscillator circuit                                                                                      |
|           |             | (Old) The oscillator clock is operated by the S1C17 core and peripheral circuits following an initial reset.      |
|           |             | (New) The S1C17 core and peripheral circuits operate with this oscillator clock after an initial reset.           |

| Code No.  | Page      | Contents                                                                                                                                                                                       |
|-----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 411581702 | 7-2       | OSC: IOSC oscillator circuit                                                                                                                                                                   |
|           |           | (Old) The IOSC oscillator circuit stops oscillating even in SLEEP mode.                                                                                                                        |
|           |           | (New) The IOSC oscillator circuit also stops oscillating in SLEEP mode.                                                                                                                        |
|           |           |                                                                                                                                                                                                |
|           |           | (Old) Following initial resetting, IOSCEN is set to 1, and the IOSC oscillator circuit is on.<br>(New) Following initial resetting, IOSCEN is set to 1 to turn the IOSC oscillator circuit on. |
|           | 7-3       | OSC: OSC3 oscillator circuit                                                                                                                                                                   |
|           | 7-0       | (Old) The OSC3 oscillator circuit stops oscillating even in SLEEP mode.                                                                                                                        |
|           |           | (New) The OSC3 oscillator circuit also stops oscillating in SLEEP mode.                                                                                                                        |
|           |           | OSC: OSC3 oscillator circuit                                                                                                                                                                   |
|           |           | (Old) No description                                                                                                                                                                           |
|           |           | (New) OSC3 external clock input                                                                                                                                                                |
|           |           | An external clock can be input to the OSC3 pin see "27 Electrical Characteristics."                                                                                                            |
|           | 7-4       | OSC: OSC1 oscillator circuit                                                                                                                                                                   |
|           |           | (Old) The OSC1 oscillator circuit stops oscillating even in SLEEP mode.                                                                                                                        |
|           | 7-5       | (New) The OSC1 oscillator circuit also stops oscillating in SLEEP mode.<br>OSC: High-speed clock (HSCLK) selection                                                                             |
|           | 7-5       | (Old) When switch the system clock between the HSCLK and OSC1 clocks, it takes switching time from                                                                                             |
|           |           | one cycle of HSCLK (min.) to one cycle of OSC1 (max.)                                                                                                                                          |
|           |           | (New) Deleted                                                                                                                                                                                  |
|           | 7-5, 7-19 | OSC: High-speed clock (HSCLK) selection                                                                                                                                                        |
|           |           | (Old) Note: Both the IOSC and OSC3 oscillator circuits the HSCLKSEL value will remain unchanged.                                                                                               |
|           |           | (New) Note: Both the IOSC and OSC3 oscillator circuits the HSCLKSEL value will remain unchanged.                                                                                               |
|           |           | When selecting HSCLK, make sure PCKEN[1:0] (D[1:0]/CLG_PCLK register) is set to 0x3 (on)                                                                                                       |
|           |           | before writing to HSCLKSEL.<br>* PCKEN(1:0): PCLK Evable Bits in the PCLK Control (CLC, PCLK) Beginter (D(1:0)/0xE090)                                                                         |
|           | 7-5       | * PCKEN[1:0]: PCLK Enable Bits in the PCLK Control (CLG_PCLK) Register (D[1:0]/0x5080)<br>OSC: System clock (OSC1 or HSCLK) selection                                                          |
|           | 7-5       | (Old) To select HSCLK as the system clock, write 0 to SRCSRC with HSCLK running.                                                                                                               |
|           |           | (New) To select HSCLK as the system clock, write 0 to CLKSRC with HSCLK running.                                                                                                               |
|           |           | When switch the system clock between the HSCLK and OSC1 clocks, it takes switching time from                                                                                                   |
|           |           | one cycle of HSCLK (min.) to one cycle of OSC1 (max.).                                                                                                                                         |
|           | 7-6       | OSC: LCD clock control                                                                                                                                                                         |
|           |           | (Old) Clock feed control                                                                                                                                                                       |
|           |           | Setting LCKEN to 1 sends the clock generated as above to the LCD driver. If no LCD display is                                                                                                  |
|           |           | required, stop the clock feed to minimize current consumption.<br>* LCKEN: LCD Clock Enable Bit in the LCD Clock Setup (OSC_LCLK) Register (D0/0x5063)                                         |
|           |           | (New) Clock feed control                                                                                                                                                                       |
|           |           | Setting LCKEN to 1 sends the clock generated as above to the LCD driver.                                                                                                                       |
|           |           | * LCKEN: LCD Clock Enable Bit in the LCD Clock Setup (OSC_LCLK) Register (D0/0x5063)                                                                                                           |
|           |           | Note: Be sure to wait at least one LCLK clock cycle before setting LCKEN to 0 to stop the LCLK                                                                                                 |
|           |           | DSPC[1:0] is set to a value other than 0x0 after LCKEN is set to 1 to resume clock feed.                                                                                                       |
|           | 7-8, 7-9  | * DSPC[1:0]: LCD Display Control Bits in the (LCD_DCTL) Register (D[1:0]/0x50a0)<br>OSC: Clock external output (FOUTH, FOUT1)                                                                  |
|           | 7-0, 7-9  | Modified Figures 7.8.1, 7.8.2, and 7.8.3                                                                                                                                                       |
|           | 7-8, 7-17 | OSC: Clock external output (FOUTH, FOUT1)                                                                                                                                                      |
|           | ,         | Modified Table 7.8.1                                                                                                                                                                           |
|           | 7-8       | OSC: FOUTH clock frequency selection                                                                                                                                                           |
|           |           | (Old) Select the division ratio for the OSC3 clock using FOUTHD[1:0] (D[3:2]/OSC_FOUT register).                                                                                               |
|           |           | (New) Select the division ratio for the OSC3 clock using FOUTHD[1:0] (D[3:2]/OSC_FOUT                                                                                                          |
|           |           | register).                                                                                                                                                                                     |
|           | 7-10      | OSC: RESET and NMI input noise filters                                                                                                                                                         |
|           |           | (Old) Note: • All noise filters should normally be enabled.                                                                                                                                    |
|           |           | (New) Note: • The RESET input noise filter should normally be enabled.                                                                                                                         |
|           | 7-19      | OSC: Precautions                                                                                                                                                                               |
|           |           | (Old) No description<br>(New) • Be sure to wait at least one LCLK clock 0x0 after LCKEN is set to 1 to resume clock feed.                                                                      |
|           | 8-1       | CLG: CLG module configuration                                                                                                                                                                  |
|           | 0-1       | Modified Figure 8.1.1                                                                                                                                                                          |
|           | 8-3       | CLG: Peripheral module clock control circuit                                                                                                                                                   |
|           |           | Modified Figure 8.3.1                                                                                                                                                                          |
|           | 8-5, 8-7  | CLG: PCLK Control Register (CLG_PCLK) - (D[1:0]) PCKEN[1:0]: PCLK Enable Bits                                                                                                                  |
|           |           | (Old) Peripheral modules operated using PCLK                                                                                                                                                   |
|           |           | • 16-bit timer Ch.0 to 2                                                                                                                                                                       |
|           |           | Interrupt controller                                                                                                                                                                           |
|           |           | SPI (New) Peripheral modules operated using PCLK                                                                                                                                               |
|           |           | (New) Peripheral modules operated using PCLK<br>• 16-bit timer Ch.0 to Ch.2                                                                                                                    |
|           |           | • SPI                                                                                                                                                                                          |

| Code No.  | Page  | Contents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 411581702 | 10-8  | P: Port input interrupt circuit configuration<br>Modified Figure 10.7.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 10-9  | <ul> <li>P: Interrupt flags</li> <li>(Old) Setting the corresponding PxIE[7:0] to 1 sets PxIF[7:0] to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port interrupt request signal is also output to the ITC at the same time.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |       | (New) PxIF[7:0] is set to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port<br>interrupt request signal is also output to the ITC at the same time if the corresponding PxIE[7:0] is<br>set to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 10-18 | <ul> <li>P: Px Port Interrupt Flag Registers (Px_IFLG) - (D[7:0]) PxIF[7:0]: Px[7:0] Port Interrupt Flags</li> <li>(Old) Setting the corresponding PxIE[7:0] (Px_IMSK register) to 1 sets PxIF[7:0] to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port interrupt request signal is also output to the ITC at the same time.</li> <li>(New) PxIF[7:0] is set to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port interrupt request signal is also output to the ITC at the same time.</li> <li>(New) PxIF[7:0] is set to 1 at the specified edge (rising or falling edge) of the input signal. A P0 or P1 port interrupt request signal is also output to the ITC at the same time if the corresponding PxIE[7:0] (Px_IMSK register) is set to 1.</li> </ul> |
|           | 13-1  | T16E: PWM & capture timer configuration<br>Modified Figure 13.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           | 18-1  | UART: UART Configuration<br>Modified Figure 18.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | 18-6  | UART: Data transfer control<br>Modified Figure 18.5.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 18-6  | <ul> <li>UART: Data reception control</li> <li>(Old) (2) RDRY = 1, RD2B = 0<br/>Read the receive data buffer contents once to clear the data inside the buffer and reset the<br/>RDRY flag</li> <li>(3) RDRY = 1, RD2B = 1</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |       | The receive data buffer outputs the oldest data first, clearing the buffer data read out and reset-<br>ting the RD2B flag<br>Even when the receive buffer is full, and the new data will overprogram the shift register data.<br>(New) (2) RDRY = 1, RD2B = 0<br>Read the receive data buffer contents once. This resets the RDRY flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           |       | (3) RDRY = 1, RD2B = 1<br>The receive data buffer outputs the oldest data first. This resets the RD2B flag<br>Even when the receive data buffer is full, the shift register can start receiving 8-bit data one more<br>time. An overrun error will occur if receiving is finished before the receive data buffer has been<br>read. In this case, the last received data cannot be read.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 18-7  | UART: Data reception control<br>Modified Figure 18.5.2<br>UART: Blocking data transfers<br>(Old) Setting the RXEN bit to 0 empties the transmission and receive data buffers, clearing any remaining<br>data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|           | 18-8  | <ul> <li>(New) Setting the RXEN bit to 0 empties the transmission data buffer, clearing any remaining data.</li> <li>UART: Overrun error</li> <li>(Old) However, if the receive data buffer is not emptied A fourth item of data sent in this state will over-<br/>program the third item of data in the shift register and generate an overrun error.</li> <li>(New) However, if the receive data buffer is not emptied sent to the buffer and an overrun error will occur.</li> </ul>                                                                                                                                                                                                                                                                                                                                                |
|           | 18-14 | <ul> <li>UART: UART Ch.x Status Registers (UART_STx)</li> <li>(Old) 0x4100: UART Status Register (UART_ST)</li> <li>(New) 0x4100/0x4120: UART Ch.x Status Registers (UART_STx)<br/>Modified the register table</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           |       | UART: UART Ch. <i>x</i> Status Registers (UART_ST <i>x</i> )<br>- (D6) FER: Framing Error Flag<br>- (D5) PER: Parity Error Flag<br>- (D4) OER: Overrun Error Flag<br>(Old) FER/PER/OER is reset by writing as 1 or by setting RXEN (D0/UART_CTL <i>x</i> register) to 0.<br>(New) FER/PER/OER is reset by writing 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | 18-19 | UART: UART Ch.x Control Registers (UART_CTLx) - (D0) RXEN: UART Enable Bit<br>(Old) Preventing transfers by writing 0 to RXEN also clears transfer data buffers.<br>(New) Preventing transfers by writing 0 to RXEN also clears transmit data buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 18-21 | UART: Precautions<br>(Old) • The following UART bits should be set with transfers blocked (RXEN = 0)<br>- All UART_CTLx register (0x4104/0x4124) bits other than RXEN (RBFI, TIEN, RIEN, REIEN)<br>(New) • The following UART bits should be set with transfers blocked (RXEN = 0)<br>- RBFI bit in the UART_CTLx register (0x4104/0x4124)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Code No.  | Page             | Contents                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 411581702 | 18-21            | UART: Precautions<br>(Old) Preventing transfer by setting RXEN to 0 clears (initializes) transfer data buffers. Before writing 0 to                                                                                                                                                                                                                                                                                     |
|           |                  | <ul> <li>RXEN, confirm the absence of data in the buffers awaiting transmission or reading.</li> <li>(New) Preventing transfer by setting RXEN to 0 clears (initializes) the transmit data buffer. Before writing 0 to RXEN, confirm the absence of data in the buffer awaiting transmission.</li> </ul>                                                                                                                |
|           | 19-3             | SPI: SPI clock                                                                                                                                                                                                                                                                                                                                                                                                          |
|           | 10 0             | <ul> <li>(Old) The Master mode SPI uses the internal clock output by the 16-bit timer Ch.1 as the SPI clock<br/>Use the MCLK (D9/SPI_CTL register) to select to use the 16-bit timer Ch.1 output clock or PCLK-<br/>1/4 clock.</li> </ul>                                                                                                                                                                               |
|           |                  | (New) The Moster mode SPI uses the 16-bit timer Ch.1 output clock or a PCLK-1/4 clock to generate the<br>Use MCLK (D9/SPI_CTL register) to select whether the 16-bit timer Ch.1 output clock or PCLK-1/4<br>clock is used.                                                                                                                                                                                              |
|           | 19-3             | SPI: SPI clock                                                                                                                                                                                                                                                                                                                                                                                                          |
|           |                  | Modified Figure 19.3.1                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |                  | <ul> <li>SPI: SPI clock</li> <li>(Old) Since the internal circuit operates in sync with the PCLK clock, the input clock is used to synchro-<br/>nize the differentiated PCLK clock.</li> </ul>                                                                                                                                                                                                                          |
|           |                  | (New) Deleted                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | 19-3, 19-14      | SPI: SPI clock<br>(Old) Note: The frequency of the clock input via the SPICLK pin must be less than 1/3 of the PCLK and                                                                                                                                                                                                                                                                                                 |
|           |                  | have a clock duty ratio of 50%.<br>(New) Note: The duty ratio of the clock input via the SPICLK pin must be 50%.<br>Deleted Figure 19.3.2                                                                                                                                                                                                                                                                               |
|           | 19-4, 19-14      | SPI: Data transfer condition settings<br>(Old) No description                                                                                                                                                                                                                                                                                                                                                           |
|           |                  | (New) Note: When the SPI module is used in master mode with CPHA set to 0, (Added Figure 19.4.2)<br>transmit data bits and the second and following bytes during continuous transfer.                                                                                                                                                                                                                                   |
|           | 19-5             | SPI: Data transmission timing chart<br>Deleted Figure 19.5.1                                                                                                                                                                                                                                                                                                                                                            |
|           |                  | SPI: Data receipt control<br>(Old) Writing to the SPI TXD register creates the trigger for receipt as well as transmission start.<br>(New) Writing to the SPI_TXD register creates the trigger for receipt as well as transmission start.                                                                                                                                                                               |
|           | 19-6             | SPI: Data transmission/receiving timing chart<br>Modified Figure 19.5.1                                                                                                                                                                                                                                                                                                                                                 |
|           |                  | SPI: Blocking data transfers                                                                                                                                                                                                                                                                                                                                                                                            |
|           |                  | <ul> <li>(Old) After a data transfer is completed the SPRBF flag is 0 before blocking data transfer.<br/>Setting the SPEN bit to 0 empties if SPEN is set to 0 while data is being sent or received.</li> <li>(New) After a data transfer is completed the SPBSY flag is 0 before blocking data transfer.<br/>The data being transferred cannot be if SPEN is set to 0 while data is being sent or received.</li> </ul> |
|           | 19-7             | SPI: Transmit buffer empty interrupt<br>(Old) If SPTBE is 0, the next transmission data can be written by the interrupt handler routine.<br>(New) If SPTBE is 1, the next transmission data can be written by the interrupt handler routine.                                                                                                                                                                            |
|           | 19-10, 19-14     | SPI: SPI Transmit Data Register (SPI_TXD)<br>(Old) No description                                                                                                                                                                                                                                                                                                                                                       |
|           |                  | (New) Note: Make sure that SPEN (D0/SPI_CTL register) is set to start data transmission/reception.                                                                                                                                                                                                                                                                                                                      |
|           | 20-1 to<br>20-18 | I <sup>2</sup> C<br>(Old) NAK, NACK<br>(New) NAK                                                                                                                                                                                                                                                                                                                                                                        |
|           | 20-2             | Added Figure 20.2.1                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | 20-3             | I <sup>2</sup> C: I <sup>2</sup> C clock (upper limit of transfer rate)<br>(Old) No description                                                                                                                                                                                                                                                                                                                         |
|           | 20-5             | (New) When the I <sup>2</sup> C module is used to 50 kbps in standard mode or 200 kbps in fast mode.<br>I <sup>2</sup> C: Slave address transmission                                                                                                                                                                                                                                                                    |
|           |                  | (Old) In 10-bit mode, data is sent twice under software control<br>(New) In 10-bit mode, data is sent twice or three times under software control                                                                                                                                                                                                                                                                       |
|           | 20-6             | I <sup>2</sup> C: Slave address and transmission data specifying transfer direction<br>Modified Figure 20.5.2                                                                                                                                                                                                                                                                                                           |
|           | 20-7             | <ul> <li>I<sup>2</sup>C: Data receipt control</li> <li>(Old) The data is loaded to the shift register in sequence at the clock rising edge, with the MSB leading.<br/>RXE is reset to 0 when D6 is loaded.</li> </ul>                                                                                                                                                                                                   |
|           |                  | (New) The data is shifted into the shift register from the MSB first in sync with the clock.<br>RXE is reset to 0 when D7 is loaded.                                                                                                                                                                                                                                                                                    |
|           |                  | <ul> <li>I<sup>2</sup>C: Data receipt control</li> <li>(Old) This flag is 1 when receiving starts and reverts to 0 when the data is received. It also reverts to 0 for<br/>the Wait state.</li> </ul>                                                                                                                                                                                                                   |
|           |                  | (New) This flag is 1 when receiving starts and reverts to 0 when the data is received.                                                                                                                                                                                                                                                                                                                                  |

| Code No.  | Page         | Contents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 411581702 | 20-8         | I <sup>2</sup> C: Data transfer end (Stop condition generation)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           |              | (Old) Stop condition generation can be reserved. To reserve the stop condition, check that I <sup>2</sup> C is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           |              | The stop condition is generated as soon as data transfer (including ACK transfer) ends.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |              | (New) Before STP can be set to 1, confirm that TBUSY or RBUSY is reset to 0 from 1 (this indicates                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           |              | has finished and the time for the slave device to finish clock stretching has elapsed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |              | I <sup>2</sup> C: Wait state for TXE, RXE, STRT, and STP settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |              | (Old) Wait state for TXE, RXE, STRT, and STP settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           |              | The module will switch to Wait state with the SCL output fixed at Low if all of the TXE (D9/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           |              | by writing 1 to TXE or RXE to restart data transfer or by generating the stop condition with STP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |              | (New) Deleted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           |              | I <sup>2</sup> C: Prohibiting data transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           |              | (Old) After data transfer is complete (both transmission and receipt), program 0 to the I2CEN bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |              | Data being transferred cannot be guaranteed if I2CEN is set to 0 during the transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           |              | (New) After the stop condition has been generated, write 0 to I2CEN to disable data transfers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           |              | the SCL and SDA output levels and transfer data at that point cannot be guaranteed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 20-9, 20-10  | I <sup>2</sup> C: Timing chart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           |              | Modified Figures 20.5.6 to 20.5.9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 20-11        | I <sup>2</sup> C: Transmit buffer empty interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |              | (Old) An interrupt occurs if other interrupt conditions are satisfied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |              | (New) The transmit buffer empty interrupt will only occur during data transmission.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           |              | To clear the cause of transmit buffer empty interrupt<br>The cause of transmit buffer empty interrupt cause of interrupt without sending the data written.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           |              | <ul> <li>* TXE: Transmit Execution Bit in the I<sup>2</sup>C Data (I2C_DAT) Register (D9/0x4344)</li> <li>I<sup>2</sup>C: Receive buffer full interrupt</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           |              | (Old) An interrupt occurs if other interrupt conditions are met.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           |              | (New) The receive buffer full interrupt will only occur during data reception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           |              | To clear the cause of receive buffer full interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           |              | The cause of receive buffer full interrupt can be cleared from RTDT[7:0].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|           |              | Note: After an I <sup>2</sup> C interrupt occurs, Note that it cannot be checked using a register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | 20-14        | I <sup>2</sup> C: I <sup>2</sup> C Control Register (I2C_CTL) - (D1) STP: Stop Control Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           |              | (Old) Note that the stop condition will be generated only if STP is 1 and TXE (D9/I2C_DAT register),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           |              | STP is disabled if any of TXE, RXE, or STRT is 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |              | (New) Before STP can be set to 1, confirm that TBUSY or RBUSY is reset to 0 from 1 (this indicates                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           |              | has finished and the time for the slave device to finish clock stretching has elapsed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           | 20-16        | I <sup>2</sup> C: I <sup>2</sup> C Data Register (I2C_DAT) - (D10) RXE: Receive Execution Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           |              | (Old) RXE is reset to 0 as soon as D6 is loaded to the shift register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |              | (New) RXE is reset to 0 as soon as D7 is loaded to the shift register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           | 22-9, 22-14, | LCD: Display on/off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 22-21        | (Old) No description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           |              | (New) Note: The LCD power supply may not generate the drive voltage normally if DSPC[1:0] is set to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           |              | 3. The LCD clock supply is enabled and the clock is fed into the LCD driver circuit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           |              | LCD: Display on/off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           |              | (Old) DSPC[1:0] is reset to 0x0 (Display off) after initial resetting or when the slp instruction is executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           |              | (New) DSPC[1:0] is reset to 0x0 (Display off) after initial resetting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |              | Note: Executing the slp instruction via software before executing the slp instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |              | SVD: Comparison voltage setting                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 27-3, AP-22  | (Old) Comparison voltage: 16 voltages, SVDC[3:0] = 0x0: 1.7 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           | 07.7         | (New) Comparison voltage: 15 voltages, SVDC[3:0] = 0x0: reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | 27-7         | External clock input AC characteristics<br>Modified the characteristic table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           | 07.11        | LCD drive voltage temperature characteristics, SVD voltage temperature characteristics, SVD voltage tem-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | 27-11,       | perature characteristics, Execution current consumption temperature characteristics, SVD voltage tem-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | 21-12, 21-13 | Modified the graphs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 28-3         | VFBGA10H-180 package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | 20-3         | Added the figure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | AP-28        | I/O register list: IRAM Size Select Register (MISC_IRAMSZ)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           | 711-20       | Modified the table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | AP-35        | Power saving: Clock system                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           |              | Modified Table C.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | AP-36        | Power saving: Peripheral clock (PCLK)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | 71-30        | (Old) Peripheral circuits operating with PCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           |              | • 16-bit timer Ch.0 to Ch.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           |              | Interrupt controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           |              | • SPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           |              | (New) Peripheral circuits operating with PCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           |              | • 16-bit timer Ch.0 to Ch.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           |              | • SPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| L         |              | le se la seconda de la seconda d |

# **EPSON**

# **International Sales Operations**

## AMERICA

#### **EPSON ELECTRONICS AMERICA, INC.**

2580 Orchard Parkway, San Jose, CA 95131, USA Phone: +1-800-228-3964

Fax: +1-408-922-0238

## **EUROPE**

#### **EPSON EUROPE ELECTRONICS GmbH**

Riesstrasse 15, 80992 Munich, GERMANY

Phone: +49-89-14005-0

Fax: +49-89-14005-110

#### ASIA

#### EPSON (CHINA) CO., LTD.

7F, Jinbao Bldg., No.89 Jinbao St., Dongcheng District, Beijing 100005, CHINA Phone: +86-10-8522-1199 Fa

Fax: +86-10-8522-1125

#### SHANGHAI BRANCH

7F, Block B, Hi-Tech Bldg., 900 Yishan Road, Shanghai 200233, CHINA Phone: +86-21-5423-5577 Fax: +86-21-5423-4677

#### SHENZHEN BRANCH

12F, Dawning Mansion, Keji South 12th Road, Hi-Tech Park, Shenzhen 518057, CHINA Phone: +86-755-2699-3828 Fax: +86-755-2699-3838

#### EPSON HONG KONG LTD.

20/F, Harbour Centre, 25 Harbour Road, Wanchai, Hong Kong Phone: +852-2585-4600 Fax: +852-2827-4346 Telex: 65542 EPSCO HX

#### EPSON TAIWAN TECHNOLOGY & TRADING LTD.

14F, No. 7, Song Ren Road, Taipei 110, TAIWAN Phone: +886-2-8786-6688 Fax: +886-2-8786-6660

#### **EPSON SINGAPORE PTE., LTD.**

 1 HarbourFront Place,

 #03-02 HarbourFront Tower One, Singapore 098633

 Phone: +65-6586-5500
 Fax: +65-6271-3182

#### SEIKO EPSON CORP. KOREA OFFICE

5F, KLI 63 Bldg., 60 Yoido-dong,

Youngdeungpo-Ku, Seoul 150-763, KOREA Phone: +82-2-784-6027 Fax: +82-2-767-3677

#### SEIKO EPSON CORP. MICRODEVICES OPERATIONS DIVISION

#### Device Sales & Marketing Dept.

421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN Phone: +81-42-587-5814 Fax: +81-42-587-5117

> Document Code: 411581702 First Issue October 2008 D Revised April 2011 in JAPAN D